DBSingle.cs 15 KB

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