DynamicSearchRequest.cs 6.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273
  1. namespace OASystem.API.OAMethodLib.GenericSearch
  2. {
  3. /// <summary>
  4. /// 动态搜索请求
  5. /// </summary>
  6. public class DynamicSearchRequest
  7. {
  8. /// <summary>
  9. /// 搜索关键词
  10. /// </summary>
  11. public string Keyword { get; set; }
  12. /// <summary>
  13. /// 字段权重配置(字段名:权重值)
  14. /// </summary>
  15. public Dictionary<string, int> FieldWeights { get; set; } = new Dictionary<string, int>();
  16. /// <summary>
  17. /// 返回字段列表(为空则返回所有字段)
  18. /// </summary>
  19. public List<string> ReturnFields { get; set; } = new List<string>();
  20. /// <summary>
  21. /// 过滤条件
  22. /// </summary>
  23. public List<SearchFilter> Filters { get; set; } = new List<SearchFilter>();
  24. /// <summary>
  25. /// 排序字段
  26. /// </summary>
  27. public string OrderBy { get; set; }
  28. /// <summary>
  29. /// 是否降序排序
  30. /// </summary>
  31. public bool IsDescending { get; set; } = true;
  32. /// <summary>
  33. /// 页码(从1开始)
  34. /// </summary>
  35. public int PageIndex { get; set; } = 1;
  36. /// <summary>
  37. /// 页大小
  38. /// </summary>
  39. public int PageSize { get; set; } = 20;
  40. /// <summary>
  41. /// 是否要求所有单字必须完全出现(新增参数)
  42. /// </summary>
  43. public bool RequireAllSingleChars { get; set; } = false;
  44. }
  45. /// <summary>
  46. /// 搜索过滤器
  47. /// </summary>
  48. public class SearchFilter
  49. {
  50. /// <summary>
  51. /// 字段名
  52. /// </summary>
  53. public string Field { get; set; }
  54. /// <summary>
  55. /// 操作符(eq, neq, contains, startswith, endswith, gt, gte, lt, lte, in)
  56. /// </summary>
  57. public string Operator { get; set; }
  58. /// <summary>
  59. /// 字段值
  60. /// </summary>
  61. public object Value { get; set; }
  62. /// <summary>
  63. /// 字段值列表(用于IN操作)
  64. /// </summary>
  65. public List<object> Values { get; set; }
  66. }
  67. /// <summary>
  68. /// 匹配字段信息
  69. /// </summary>
  70. public class MatchFieldInfo
  71. {
  72. /// <summary>
  73. /// 字段名
  74. /// </summary>
  75. public string FieldName { get; set; }
  76. /// <summary>
  77. /// 字段值
  78. /// </summary>
  79. public string FieldValue { get; set; }
  80. /// <summary>
  81. /// 匹配分数
  82. /// </summary>
  83. public int Score { get; set; }
  84. /// <summary>
  85. /// 匹配原因
  86. /// </summary>
  87. public string MatchReason { get; set; }
  88. }
  89. /// <summary>
  90. /// 搜索结果项(包含匹配度分数)
  91. /// </summary>
  92. /// <typeparam name="T">实体类型</typeparam>
  93. public class SearchResultItem<T>
  94. {
  95. /// <summary>
  96. /// 实体数据
  97. /// </summary>
  98. public T Data { get; set; }
  99. /// <summary>
  100. /// 匹配度分数
  101. /// </summary>
  102. public int MatchScore { get; set; }
  103. /// <summary>
  104. /// 匹配字段信息
  105. /// </summary>
  106. public List<MatchFieldInfo> MatchFields { get; set; } = new List<MatchFieldInfo>();
  107. }
  108. /// <summary>
  109. /// 搜索结果(应用层统计匹配度)
  110. /// </summary>
  111. /// <typeparam name="T">实体类型</typeparam>
  112. public class SearchResult<T>
  113. {
  114. /// <summary>
  115. /// 是否成功
  116. /// </summary>
  117. public bool Success { get; set; } = true;
  118. /// <summary>
  119. /// 消息
  120. /// </summary>
  121. public string Message { get; set; } = "搜索成功";
  122. /// <summary>
  123. /// 数据列表(包含匹配度信息)
  124. /// </summary>
  125. public List<SearchResultItem<T>> Items { get; set; } = new List<SearchResultItem<T>>();
  126. /// <summary>
  127. /// 总记录数
  128. /// </summary>
  129. public int TotalCount { get; set; }
  130. /// <summary>
  131. /// 搜索关键词
  132. /// </summary>
  133. public string Keyword { get; set; }
  134. /// <summary>
  135. /// 使用的字段权重配置
  136. /// </summary>
  137. public Dictionary<string, int> FieldWeights { get; set; }
  138. /// <summary>
  139. /// 返回的字段列表
  140. /// </summary>
  141. public List<string> ReturnFields { get; set; }
  142. /// <summary>
  143. /// 页码
  144. /// </summary>
  145. public int PageIndex { get; set; }
  146. /// <summary>
  147. /// 页大小
  148. /// </summary>
  149. public int PageSize { get; set; }
  150. /// <summary>
  151. /// 响应时间(毫秒)
  152. /// </summary>
  153. public long ResponseTime { get; set; }
  154. /// <summary>
  155. /// 搜索ID(用于追踪)
  156. /// </summary>
  157. public string SearchId { get; set; }
  158. }
  159. /// <summary>
  160. /// 字段信息
  161. /// </summary>
  162. public class FieldInfo
  163. {
  164. /// <summary>
  165. /// 字段名
  166. /// </summary>
  167. public string FieldName { get; set; }
  168. /// <summary>
  169. /// 显示名称
  170. /// </summary>
  171. public string DisplayName { get; set; }
  172. /// <summary>
  173. /// 数据类型
  174. /// </summary>
  175. public string DataType { get; set; }
  176. /// <summary>
  177. /// 是否可搜索
  178. /// </summary>
  179. public bool IsSearchable { get; set; }
  180. /// <summary>
  181. /// 默认权重
  182. /// </summary>
  183. public int DefaultWeight { get; set; }
  184. /// <summary>
  185. /// 字段描述
  186. /// </summary>
  187. public string Description { get; set; }
  188. /// <summary>
  189. /// 是否可过滤
  190. /// </summary>
  191. public bool CanFilter { get; set; } = true;
  192. /// <summary>
  193. /// 是否可排序
  194. /// </summary>
  195. public bool CanSort { get; set; } = true;
  196. }
  197. /// <summary>
  198. /// 搜索分析结果
  199. /// </summary>
  200. public class SearchAnalysis
  201. {
  202. /// <summary>
  203. /// 原始关键词
  204. /// </summary>
  205. public string OriginalKeyword { get; set; }
  206. /// <summary>
  207. /// 是否有特殊符号
  208. /// </summary>
  209. public bool HasSpecialSymbols { get; set; }
  210. /// <summary>
  211. /// 符号分割的段
  212. /// </summary>
  213. public List<string> SymbolSegments { get; set; } = new List<string>();
  214. /// <summary>
  215. /// 是否是单字
  216. /// </summary>
  217. public bool IsSingleChar { get; set; }
  218. /// <summary>
  219. /// 单字列表
  220. /// </summary>
  221. public List<char> SingleChars { get; set; } = new List<char>();
  222. /// <summary>
  223. /// 是否有搜索内容
  224. /// </summary>
  225. public bool HasSearchContent => HasSpecialSymbols || IsSingleChar;
  226. }
  227. }