123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302 |
- using System;
- using System.Collections.Generic;
- using System.Data.SQLite;
- using System.Linq;
- using System.Text;
- using System.Threading.Tasks;
- namespace MeterVision.db
- {
- public class DBSingle
- {
- public static bool InsertTSingleDetail0(TSingleDetail singlDetail)
- {
- // 构建插入的 SQL 语句
- string sql = "INSERT INTO t_single_detail (single_detail_id, create_time, src_image) " +
- "VALUES (@SingleDetailId, @CreateTime, @SrcImage)";
- // 创建参数数组
- SQLiteParameter[] parameters = new SQLiteParameter[]
- {
- new SQLiteParameter("@SingleDetailId", singlDetail.SingleDetailId),
- new SQLiteParameter("@CreateTime", singlDetail.CreateTime),
- new SQLiteParameter("@SrcImage", singlDetail.SrcImage)
- };
- try
- {
- // 调用 SQLiteHelper 执行插入操作
- int rowsAffected = SQLiteHelper.ExecuteSql(sql, parameters);
- // 如果插入成功,返回 true,否则返回 false
- return rowsAffected > 0;
- }
- catch (Exception ex)
- {
- // 处理异常(如果有的话)
- Console.WriteLine("Error inserting data: " + ex.Message);
- return false;
- }
- }
- public static bool InsertSingleDetail(TSingleDetail detail)
- {
- // 定义 SQL 插入语句
- string sql = @"
- INSERT INTO t_single_detail (
- single_detail_id, create_time, src_image, run_flag, run_time,
- dst_image, meter_type, digit_count, pointer_count, last_unit,
- result_type, raw_value, final_value, ai_ver, debug_info, log_path
- )
- VALUES (
- @SingleDetailId, @CreateTime, @SrcImage, @RunFlag, @RunTime,
- @DstImage, @MeterType, @DigitCount, @PointerCount, @LastUnit,
- @ResultType, @RawValue, @FinalValue, @AiVer, @DebugInfo, @LogPath
- );
- ";
- // 创建 SQL 参数
- SQLiteParameter[] parameters = new SQLiteParameter[]
- {
- new SQLiteParameter("@SingleDetailId", detail.SingleDetailId),
- new SQLiteParameter("@CreateTime", detail.CreateTime),
- new SQLiteParameter("@SrcImage", detail.SrcImage),
- new SQLiteParameter("@RunFlag", detail.RunFlag),
- new SQLiteParameter("@RunTime", detail.RunTime),
- new SQLiteParameter("@DstImage", detail.DstImage),
- new SQLiteParameter("@MeterType", detail.MeterType),
- new SQLiteParameter("@DigitCount", detail.DigitCount),
- new SQLiteParameter("@PointerCount", detail.PointerCount),
- new SQLiteParameter("@LastUnit", detail.LastUnit),
- new SQLiteParameter("@ResultType", detail.ResultType),
- new SQLiteParameter("@RawValue", detail.RawValue),
- new SQLiteParameter("@FinalValue", detail.FinalValue),
- new SQLiteParameter("@AiVer", detail.AiVer),
- new SQLiteParameter("@DebugInfo", detail.DebugInfo),
- new SQLiteParameter("@LogPath", detail.LogPath)
- };
- // 执行插入操作并返回受影响的行数
- return SQLiteHelper.ExecuteNonQuery(sql, parameters) > 0;
- }
- public static bool UpdateSingleDetail(TSingleDetail detail)
- {
- // 定义 SQL 更新语句
- string sql = @"
- UPDATE t_single_detail
- SET run_flag = @RunFlag,
- run_time = @RunTime,
- dst_image = @DstImage,
- meter_type = @MeterType,
- digit_count = @DigitCount,
- pointer_count = @PointerCount,
- last_unit = @LastUnit,
- result_type = @ResultType,
- raw_value = @RawValue,
- final_value = @FinalValue,
- ai_ver = @AiVer,
- debug_info = @DebugInfo,
- log_path = @LogPath
- WHERE single_detail_id = @SingleDetailId;";
- // 创建 SQL 参数
- SQLiteParameter[] parameters = new SQLiteParameter[]
- {
- new SQLiteParameter("@SingleDetailId", detail.SingleDetailId),
- //new SQLiteParameter("@CreateTime", detail.CreateTime),
- //new SQLiteParameter("@SrcImage", detail.SrcImage),
- new SQLiteParameter("@RunFlag", detail.RunFlag),
- new SQLiteParameter("@RunTime", detail.RunTime),
- new SQLiteParameter("@DstImage", detail.DstImage),
- new SQLiteParameter("@MeterType", detail.MeterType),
- new SQLiteParameter("@DigitCount", detail.DigitCount),
- new SQLiteParameter("@PointerCount", detail.PointerCount),
- new SQLiteParameter("@LastUnit", detail.LastUnit),
- new SQLiteParameter("@ResultType", detail.ResultType),
- new SQLiteParameter("@RawValue", detail.RawValue),
- new SQLiteParameter("@FinalValue", detail.FinalValue),
- new SQLiteParameter("@AiVer", detail.AiVer),
- new SQLiteParameter("@DebugInfo", detail.DebugInfo),
- new SQLiteParameter("@LogPath", detail.LogPath)
- };
- // 执行更新操作并返回受影响的行数
- return SQLiteHelper.ExecuteNonQuery(sql, parameters) > 0;
- }
- //更改备注信息
- public static bool UpdateSingleDetailMemo(string detailId,string memo)
- {
- // 定义 SQL 更新语句
- string sql = @"
- UPDATE t_single_detail
- SET memo = @Memo
- WHERE single_detail_id = @SingleDetailId;";
- // 创建 SQL 参数
- SQLiteParameter[] parameters = new SQLiteParameter[]
- {
- new SQLiteParameter("@SingleDetailId", detailId),
- new SQLiteParameter("@Memo", memo)
- };
- // 执行更新操作并返回受影响的行数
- return SQLiteHelper.ExecuteNonQuery(sql, parameters) > 0;
- }
- public static Tuple<int,int, List<TSingleDetail>> GetPagedSingleDetails(int pageNumber, int pageSize)
- {
- // 计算 OFFSET 值
- int offset = (pageNumber - 1) * pageSize;
- // 定义 SQL 查询语句,带有分页
- string sql = @"
- SELECT single_detail_id, create_time, src_image, run_flag, run_time,
- dst_image, meter_type, digit_count, pointer_count, last_unit,
- result_type, raw_value, final_value, ai_ver, debug_info, log_path, memo
- FROM t_single_detail
- ORDER BY create_time DESC
- LIMIT @PageSize OFFSET @Offset;";
- // 创建 SQL 参数
- SQLiteParameter[] parameters = new SQLiteParameter[]
- {
- new SQLiteParameter("@PageSize", pageSize),
- new SQLiteParameter("@Offset", offset)
- };
- // 执行查询并获取结果
- List<TSingleDetail> details = new List<TSingleDetail>();
- using (SQLiteDataReader reader = SQLiteHelper.ExecuteReader(sql, parameters))
- {
- while (reader.Read())
- {
- // 将查询结果映射到 TSingleDetail 对象
- TSingleDetail detail = new TSingleDetail
- {
- SingleDetailId = reader.GetString(reader.GetOrdinal("single_detail_id")),
- CreateTime = reader.GetString(reader.GetOrdinal("create_time")),
- SrcImage = reader.GetString(reader.GetOrdinal("src_image")),
- RunFlag = reader.GetInt32(reader.GetOrdinal("run_flag")),
- RunTime = reader.GetString(reader.GetOrdinal("run_time")),
- DstImage = reader.GetString(reader.GetOrdinal("dst_image")),
- MeterType = reader.GetInt32(reader.GetOrdinal("meter_type")),
- DigitCount = reader.GetInt32(reader.GetOrdinal("digit_count")),
- PointerCount = reader.GetInt32(reader.GetOrdinal("pointer_count")),
- LastUnit = reader.GetString(reader.GetOrdinal("last_unit")),
- ResultType = reader.GetInt32(reader.GetOrdinal("result_type")),
- RawValue = reader.GetString(reader.GetOrdinal("raw_value")),
- FinalValue = reader.GetString(reader.GetOrdinal("final_value")),
- AiVer = reader.GetString(reader.GetOrdinal("ai_ver")),
- DebugInfo = reader.GetString(reader.GetOrdinal("debug_info")),
- LogPath = reader.GetString(reader.GetOrdinal("log_path")),
- Memo = reader.GetString(reader.GetOrdinal("memo"))
- };
- details.Add(detail);
- }
- }
- // 获取总记录数,用于计算总页数
- string countSql = "SELECT COUNT(*) FROM t_single_detail";
- int totalRecords = Convert.ToInt32(SQLiteHelper.GetSingle(countSql));
- // 计算总页数
- int totalPages = (int)Math.Ceiling((double)totalRecords / pageSize);
- // 返回元组,包含总页数和结果列表
- return Tuple.Create(totalRecords,totalPages, details);
- }
- /// <summary>
- /// 根据 single_detail_id 删除指定的记录
- /// </summary>
- /// <param name="singleDetailId">要删除的记录的 ID</param>
- /// <returns>删除成功返回 true,否则返回 false</returns>
- public static bool DeleteTSingleDetailById(string singleDetailId)
- {
- // 构建删除的 SQL 语句
- string sql = "DELETE FROM t_single_detail WHERE single_detail_id = @SingleDetailId";
- // 创建参数数组
- SQLiteParameter[] parameters = new SQLiteParameter[]
- {
- new SQLiteParameter("@SingleDetailId", singleDetailId)
- };
- try
- {
- // 调用 SQLiteHelper 执行删除操作
- int rowsAffected = SQLiteHelper.ExecuteSql(sql, parameters);
- // 如果删除成功,返回 true,否则返回 false
- return rowsAffected > 0;
- }
- catch (Exception ex)
- {
- // 处理异常(如果有的话)
- Console.WriteLine("Error deleting data: " + ex.Message);
- return false;
- }
- }
- /// <summary>
- /// 清空 t_single_detail 表中的所有记录
- /// </summary>
- /// <returns>操作成功返回 true,否则返回 false</returns>
- public static bool ClearTSingleDetailTable()
- {
- // 构建清空表的 SQL 语句
- string sql = "DELETE FROM t_single_detail";
- try
- {
- // 调用 SQLiteHelper 执行清空操作
- SQLiteHelper.ExecuteSql(sql, null);
- // 返回 true 表示操作成功
- return true;
- }
- catch (Exception ex)
- {
- // 处理异常(如果有的话)
- Console.WriteLine("Error clearing table: " + ex.Message);
- return false;
- }
- }
- //升级数据库(t_patch_detail添加memo字段)
- public static void UpdateTSingleDetailSchema()
- {
- string sql = "PRAGMA table_info(t_single_detail)";
- // 查询表结构,判断是否存在memo字段
- using (SQLiteDataReader reader = SQLiteHelper.ExecuteReader(sql))
- {
- bool memoExists = false;
- while (reader.Read())
- {
- if (reader["name"].ToString().ToLower() == "memo")
- {
- memoExists = true;
- break;
- }
- }
- reader.Close();
- //如果不存在memo字段,则添加该字段
- if (!memoExists)
- {
- sql = "ALTER TABLE t_single_detail ADD COLUMN memo TEXT NOT NULL DEFAULT ''";
- SQLiteHelper.ExecuteNonQuery(sql, null);
- }
- }//using
- }
- //-----------------------------------------------------------------------------------------
- }
- }
|