DBSingle.cs 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Data.SQLite;
  4. using System.Linq;
  5. using System.Text;
  6. using System.Threading.Tasks;
  7. namespace MeterVision.db
  8. {
  9. public class DBSingle
  10. {
  11. public static bool InsertTSingleDetail0(TSingleDetail singlDetail)
  12. {
  13. // 构建插入的 SQL 语句
  14. string sql = "INSERT INTO t_single_detail (single_detail_id, create_time, src_image) " +
  15. "VALUES (@SingleDetailId, @CreateTime, @SrcImage)";
  16. // 创建参数数组
  17. SQLiteParameter[] parameters = new SQLiteParameter[]
  18. {
  19. new SQLiteParameter("@SingleDetailId", singlDetail.SingleDetailId),
  20. new SQLiteParameter("@CreateTime", singlDetail.CreateTime),
  21. new SQLiteParameter("@SrcImage", singlDetail.SrcImage)
  22. };
  23. try
  24. {
  25. // 调用 SQLiteHelper 执行插入操作
  26. int rowsAffected = SQLiteHelper.ExecuteSql(sql, parameters);
  27. // 如果插入成功,返回 true,否则返回 false
  28. return rowsAffected > 0;
  29. }
  30. catch (Exception ex)
  31. {
  32. // 处理异常(如果有的话)
  33. Console.WriteLine("Error inserting data: " + ex.Message);
  34. return false;
  35. }
  36. }
  37. public static bool InsertSingleDetail(TSingleDetail detail)
  38. {
  39. // 定义 SQL 插入语句
  40. string sql = @"
  41. INSERT INTO t_single_detail (
  42. single_detail_id, create_time, src_image, run_flag, run_time,
  43. dst_image, meter_type, digit_count, pointer_count, last_unit,
  44. result_type, raw_value, final_value, ai_ver, debug_info, log_path
  45. )
  46. VALUES (
  47. @SingleDetailId, @CreateTime, @SrcImage, @RunFlag, @RunTime,
  48. @DstImage, @MeterType, @DigitCount, @PointerCount, @LastUnit,
  49. @ResultType, @RawValue, @FinalValue, @AiVer, @DebugInfo, @LogPath
  50. );
  51. ";
  52. // 创建 SQL 参数
  53. SQLiteParameter[] parameters = new SQLiteParameter[]
  54. {
  55. new SQLiteParameter("@SingleDetailId", detail.SingleDetailId),
  56. new SQLiteParameter("@CreateTime", detail.CreateTime),
  57. new SQLiteParameter("@SrcImage", detail.SrcImage),
  58. new SQLiteParameter("@RunFlag", detail.RunFlag),
  59. new SQLiteParameter("@RunTime", detail.RunTime),
  60. new SQLiteParameter("@DstImage", detail.DstImage),
  61. new SQLiteParameter("@MeterType", detail.MeterType),
  62. new SQLiteParameter("@DigitCount", detail.DigitCount),
  63. new SQLiteParameter("@PointerCount", detail.PointerCount),
  64. new SQLiteParameter("@LastUnit", detail.LastUnit),
  65. new SQLiteParameter("@ResultType", detail.ResultType),
  66. new SQLiteParameter("@RawValue", detail.RawValue),
  67. new SQLiteParameter("@FinalValue", detail.FinalValue),
  68. new SQLiteParameter("@AiVer", detail.AiVer),
  69. new SQLiteParameter("@DebugInfo", detail.DebugInfo),
  70. new SQLiteParameter("@LogPath", detail.LogPath)
  71. };
  72. // 执行插入操作并返回受影响的行数
  73. return SQLiteHelper.ExecuteNonQuery(sql, parameters) > 0;
  74. }
  75. public static bool UpdateSingleDetailByConfig(TSingleDetail detail)
  76. {
  77. // 定义 SQL 更新语句
  78. string sql = @"
  79. UPDATE t_single_detail
  80. SET meter_type = @MeterType,
  81. digit_count = @DigitCount,
  82. pointer_count = @PointerCount,
  83. last_unit = @LastUnit,
  84. bright_val = @BrightVal,
  85. flow_rate = @FlowRate,
  86. meter_region = @MeterRegion,
  87. feature_region = @FeatureRegion,
  88. last_value = @LastValue,
  89. last_time = @LastTime
  90. WHERE single_detail_id = @SingleDetailId;";
  91. // 创建 SQL 参数
  92. SQLiteParameter[] parameters = new SQLiteParameter[]
  93. {
  94. new SQLiteParameter("@SingleDetailId", detail.SingleDetailId),
  95. new SQLiteParameter("@MeterType", detail.MeterType),
  96. new SQLiteParameter("@DigitCount", detail.DigitCount),
  97. new SQLiteParameter("@PointerCount", detail.PointerCount),
  98. new SQLiteParameter("@LastUnit", detail.LastUnit),
  99. new SQLiteParameter("@BrightVal", detail.BrightVal),
  100. new SQLiteParameter("@FlowRate", detail.FlowRate),
  101. new SQLiteParameter("@MeterRegion", detail.MeterRegion),
  102. new SQLiteParameter("@FeatureRegion", detail.FeatureRegion),
  103. new SQLiteParameter("@LastValue", detail.LastValue),
  104. new SQLiteParameter("@LastTime", detail.LastTime)
  105. };
  106. // 执行更新操作并返回受影响的行数
  107. return SQLiteHelper.ExecuteNonQuery(sql, parameters) > 0;
  108. }
  109. //识别结果引发的更改
  110. public static bool UpdateSingleDetailByResult(TSingleDetail detail)
  111. {
  112. // 定义 SQL 更新语句
  113. string sql = @"
  114. UPDATE t_single_detail
  115. SET run_flag = @RunFlag,
  116. run_time = @RunTime,
  117. dst_image = @DstImage,
  118. result_type = @ResultType,
  119. raw_value = @RawValue,
  120. final_value = @FinalValue,
  121. ai_ver = @AiVer,
  122. debug_info = @DebugInfo,
  123. log_path = @LogPath
  124. WHERE single_detail_id = @SingleDetailId;";
  125. // 创建 SQL 参数
  126. SQLiteParameter[] parameters = new SQLiteParameter[]
  127. {
  128. new SQLiteParameter("@SingleDetailId", detail.SingleDetailId),
  129. new SQLiteParameter("@RunFlag", detail.RunFlag),
  130. new SQLiteParameter("@RunTime", detail.RunTime),
  131. new SQLiteParameter("@DstImage", detail.DstImage),
  132. new SQLiteParameter("@LastUnit", detail.LastUnit),
  133. new SQLiteParameter("@ResultType", detail.ResultType),
  134. new SQLiteParameter("@RawValue", detail.RawValue),
  135. new SQLiteParameter("@FinalValue", detail.FinalValue),
  136. new SQLiteParameter("@AiVer", detail.AiVer),
  137. new SQLiteParameter("@DebugInfo", detail.DebugInfo),
  138. new SQLiteParameter("@LogPath", detail.LogPath)
  139. };
  140. // 执行更新操作并返回受影响的行数
  141. return SQLiteHelper.ExecuteNonQuery(sql, parameters) > 0;
  142. }
  143. //更改备注信息
  144. public static bool UpdateSingleDetailMemo(string detailId,string memo)
  145. {
  146. // 定义 SQL 更新语句
  147. string sql = @"
  148. UPDATE t_single_detail
  149. SET memo = @Memo
  150. WHERE single_detail_id = @SingleDetailId;";
  151. // 创建 SQL 参数
  152. SQLiteParameter[] parameters = new SQLiteParameter[]
  153. {
  154. new SQLiteParameter("@SingleDetailId", detailId),
  155. new SQLiteParameter("@Memo", memo)
  156. };
  157. // 执行更新操作并返回受影响的行数
  158. return SQLiteHelper.ExecuteNonQuery(sql, parameters) > 0;
  159. }
  160. public static Tuple<int,int, List<TSingleDetail>> GetPagedSingleDetails(int pageNumber, int pageSize)
  161. {
  162. // 计算 OFFSET 值
  163. int offset = (pageNumber - 1) * pageSize;
  164. // 定义 SQL 查询语句,带有分页
  165. string sql = @"
  166. SELECT single_detail_id, create_time, src_image, run_flag, run_time,
  167. dst_image, meter_type, digit_count, pointer_count, last_unit,
  168. result_type, raw_value, final_value, ai_ver, debug_info, log_path, memo,
  169. bright_val,flow_rate,meter_region,feature_region,last_value,last_time
  170. FROM t_single_detail
  171. ORDER BY create_time DESC
  172. LIMIT @PageSize OFFSET @Offset;";
  173. // 创建 SQL 参数
  174. SQLiteParameter[] parameters = new SQLiteParameter[]
  175. {
  176. new SQLiteParameter("@PageSize", pageSize),
  177. new SQLiteParameter("@Offset", offset)
  178. };
  179. // 执行查询并获取结果
  180. List<TSingleDetail> details = new List<TSingleDetail>();
  181. using (SQLiteDataReader reader = SQLiteHelper.ExecuteReader(sql, parameters))
  182. {
  183. while (reader.Read())
  184. {
  185. // 将查询结果映射到 TSingleDetail 对象
  186. TSingleDetail detail = new TSingleDetail
  187. {
  188. SingleDetailId = reader.GetString(reader.GetOrdinal("single_detail_id")),
  189. CreateTime = reader.GetString(reader.GetOrdinal("create_time")),
  190. SrcImage = reader.GetString(reader.GetOrdinal("src_image")),
  191. RunFlag = reader.GetInt32(reader.GetOrdinal("run_flag")),
  192. RunTime = reader.GetString(reader.GetOrdinal("run_time")),
  193. DstImage = reader.GetString(reader.GetOrdinal("dst_image")),
  194. MeterType = reader.GetInt32(reader.GetOrdinal("meter_type")),
  195. DigitCount = reader.GetInt32(reader.GetOrdinal("digit_count")),
  196. PointerCount = reader.GetInt32(reader.GetOrdinal("pointer_count")),
  197. LastUnit = reader.GetString(reader.GetOrdinal("last_unit")),
  198. ResultType = reader.GetInt32(reader.GetOrdinal("result_type")),
  199. RawValue = reader.GetString(reader.GetOrdinal("raw_value")),
  200. FinalValue = reader.GetString(reader.GetOrdinal("final_value")),
  201. AiVer = reader.GetString(reader.GetOrdinal("ai_ver")),
  202. DebugInfo = reader.GetString(reader.GetOrdinal("debug_info")),
  203. LogPath = reader.GetString(reader.GetOrdinal("log_path")),
  204. Memo = reader.GetString(reader.GetOrdinal("memo")),
  205. BrightVal = reader.GetDouble(reader.GetOrdinal("bright_val")),
  206. FlowRate = reader.GetInt32(reader.GetOrdinal("flow_rate")),
  207. MeterRegion = reader.GetString(reader.GetOrdinal("meter_region")),
  208. FeatureRegion = reader.GetString(reader.GetOrdinal("feature_region")),
  209. LastValue = reader.GetDouble(reader.GetOrdinal("last_value")),
  210. LastTime = reader.GetString(reader.GetOrdinal("last_time"))
  211. };
  212. details.Add(detail);
  213. }
  214. }
  215. // 获取总记录数,用于计算总页数
  216. string countSql = "SELECT COUNT(*) FROM t_single_detail";
  217. int totalRecords = Convert.ToInt32(SQLiteHelper.GetSingle(countSql));
  218. // 计算总页数
  219. int totalPages = (int)Math.Ceiling((double)totalRecords / pageSize);
  220. // 返回元组,包含总页数和结果列表
  221. return Tuple.Create(totalRecords,totalPages, details);
  222. }
  223. /// <summary>
  224. /// 根据 single_detail_id 删除指定的记录
  225. /// </summary>
  226. /// <param name="singleDetailId">要删除的记录的 ID</param>
  227. /// <returns>删除成功返回 true,否则返回 false</returns>
  228. public static bool DeleteTSingleDetailById(string singleDetailId)
  229. {
  230. // 构建删除的 SQL 语句
  231. string sql = "DELETE FROM t_single_detail WHERE single_detail_id = @SingleDetailId";
  232. // 创建参数数组
  233. SQLiteParameter[] parameters = new SQLiteParameter[]
  234. {
  235. new SQLiteParameter("@SingleDetailId", singleDetailId)
  236. };
  237. try
  238. {
  239. // 调用 SQLiteHelper 执行删除操作
  240. int rowsAffected = SQLiteHelper.ExecuteSql(sql, parameters);
  241. // 如果删除成功,返回 true,否则返回 false
  242. return rowsAffected > 0;
  243. }
  244. catch (Exception ex)
  245. {
  246. // 处理异常(如果有的话)
  247. Console.WriteLine("Error deleting data: " + ex.Message);
  248. return false;
  249. }
  250. }
  251. /// <summary>
  252. /// 清空 t_single_detail 表中的所有记录
  253. /// </summary>
  254. /// <returns>操作成功返回 true,否则返回 false</returns>
  255. public static bool ClearTSingleDetailTable()
  256. {
  257. // 构建清空表的 SQL 语句
  258. string sql = "DELETE FROM t_single_detail";
  259. try
  260. {
  261. // 调用 SQLiteHelper 执行清空操作
  262. SQLiteHelper.ExecuteSql(sql, null);
  263. // 返回 true 表示操作成功
  264. return true;
  265. }
  266. catch (Exception ex)
  267. {
  268. // 处理异常(如果有的话)
  269. Console.WriteLine("Error clearing table: " + ex.Message);
  270. return false;
  271. }
  272. }
  273. //升级数据库(t_patch_detail添加memo字段)
  274. public static void UpdateTSingleDetailSchema()
  275. {
  276. string sql = "PRAGMA table_info(t_single_detail)";
  277. // 查询表结构,判断是否存在memo字段
  278. using (SQLiteDataReader reader = SQLiteHelper.ExecuteReader(sql))
  279. {
  280. bool memoExists = false;
  281. while (reader.Read())
  282. {
  283. if (reader["name"].ToString().ToLower() == "memo")
  284. {
  285. memoExists = true;
  286. break;
  287. }
  288. }
  289. reader.Close();
  290. //如果不存在memo字段,则添加该字段
  291. if (!memoExists)
  292. {
  293. sql = "ALTER TABLE t_single_detail ADD COLUMN memo TEXT NOT NULL DEFAULT ''";
  294. SQLiteHelper.ExecuteNonQuery(sql, null);
  295. }
  296. }//using
  297. }
  298. //-----------------------------------------------------------------------------------------
  299. }
  300. }