12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304 |
- using MeterVision.model;
- 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 DBPatch
- {
- public static bool InsertTPatch(TPatch tPatch)
- {
- // 构建插入的 SQL 语句
- string sql = "INSERT INTO t_patch (patch_id, create_time, patch_name,stand_id,stand_name) " +
- "VALUES (@PatchId, @CreateTime, @PatchName, @StandId, @StandName)";
- // 创建参数数组
- SQLiteParameter[] parameters = new SQLiteParameter[]
- {
- new SQLiteParameter("@PatchId", tPatch.PatchId),
- new SQLiteParameter("@CreateTime", tPatch.CreateTime),
- new SQLiteParameter("@PatchName", tPatch.PatchName),
- new SQLiteParameter("@StandId", tPatch.StandId),
- new SQLiteParameter("@StandName", tPatch.StandName),
- };
- 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 DeletePatchAndDetails(string patchId)
- {
- // 定义删除的 SQL 语句,使用事务来保证一致性
- string sql = @"
- BEGIN TRANSACTION;
- -- 删除 t_patch_detail 表中与 stand_id 相关的数据
- DELETE FROM t_patch_detail WHERE patch_id = @PatchId;
- -- 删除 t_patch 表中与 patch_id 相关的数据
- DELETE FROM t_patch WHERE patch_id = @PatchId;
- COMMIT;";
- // 创建参数
- SQLiteParameter[] parameters = new SQLiteParameter[]
- {
- new SQLiteParameter("@PatchId", patchId)
- };
- try
- {
- // 执行 SQL 删除操作
- int rowsAffected = SQLiteHelper.ExecuteSql(sql, parameters);
- // 返回是否成功删除
- return rowsAffected > 0;
- }
- catch (Exception ex)
- {
- // 处理异常(如果有的话)
- Console.WriteLine("Error deleting data: " + ex.Message);
- return false;
- }
- }
- public static Tuple<int,int, List<VPatch>> GetPagedVPatchs(int pageNumber, int pageSize)
- {
- // 计算 OFFSET 值
- int offset = (pageNumber - 1) * pageSize;
- // 定义 SQL 查询语句,带有分页
- string sql = @"
- SELECT patch_id, create_time, patch_name, stand_id, stand_name,
- detail_count,run_count,equal_count,invalid_count,error_count
- FROM v_patch ORDER BY create_time DESC
- LIMIT @PageSize OFFSET @Offset;";
- // 创建 SQL 参数
- SQLiteParameter[] parameters = new SQLiteParameter[]
- {
- new SQLiteParameter("@PageSize", pageSize),
- new SQLiteParameter("@Offset", offset)
- };
- // 执行查询并获取结果
- List<VPatch> patchs = new List<VPatch>();
- using (SQLiteDataReader reader = SQLiteHelper.ExecuteReader(sql, parameters))
- {
- while (reader.Read())
- {
- // 将查询结果映射到 TStand 对象
- VPatch patch = new VPatch
- {
- PatchId = reader.GetString(reader.GetOrdinal("patch_id")),
- CreateTime = reader.GetString(reader.GetOrdinal("create_time")),
- PatchName = reader.GetString(reader.GetOrdinal("patch_name")),
- StandId = reader.GetString(reader.GetOrdinal("stand_id")),
- StandName = reader.GetString(reader.GetOrdinal("stand_name")),
- DetailCount = reader.GetInt32(reader.GetOrdinal("detail_count")),
- RunCount = reader.GetInt32(reader.GetOrdinal("run_count")),
- EqualCount = reader.GetInt32(reader.GetOrdinal("equal_count")),
- InvalidCount = reader.GetInt32(reader.GetOrdinal("invalid_count")),
- ErrorCount = reader.GetInt32(reader.GetOrdinal("error_count"))
- };
- patchs.Add(patch);
- }
- }
- // 获取总记录数,用于计算总页数
- string countSql = "SELECT COUNT(*) FROM v_patch";
- int totalRecords = Convert.ToInt32(SQLiteHelper.GetSingle(countSql));
- // 计算总页数
- int totalPages = (int)Math.Ceiling((double)totalRecords / pageSize);
- // 返回元组,包含总页数和结果列表
- return Tuple.Create(totalRecords,totalPages, patchs);
- }
- public static bool InsertPatchDetail(TPatchDetail patchDetail)
- {
- // 插入SQL语句
- string sql = @"
- INSERT INTO t_patch_detail (patch_detail_id, patch_id, create_time, stand_detail_id, stand_value, src_image)
- VALUES (@PatchDetailId, @PatchId, @CreateTime, @StandDetailId, @StandValue, @SrcImage);";
- // 定义参数
- SQLiteParameter[] parameters = new SQLiteParameter[]
- {
- new SQLiteParameter("@PatchDetailId", patchDetail.PatchDetailId),
- new SQLiteParameter("@PatchId", patchDetail.PatchId),
- new SQLiteParameter("@CreateTime", patchDetail.CreateTime),
- new SQLiteParameter("@StandDetailId", patchDetail.StandDetailId),
- new SQLiteParameter("@StandValue", patchDetail.StandValue),
- new SQLiteParameter("@SrcImage", patchDetail.SrcImage)
- };
- // 执行插入操作
- try
- {
- int rowsAffected = SQLiteHelper.ExecuteNonQuery(sql, parameters);
- return rowsAffected > 0; // 返回是否成功插入
- }
- catch (Exception ex)
- {
- // 处理异常
- Console.WriteLine(ex.Message);
- return false;
- }
- }
- public static bool InsertPatchDetails(List<TPatchDetail> patchDetails)
- {
- // 插入SQL语句
- string sql = @"
- INSERT INTO t_patch_detail (patch_detail_id, patch_id, create_time, stand_detail_id, stand_value, src_image)
- VALUES (@PatchDetailId, @PatchId, @CreateTime, @StandDetailId, @StandValue, @SrcImage);";
- try
- {
- // 开始事务
- using (SQLiteConnection connection = SQLiteHelper.GetConnection())
- {
- connection.Open();
- using (SQLiteTransaction transaction = connection.BeginTransaction())
- {
- // 遍历列表插入每一条数据
- foreach (var patchDetail in patchDetails)
- {
- SQLiteParameter[] parameters = new SQLiteParameter[]
- {
- new SQLiteParameter("@PatchDetailId", patchDetail.PatchDetailId),
- new SQLiteParameter("@PatchId", patchDetail.PatchId),
- new SQLiteParameter("@CreateTime", patchDetail.CreateTime),
- new SQLiteParameter("@StandDetailId", patchDetail.StandDetailId),
- new SQLiteParameter("@StandValue", patchDetail.StandValue),
- new SQLiteParameter("@SrcImage", patchDetail.SrcImage)
- };
- // 执行插入操作
- SQLiteHelper.ExecuteNonQuery(sql, parameters, transaction);
- }
- // 提交事务
- transaction.Commit();
- }
- }
- return true;
- }
- catch (Exception ex)
- {
- // 处理异常
- Console.WriteLine(ex.Message);
- return false;
- }
- }
- public static bool UpdatePatchDetails(List<TPatchDetail> patchDetails)
- {
- // 更新 SQL 语句
- string sql = @"
- UPDATE t_patch_detail
- SET
- run_flag = @RunFlag,
- run_time = @RunTime,
- dst_image = @DstImage,
- result_meter = @ResultMeter,
- result_type = @ResultType,
- raw_value = @RawValue,
- final_value = @FinalValue,
- complete_value = @CompleteValue,
- value_changed = @ValueChanged,
- equal_flag = @EqualFlag,
- ai_ver = @AiVer,
- debug_info = @DebugInfo,
- log_path = @LogPath,
- memo = @Memo,
- meter_region = @MeterRegion,
- feature_region = @FeatureRegion,
- latest_complete = @LatestComplete,
- last_compress = @LastCompress,
- latest_value = @LatestValue,
- latest_time = @LatestTime
- WHERE patch_detail_id = @PatchDetailId;";
- try
- {
- using (SQLiteConnection connection = SQLiteHelper.GetConnection())
- {
- connection.Open();
- using (SQLiteTransaction transaction = connection.BeginTransaction())
- {
- foreach (var patchDetail in patchDetails)
- {
- SQLiteParameter[] parameters = new SQLiteParameter[]
- {
- new SQLiteParameter("@RunFlag", patchDetail.RunFlag),
- new SQLiteParameter("@RunTime", patchDetail.RunTime),
- new SQLiteParameter("@DstImage", patchDetail.DstImage),
- new SQLiteParameter("@ResultMeter", patchDetail.ResultMeter),
- new SQLiteParameter("@ResultType", patchDetail.ResultType),
- new SQLiteParameter("@RawValue", patchDetail.RawValue),
- new SQLiteParameter("@FinalValue", patchDetail.FinalValue),
- new SQLiteParameter("@CompleteValue", patchDetail.CompleteValue),
- new SQLiteParameter("@ValueChanged", patchDetail.ValueChanged),
- new SQLiteParameter("@EqualFlag", patchDetail.EqualFlag),
- new SQLiteParameter("@AiVer", patchDetail.AiVer),
- new SQLiteParameter("@DebugInfo", patchDetail.DebugInfo),
- new SQLiteParameter("@LogPath", patchDetail.LogPath),
- new SQLiteParameter("@Memo", patchDetail.Memo),
- new SQLiteParameter("@MeterRegion", patchDetail.MeterRegion),
- new SQLiteParameter("@FeatureRegion", patchDetail.FeatureRegion),
- new SQLiteParameter("@LatestComplete", patchDetail.LatestComplete),
- new SQLiteParameter("@LastCompress", patchDetail.LastCompress),
- new SQLiteParameter("@LatestValue", patchDetail.LatestValue),
- new SQLiteParameter("@LatestTime", patchDetail.LatestTime),
- new SQLiteParameter("@PatchDetailId", patchDetail.PatchDetailId) // 条件字段
- };
- SQLiteHelper.ExecuteNonQuery(sql, parameters, transaction);
- }
- // 提交事务
- transaction.Commit();
- }
- }
- return true;
- }
- catch (Exception ex)
- {
- Console.WriteLine("更新数据时出错: " + ex.Message);
- return false;
- }
- }
- //根据识别结果修改表内容
- public static bool UpdatePatchDetailWithResult(TPatchDetail detail)
- {
- string sql = @"
- UPDATE t_patch_detail
- SET run_flag = @RunFlag,
- run_time = @RunTime,
- dst_image = @DstImage,
- result_meter = @ResultMeter,
- result_type = @ResultType,
- raw_value = @RawValue,
- final_value = @FinalValue,
- complete_value = @CompleteValue,
- value_changed = @ValueChanged,
- equal_flag = @EqualFlag,
- ai_ver = @AiVer,
- debug_info = @DebugInfo,
- log_path = @LogPath
- WHERE patch_detail_id = @PatchDetailId;";
- // 创建 SQL 参数
- SQLiteParameter[] parameters = new SQLiteParameter[]
- {
- new SQLiteParameter("@PatchDetailId", detail.PatchDetailId),
- new SQLiteParameter("@RunFlag", detail.RunFlag),
- new SQLiteParameter("@RunTime", detail.RunTime),
- new SQLiteParameter("@DstImage", detail.DstImage),
- new SQLiteParameter("@ResultMeter", detail.ResultMeter),
- new SQLiteParameter("@ResultType", detail.ResultType),
- new SQLiteParameter("@RawValue", detail.RawValue),
- new SQLiteParameter("@FinalValue", detail.FinalValue),
- new SQLiteParameter("@CompleteValue",detail.CompleteValue),
- new SQLiteParameter("@ValueChanged",detail.ValueChanged),
- new SQLiteParameter("@EqualFlag", detail.EqualFlag),
- new SQLiteParameter("@AiVer", detail.AiVer),
- new SQLiteParameter("@DebugInfo", detail.DebugInfo),
- new SQLiteParameter("@LogPath", detail.LogPath)
- };
- // 执行更新操作并返回受影响的行数
- return SQLiteHelper.ExecuteNonQuery(sql, parameters) > 0;
- }
- public static bool UpdatePatchDetailStandValue(string patchDetailId,string standValue,int equalFlag)
- {
- string sql = @"
- UPDATE t_patch_detail
- SET stand_value = @StandValue,
- equal_flag = @EqualFlag
- WHERE patch_detail_id = @PatchDetailId;";
- // 创建 SQL 参数
- SQLiteParameter[] parameters = new SQLiteParameter[]
- {
- new SQLiteParameter("@PatchDetailId", patchDetailId),
- new SQLiteParameter("@EqualFlag", equalFlag),
- new SQLiteParameter("@StandValue", standValue)
- };
- // 执行更新操作并返回受影响的行数
- return SQLiteHelper.ExecuteNonQuery(sql, parameters) > 0;
- }
- //同时插入t_patch与t_patch_detail(在一个事务中)
- public static bool InsertPatchAndDetails(TPatch patch, List<TPatchDetail> patchDetails)
- {
- try
- {
- using (SQLiteConnection connection = SQLiteHelper.GetConnection())
- {
- connection.Open();
- using (SQLiteTransaction transaction = connection.BeginTransaction())
- {
- // 插入 t_patch 表
- string patchSql = "INSERT INTO t_patch (patch_id, create_time, patch_name, stand_id, stand_name) VALUES (@PatchId, @CreateTime, @PatchName, @StandId, @StandName)";
- SQLiteParameter[] patchParams = new SQLiteParameter[]
- {
- new SQLiteParameter("@PatchId", patch.PatchId),
- new SQLiteParameter("@CreateTime", patch.CreateTime),
- new SQLiteParameter("@PatchName", patch.PatchName),
- new SQLiteParameter("@StandId", patch.StandId),
- new SQLiteParameter("@StandName", patch.StandName)
- };
- SQLiteHelper.ExecuteNonQuery(patchSql, patchParams, transaction);
- // 插入 t_patch_detail 表
- foreach (var patchDetail in patchDetails)
- {
- //string detailSql = "INSERT INTO t_patch_detail (patch_detail_id, patch_id, create_time, stand_detail_id, stand_value, src_image) VALUES (@PatchDetailId, @PatchId, @CreateTime, @StandDetailId, @StandValue, @SrcImage)";
- string detailSql = @"
- INSERT INTO t_patch_detail (
- patch_detail_id, patch_id, create_time,
- stand_detail_id, stand_value, src_image,
- sample_time, station_key, station_id,
- meter_type, bright_val, flow_rate,
- digit_count, pointer_count, last_unit, num_in_upper,
- meter_region, feature_region, last_compress,
- latest_value, latest_time, latest_complete
- ) VALUES (
- @PatchDetailId, @PatchId, @CreateTime,
- @StandDetailId, @StandValue, @SrcImage,
- @SampleTime, @StationKey, @StationId,
- @MeterType, @BrightVal, @FlowRate,
- @DigitCount, @PointerCount, @LastUnit, @NumInUpper,
- @MeterRegion, @FeatureRegion, @LastCompress,
- @LatestValue, @LatestTime, @LatestComplete
- )";
- SQLiteParameter[] detailParams = new SQLiteParameter[]
- {
- new SQLiteParameter("@PatchDetailId", patchDetail.PatchDetailId),
- new SQLiteParameter("@PatchId", patchDetail.PatchId),
- new SQLiteParameter("@CreateTime", patchDetail.CreateTime),
- new SQLiteParameter("@StandDetailId", patchDetail.StandDetailId),
- new SQLiteParameter("@StandValue", patchDetail.StandValue),
- new SQLiteParameter("@SrcImage", patchDetail.SrcImage),
- new SQLiteParameter("@SampleTime", patchDetail.SampleTime),
- new SQLiteParameter("@StationKey", patchDetail.StationKey),
- new SQLiteParameter("@StationId", patchDetail.StationId),
- new SQLiteParameter("@MeterType", patchDetail.MeterType),
- new SQLiteParameter("@BrightVal", patchDetail.BrightVal),
- new SQLiteParameter("@FlowRate", patchDetail.FlowRate),
- new SQLiteParameter("@DigitCount", patchDetail.DigitCount),
- new SQLiteParameter("@PointerCount", patchDetail.PointerCount),
- new SQLiteParameter("@LastUnit", patchDetail.LastUnit),
- new SQLiteParameter("@NumInUpper", patchDetail.NumInUpper),
- new SQLiteParameter("@MeterRegion", patchDetail.MeterRegion),
- new SQLiteParameter("@FeatureRegion", patchDetail.FeatureRegion),
- new SQLiteParameter("@LastCompress", patchDetail.LastCompress),
- new SQLiteParameter("@LatestValue", patchDetail.LatestValue),
- new SQLiteParameter("@LatestTime", patchDetail.LatestTime),
- new SQLiteParameter("@LatestComplete", patchDetail.LatestComplete),
- };
- SQLiteHelper.ExecuteNonQuery(detailSql, detailParams, transaction);
- }
- // 提交事务
- transaction.Commit();
- return true;
- }
- }
- }
- catch (Exception ex)
- {
- Console.WriteLine($"插入数据失败:{ex.Message}");
- return false;
- }
- }
- public static bool UpdatePatchDetails_Latest(List<TPatchDetail> patchDetails)
- {
- try
- {
- using (SQLiteConnection connection = SQLiteHelper.GetConnection())
- {
- connection.Open();
- using (SQLiteTransaction transaction = connection.BeginTransaction())
- {
- // 插入 t_patch_detail 表
- foreach (var patchDetail in patchDetails)
- {
- // 更新 t_patch_detail 表(仅涉及的字段)
- string detailSql = @"
- UPDATE t_patch_detail
- SET latest_value = @LatestValue,
- latest_time = @LatestTime,
- latest_complete = @LatestComplete,
- last_compress = @LastCompress
- WHERE patch_detail_id = @PatchDetailId;";
- SQLiteParameter[] detailParams = new SQLiteParameter[]
- {
- new SQLiteParameter("@PatchDetailId", patchDetail.PatchDetailId),
- new SQLiteParameter("@LastCompress", patchDetail.LastCompress),
- new SQLiteParameter("@LatestValue", patchDetail.LatestValue),
- new SQLiteParameter("@LatestTime", patchDetail.LatestTime),
- new SQLiteParameter("@LatestComplete", patchDetail.LatestComplete),
- };
- SQLiteHelper.ExecuteNonQuery(detailSql, detailParams, transaction);
- }
- // 提交事务
- transaction.Commit();
- return true;
- }
- }
- }
- catch (Exception ex)
- {
- Console.WriteLine($"插入数据失败:{ex.Message}");
- return false;
- }
- }
- public static bool UpdatePatchDetails_Latest(TPatchDetail patchDetail)
- {
- try
- {
- using (SQLiteConnection connection = SQLiteHelper.GetConnection())
- {
- connection.Open();
- // 更新 t_patch_detail 表(仅涉及的字段)
- string detailSql = @"
- UPDATE t_patch_detail
- SET latest_value = @LatestValue,
- latest_time = @LatestTime,
- latest_complete = @LatestComplete,
- last_compress = @LastCompress,
- meter_region = @MeterRegion,
- feature_region = @FeatureRegion
- WHERE patch_detail_id = @PatchDetailId;";
- SQLiteParameter[] detailParams = new SQLiteParameter[]
- {
- new SQLiteParameter("@PatchDetailId", patchDetail.PatchDetailId),
- new SQLiteParameter("@LastCompress", patchDetail.LastCompress),
- new SQLiteParameter("@LatestValue", patchDetail.LatestValue),
- new SQLiteParameter("@LatestTime", patchDetail.LatestTime),
- new SQLiteParameter("@LatestComplete", patchDetail.LatestComplete),
- new SQLiteParameter("@MeterRegion", patchDetail.MeterRegion),
- new SQLiteParameter("@FeatureRegion", patchDetail.FeatureRegion),
- };
- SQLiteHelper.ExecuteNonQuery(detailSql, detailParams);
- return true;
- }
- }
- catch (Exception ex)
- {
- Console.WriteLine($"插入数据失败:{ex.Message}");
- return false;
- }
- }
- public static Tuple<int, int, List<TPatchDetail>> GetPagedPatchDetails(int pageNumber, int pageSize, string patchId)
- {
- // 计算偏移量
- int offset = (pageNumber - 1) * pageSize;
- // 分页查询SQL
- //string sql = @"
- // SELECT patch_detail_id, patch_id, create_time, stand_detail_id, stand_value, src_image,
- // run_flag, run_time, dst_image, meter_type, digit_count, pointer_count,
- // last_unit, result_type, raw_value, final_value, equal_flag, ai_ver, debug_info, log_path
- // FROM t_patch_detail WHERE patch_id = @PatchId
- // ORDER BY create_time DESC -- 根据需要修改排序字段
- // LIMIT @PageSize OFFSET @Offset;";
- string sql = @"
- SELECT patch_detail_id, patch_id, create_time, stand_detail_id, stand_value, src_image,
- run_flag, run_time, dst_image, meter_type, digit_count, pointer_count,
- last_unit, result_type, raw_value, final_value, equal_flag, ai_ver, debug_info, log_path, memo
- FROM t_patch_detail WHERE patch_id = @PatchId
- ORDER BY create_time ASC -- 根据需要修改排序字段
- LIMIT @PageSize OFFSET @Offset;";
- // 定义参数
- SQLiteParameter[] parameters = new SQLiteParameter[]
- {
- new SQLiteParameter("@PatchId", patchId),
- new SQLiteParameter("@PageSize", pageSize),
- new SQLiteParameter("@Offset", offset)
- };
- // 执行查询并读取数据
- List<TPatchDetail> patchDetails = new List<TPatchDetail>();
- using (SQLiteDataReader reader = SQLiteHelper.ExecuteReader(sql, parameters))
- {
- while (reader.Read())
- {
- // 将查询结果映射到 TPatchDetail 对象
- TPatchDetail patchDetail = new TPatchDetail
- {
- PatchDetailId = reader.GetString(reader.GetOrdinal("patch_detail_id")),
- PatchId = reader.GetString(reader.GetOrdinal("patch_id")),
- CreateTime = reader.GetString(reader.GetOrdinal("create_time")),
- StandDetailId = reader.GetString(reader.GetOrdinal("stand_detail_id")),
- StandValue = reader.GetString(reader.GetOrdinal("stand_value")),
- 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.GetDouble(reader.GetOrdinal("last_unit")),
- ResultType = reader.GetInt32(reader.GetOrdinal("result_type")),
- RawValue = reader.GetInt64(reader.GetOrdinal("raw_value")),
- FinalValue = reader.GetInt64(reader.GetOrdinal("final_value")),
- EqualFlag = reader.GetInt32(reader.GetOrdinal("equal_flag")),
- 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"))
- };
- patchDetails.Add(patchDetail);
- }
- }
- // 获取总记录数,用于计算总页数
- string countSql = "SELECT COUNT(*) FROM t_patch_detail WHERE patch_id = @PatchId";
- int totalRecords = Convert.ToInt32(SQLiteHelper.GetSingle(countSql, new SQLiteParameter("@PatchId", patchId)));
- // 计算总页数
- int totalPages = (int)Math.Ceiling((double)totalRecords / pageSize);
- // 返回总记录数、总页数和分页结果
- return Tuple.Create(totalRecords, totalPages, patchDetails);
- }
- public static Tuple<int, int, List<TPatchDetail>> GetPagedPatchDetails(PatchFindModel findModel)
- {
- // 计算偏移量
- int offset = (findModel.PageNumber - 1) * findModel.PageSize;
- // 动态构造 WHERE 子句
- StringBuilder whereClause = new StringBuilder("WHERE patch_id = @PatchId");
- List<SQLiteParameter> parameters = new List<SQLiteParameter>
- {
- new SQLiteParameter("@PatchId", findModel.PatchId),
- new SQLiteParameter("@PageSize", findModel.PageSize),
- new SQLiteParameter("@Offset", offset)
- };
- if (findModel.RunFlag >= 0)
- {
- whereClause.Append(" AND run_flag = @RunFlag");
- parameters.Add(new SQLiteParameter("@RunFlag", findModel.RunFlag));
- }
- if (findModel.EqualFlag >= 0)
- {
- whereClause.Append(" AND equal_flag = @EqualFlag");
- parameters.Add(new SQLiteParameter("@EqualFlag", findModel.EqualFlag));
- }
- if (!string.IsNullOrEmpty(findModel.StationId))
- {
- whereClause.Append(" AND station_id = @StationId");
- parameters.Add(new SQLiteParameter("StationId", findModel.StationId));
- }
- if(findModel.PatchFindType == Patch.PatchFindType.HAVE_MEMO)
- {
- whereClause.Append(" AND memo != ''");
- //parameters.Add(new SQLiteParameter("@EqualFlag", findModel.EqualFlag));
- }
- //if (findModel.EqualFlag == 2) // 针对无标准值的查询条件
- //{
- // whereClause.Append(" AND stand_value = ''");
- //}
- // 分页查询SQL
- //string sql = $@"
- // SELECT patch_detail_id, patch_id, create_time, stand_detail_id, stand_value, src_image,
- // run_flag, run_time, dst_image, meter_type, digit_count, pointer_count,
- // last_unit, result_type, raw_value, final_value, equal_flag, ai_ver, debug_info, log_path, memo
- // FROM t_patch_detail
- // {whereClause}
- // ORDER BY create_time ASC -- 根据需要修改排序字段
- // LIMIT @PageSize OFFSET @Offset;";
- string sql = $@"
- SELECT * FROM t_patch_detail
- {whereClause}
- ORDER BY station_id,sample_time ASC
- LIMIT @PageSize OFFSET @Offset;";
- // 执行查询并读取数据
- List<TPatchDetail> patchDetails = new List<TPatchDetail>();
- using (SQLiteDataReader reader = SQLiteHelper.ExecuteReader(sql, parameters.ToArray()))
- {
- while (reader.Read())
- {
- TPatchDetail patchDetail = new TPatchDetail
- {
- PatchDetailId = reader.GetString(reader.GetOrdinal("patch_detail_id")),
- PatchId = reader.GetString(reader.GetOrdinal("patch_id")),
- CreateTime = reader.GetString(reader.GetOrdinal("create_time")),
- StandDetailId = reader.GetString(reader.GetOrdinal("stand_detail_id")),
- StandValue = reader.GetString(reader.GetOrdinal("stand_value")),
- SrcImage = reader.GetString(reader.GetOrdinal("src_image")),
- SampleTime = reader.GetString(reader.GetOrdinal("sample_time")),
- RunFlag = reader.GetInt32(reader.GetOrdinal("run_flag")),
- RunTime = reader.GetString(reader.GetOrdinal("run_time")),
- DstImage = reader.GetString(reader.GetOrdinal("dst_image")),
- ResultType = reader.GetInt32(reader.GetOrdinal("result_type")),
- RawValue = reader.GetInt64(reader.GetOrdinal("raw_value")),
- FinalValue = reader.GetInt64(reader.GetOrdinal("final_value")),
- CompleteValue = reader.GetInt64(reader.GetOrdinal("complete_value")),
- ValueChanged = reader.GetInt32(reader.GetOrdinal("value_changed")),
- ResultMeter = reader.GetInt32(reader.GetOrdinal("result_meter")),
- EqualFlag = reader.GetInt32(reader.GetOrdinal("equal_flag")),
- 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")),
- StationKey = reader.GetString(reader.GetOrdinal("station_key")),
- StationId = reader.GetString(reader.GetOrdinal("station_id")),
- MeterType = reader.GetInt32(reader.GetOrdinal("meter_type")),
- BrightVal = reader.GetDouble(reader.GetOrdinal("bright_val")),
- FlowRate = reader.GetInt32(reader.GetOrdinal("flow_rate")),
- DigitCount = reader.GetInt32(reader.GetOrdinal("digit_count")),
- PointerCount = reader.GetInt32(reader.GetOrdinal("pointer_count")),
- LastUnit = reader.GetDouble(reader.GetOrdinal("last_unit")),
- NumInUpper = reader.GetInt32(reader.GetOrdinal("num_in_upper")),
- MeterRegion = reader.GetString(reader.GetOrdinal("meter_region")),
- FeatureRegion = reader.GetString(reader.GetOrdinal("feature_region")),
- LastCompress = reader.GetInt32(reader.GetOrdinal("last_compress")),
- LatestValue = reader.GetInt64(reader.GetOrdinal("latest_value")),
- LatestTime = reader.GetString(reader.GetOrdinal("latest_time")),
- LatestComplete = reader.GetInt64(reader.GetOrdinal("latest_complete"))
- };
- patchDetails.Add(patchDetail);
- }
- }
- // 获取总记录数,用于计算总页数
- string countSql = "SELECT COUNT(*) FROM t_patch_detail " + whereClause;
- int totalRecords = Convert.ToInt32(SQLiteHelper.GetSingle(countSql, parameters.ToArray()));
- // 计算总页数
- int totalPages = (int)Math.Ceiling((double)totalRecords / findModel.PageSize);
- // 返回总记录数、总页数和分页结果
- return Tuple.Create(totalRecords, totalPages, patchDetails);
- }
- public static VPatch GetVPatchById(string patchId)
- {
- VPatch vPatch = null;
- // 查询 SQL,从 v_patch 视图中获取数据
- string query = @"
- SELECT
- patch_id,
- create_time,
- patch_name,
- stand_id,
- stand_name,
- detail_count,
- run_count,
- equal_count,
- invalid_count,
- error_count
- FROM v_patch
- WHERE patch_id = @PatchId;";
- // 构造参数
- SQLiteParameter[] parameters = new SQLiteParameter[]
- {
- new SQLiteParameter("@PatchId", patchId)
- };
- // 执行查询
- using (SQLiteDataReader reader = SQLiteHelper.ExecuteReader(query, parameters))
- {
- if (reader.Read())
- {
- vPatch = new VPatch
- {
- PatchId = reader["patch_id"].ToString(),
- CreateTime = reader["create_time"].ToString(),
- PatchName = reader["patch_name"].ToString(),
- StandId = reader["stand_id"].ToString(),
- StandName = reader["stand_name"].ToString(),
- DetailCount = reader["detail_count"] == DBNull.Value ? 0 : Convert.ToInt32(reader["detail_count"]),
- RunCount = reader["run_count"] == DBNull.Value ? 0 : Convert.ToInt32(reader["run_count"]),
- EqualCount = reader["equal_count"] == DBNull.Value ? 0 : Convert.ToInt32(reader["equal_count"]),
- InvalidCount = reader["invalid_count"] == DBNull.Value ? 0 : Convert.ToInt32(reader["invalid_count"]),
- ErrorCount = reader["error_count"] == DBNull.Value ? 0 : Convert.ToInt32(reader["error_count"]),
- };
- }
- }
- return vPatch;
- }
- public static Tuple<int, int, List<VPatchStation>> GetPagedPatchStations(int pageNumber, int pageSize, string findStationId,string patchId)
- {
- // 计算偏移量
- int offset = (pageNumber - 1) * pageSize;
- //动态构造 WHERE 子句
- StringBuilder whereClause = new StringBuilder("WHERE (patch_id = @PatchId");
- if (!string.IsNullOrEmpty(findStationId))
- {
- whereClause.Append(" AND station_id like @FindStationId");
- }
- whereClause.Append(") OR patch_id = ''");
- //string sql = @"
- // SELECT patch_id, station_id, total_count, error_count,equal_count, invalid_count
- // FROM v_patch_detail_station
- // WHERE patch_id = @PatchId OR patch_id = ''
- // ORDER BY station_id ASC -- 根据需要修改排序字段
- // LIMIT @PageSize OFFSET @Offset;";
- string sql = $@"
- SELECT patch_id, station_id, total_count, error_count,equal_count, invalid_count
- FROM v_patch_detail_station
- {whereClause}
- ORDER BY station_id ASC -- 根据需要修改排序字段
- LIMIT @PageSize OFFSET @Offset;";
- // 定义参数
- //SQLiteParameter[] parameters = new SQLiteParameter[]
- List<SQLiteParameter> parameters = new List<SQLiteParameter>
- {
- new SQLiteParameter("@PatchId", patchId),
- new SQLiteParameter("@PageSize", pageSize),
- new SQLiteParameter("@Offset", offset)
- };
- if (!string.IsNullOrEmpty(findStationId))
- {
- parameters.Add(new SQLiteParameter("FindStationId", "%" + findStationId + "%"));
- }
- // 执行查询并读取数据
- List<VPatchStation> vpsDetails = new List<VPatchStation>();
- using (SQLiteDataReader reader = SQLiteHelper.ExecuteReader(sql, parameters.ToArray()))
- {
- while (reader.Read())
- {
- VPatchStation patchDetail = new VPatchStation
- {
- PatchId = reader.GetString(reader.GetOrdinal("patch_id")),
- StationId = reader.GetString(reader.GetOrdinal("station_id")),
- TotalCount = reader.GetInt32(reader.GetOrdinal("total_count")),
- ErrorCount = reader.GetInt32(reader.GetOrdinal("error_count")),
- EqualCount = reader.GetInt32(reader.GetOrdinal("equal_count")),
- InvalidCount = reader.GetInt32(reader.GetOrdinal("invalid_count"))
- };
- vpsDetails.Add(patchDetail);
- }
- }
- // 获取总记录数,用于计算总页数
- string countSql = "SELECT COUNT(*) FROM v_patch_detail_station " + whereClause;
- //WHERE patch_id = @PatchId OR patch_id = ''";
- int totalRecords = Convert.ToInt32(SQLiteHelper.GetSingle(countSql, parameters.ToArray()));
- // 计算总页数
- int totalPages = (int)Math.Ceiling((double)totalRecords / pageSize);
- // 返回总记录数、总页数和分页结果
- return Tuple.Create(totalRecords, totalPages, vpsDetails);
- }
- public static VPatchStation GetPatchStation(string patchId,string stationId)
- {
- VPatchStation vps = null;
- // 查询 SQL,从 v_patch 视图中获取数据
- string query = @"
- SELECT patch_id, station_id, total_count, error_count,equal_count, invalid_count
- FROM v_patch_detail_station
- WHERE patch_id = @PatchId AND station_id=@StationId;";
- // 构造参数
- SQLiteParameter[] parameters = new SQLiteParameter[]
- {
- new SQLiteParameter("@PatchId", patchId),
- new SQLiteParameter("@StationId", stationId),
- };
- // 执行查询
- using (SQLiteDataReader reader = SQLiteHelper.ExecuteReader(query, parameters))
- {
- if (reader.Read())
- {
- vps = new VPatchStation
- {
- PatchId = reader["patch_id"].ToString(),
- StationId = reader["station_id"].ToString(),
- TotalCount = reader["total_count"] == DBNull.Value ? 0 : Convert.ToInt32(reader["total_count"]),
- EqualCount = reader["equal_count"] == DBNull.Value ? 0 : Convert.ToInt32(reader["equal_count"]),
- ErrorCount = reader["error_count"] == DBNull.Value ? 0 : Convert.ToInt32(reader["error_count"]),
- InvalidCount = reader["invalid_count"] == DBNull.Value ? 0 : Convert.ToInt32(reader["invalid_count"])
- };
- }
- }
- return vps;
- }
- //获取所有的识别任务
- public static List<VPatch> GetAllVPatchs()
- {
- // 定义 SQL 查询语句,带有分页
- string sql = @"
- SELECT
- patch_id,
- create_time,
- patch_name,
- stand_id,
- stand_name,
- detail_count,
- run_count,
- equal_count
- FROM v_patch WHERE detail_count = run_count
- ORDER BY create_time DESC";
- // 执行查询并获取结果
- List<VPatch> patchs = new List<VPatch>();
- using (SQLiteDataReader reader = SQLiteHelper.ExecuteReader(sql))
- {
- while (reader.Read())
- {
- // 将查询结果映射到 TStand 对象
- VPatch patch = new VPatch
- {
- PatchId = reader["patch_id"].ToString(),
- CreateTime = reader["create_time"].ToString(),
- PatchName = reader["patch_name"].ToString(),
- StandId = reader["stand_id"].ToString(),
- StandName = reader["stand_name"].ToString(),
- DetailCount = reader["detail_count"] == DBNull.Value ? 0 : Convert.ToInt32(reader["detail_count"]),
- RunCount = reader["run_count"] == DBNull.Value ? 0 : Convert.ToInt32(reader["run_count"]),
- EqualCount = reader["equal_count"] == DBNull.Value ? 0 : Convert.ToInt32(reader["equal_count"])
- };
- patchs.Add(patch);
- }
- }
- return patchs;
- }
- public static List<TPatchDetail> GetPatchDetailsWithRunFlag(string patchId,string stationId,int runFlag)
- {
- // 查询 SQL
- //string sql = @"
- // SELECT patch_detail_id, patch_id, create_time, stand_detail_id, stand_value, src_image,
- // run_flag, run_time, dst_image, meter_type, digit_count, pointer_count,
- // last_unit, result_type, raw_value, final_value, equal_flag, ai_ver, debug_info, log_path
- // FROM t_patch_detail
- // WHERE patch_id = @PatchId AND run_flag = 0
- // ORDER BY create_time AESC;"; // 可以根据需要修改排序字段
- //string sql = @"
- // SELECT patch_detail_id, patch_id, create_time, stand_detail_id, stand_value, src_image
- // FROM t_patch_detail
- // WHERE patch_id = @PatchId AND run_flag = 0
- // ORDER BY create_time ASC;"; // 可以根据需要修改排序字段
- string whereStation = " AND run_flag = @RunFlag";
- if (!string.IsNullOrEmpty(stationId))
- {
- whereStation = " AND station_id = @StationId";
- }
- //string sql = $@"
- // SELECT * FROM t_patch_detail
- // WHERE patch_id = @PatchId AND run_flag = 0{whereStation}
- // ORDER BY station_id,sample_time ASC";
- string sql = $@"
- SELECT * FROM t_patch_detail
- WHERE patch_id = @PatchId{whereStation}
- ORDER BY station_id,sample_time ASC";
- // 定义参数
- SQLiteParameter[] parameters = new SQLiteParameter[]
- {
- new SQLiteParameter("@PatchId", patchId),
- new SQLiteParameter("@StationId",stationId),
- new SQLiteParameter("@RunFlag",runFlag)
- };
- // 执行查询并读取数据
- List<TPatchDetail> patchDetails = new List<TPatchDetail>();
- using (SQLiteDataReader reader = SQLiteHelper.ExecuteReader(sql, parameters))
- {
- while (reader.Read())
- {
- // 将查询结果映射到 TPatchDetail 对象
- TPatchDetail patchDetail = new TPatchDetail
- {
- PatchDetailId = reader.GetString(reader.GetOrdinal("patch_detail_id")),
- PatchId = reader.GetString(reader.GetOrdinal("patch_id")),
- CreateTime = reader.GetString(reader.GetOrdinal("create_time")),
- StandDetailId = reader.GetString(reader.GetOrdinal("stand_detail_id")),
- StandValue = reader.GetString(reader.GetOrdinal("stand_value")),
- SrcImage = reader.GetString(reader.GetOrdinal("src_image")),
- SampleTime = reader.GetString(reader.GetOrdinal("sample_time")),
- RunFlag = reader.GetInt32(reader.GetOrdinal("run_flag")),
- RunTime = reader.GetString(reader.GetOrdinal("run_time")),
- DstImage = reader.GetString(reader.GetOrdinal("dst_image")),
- ResultType = reader.GetInt32(reader.GetOrdinal("result_type")),
- RawValue = reader.GetInt64(reader.GetOrdinal("raw_value")),
- FinalValue = reader.GetInt64(reader.GetOrdinal("final_value")),
- CompleteValue = reader.GetInt64(reader.GetOrdinal("complete_value")),
- ValueChanged = reader.GetInt32(reader.GetOrdinal("value_changed")),
- ResultMeter = reader.GetInt32(reader.GetOrdinal("result_meter")),
- EqualFlag = reader.GetInt32(reader.GetOrdinal("equal_flag")),
- 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")),
- StationKey = reader.GetString(reader.GetOrdinal("station_key")),
- StationId = reader.GetString(reader.GetOrdinal("station_id")),
- MeterType = reader.GetInt32(reader.GetOrdinal("meter_type")),
- BrightVal = reader.GetDouble(reader.GetOrdinal("bright_val")),
- FlowRate = reader.GetInt32(reader.GetOrdinal("flow_rate")),
- DigitCount = reader.GetInt32(reader.GetOrdinal("digit_count")),
- PointerCount = reader.GetInt32(reader.GetOrdinal("pointer_count")),
- LastUnit = reader.GetDouble(reader.GetOrdinal("last_unit")),
- NumInUpper = reader.GetInt32(reader.GetOrdinal("num_in_upper")),
- MeterRegion = reader.GetString(reader.GetOrdinal("meter_region")),
- FeatureRegion = reader.GetString(reader.GetOrdinal("feature_region")),
- LastCompress = reader.GetInt32(reader.GetOrdinal("last_compress")),
- LatestValue = reader.GetInt64(reader.GetOrdinal("latest_value")),
- LatestTime = reader.GetString(reader.GetOrdinal("latest_time")),
- LatestComplete = reader.GetInt64(reader.GetOrdinal("latest_complete"))
- };
- patchDetails.Add(patchDetail);
- }
- }
- return patchDetails;
- }
- public static List<TPatchDetail> GetPatchDetailsWithRunFlag_StandDetal(string patchId, string stationId, int runFlag)
- {
- // 查询 SQL
- //string sql = @"
- // SELECT patch_detail_id, patch_id, create_time, stand_detail_id, stand_value, src_image,
- // run_flag, run_time, dst_image, meter_type, digit_count, pointer_count,
- // last_unit, result_type, raw_value, final_value, equal_flag, ai_ver, debug_info, log_path
- // FROM t_patch_detail
- // WHERE patch_id = @PatchId AND run_flag = 0
- // ORDER BY create_time AESC;"; // 可以根据需要修改排序字段
- //string sql = @"
- // SELECT patch_detail_id, patch_id, create_time, stand_detail_id, stand_value, src_image
- // FROM t_patch_detail
- // WHERE patch_id = @PatchId AND run_flag = 0
- // ORDER BY create_time ASC;"; // 可以根据需要修改排序字段
- string whereStation = " AND a.run_flag = @RunFlag";
- if (!string.IsNullOrEmpty(stationId))
- {
- whereStation = " AND a.station_id = @StationId";
- }
- //string sql = $@"
- // SELECT * FROM t_patch_detail
- // WHERE patch_id = @PatchId AND run_flag = 0{whereStation}
- // ORDER BY station_id,sample_time ASC";
- //string sql = $@"
- // SELECT * FROM t_patch_detail
- // WHERE patch_id = @PatchId{whereStation}
- // ORDER BY station_id,sample_time ASC";
- string sql = $@"
- SELECT a.*, b.dial_region as dial_region1,b.feature_region as feature_region1
- FROM t_patch_detail a
- LEFT JOIN t_stand_detail b ON a.stand_detail_id = b.stand_detail_id
- WHERE a.patch_id = @PatchId{ whereStation}
- ORDER BY a.station_id,a.sample_time ASC";
- // 定义参数
- SQLiteParameter[] parameters = new SQLiteParameter[]
- {
- new SQLiteParameter("@PatchId", patchId),
- new SQLiteParameter("@StationId",stationId),
- new SQLiteParameter("@RunFlag",runFlag)
- };
- // 执行查询并读取数据
- List<TPatchDetail> patchDetails = new List<TPatchDetail>();
- using (SQLiteDataReader reader = SQLiteHelper.ExecuteReader(sql, parameters))
- {
- while (reader.Read())
- {
- // 将查询结果映射到 TPatchDetail 对象
- TPatchDetail patchDetail = new TPatchDetail
- {
- PatchDetailId = reader.GetString(reader.GetOrdinal("patch_detail_id")),
- PatchId = reader.GetString(reader.GetOrdinal("patch_id")),
- CreateTime = reader.GetString(reader.GetOrdinal("create_time")),
- StandDetailId = reader.GetString(reader.GetOrdinal("stand_detail_id")),
- StandValue = reader.GetString(reader.GetOrdinal("stand_value")),
- SrcImage = reader.GetString(reader.GetOrdinal("src_image")),
- SampleTime = reader.GetString(reader.GetOrdinal("sample_time")),
- RunFlag = reader.GetInt32(reader.GetOrdinal("run_flag")),
- RunTime = reader.GetString(reader.GetOrdinal("run_time")),
- DstImage = reader.GetString(reader.GetOrdinal("dst_image")),
- ResultType = reader.GetInt32(reader.GetOrdinal("result_type")),
- RawValue = reader.GetInt64(reader.GetOrdinal("raw_value")),
- FinalValue = reader.GetInt64(reader.GetOrdinal("final_value")),
- CompleteValue = reader.GetInt64(reader.GetOrdinal("complete_value")),
- ValueChanged = reader.GetInt32(reader.GetOrdinal("value_changed")),
- ResultMeter = reader.GetInt32(reader.GetOrdinal("result_meter")),
- EqualFlag = reader.GetInt32(reader.GetOrdinal("equal_flag")),
- 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")),
- StationKey = reader.GetString(reader.GetOrdinal("station_key")),
- StationId = reader.GetString(reader.GetOrdinal("station_id")),
- MeterType = reader.GetInt32(reader.GetOrdinal("meter_type")),
- BrightVal = reader.GetDouble(reader.GetOrdinal("bright_val")),
- FlowRate = reader.GetInt32(reader.GetOrdinal("flow_rate")),
- DigitCount = reader.GetInt32(reader.GetOrdinal("digit_count")),
- PointerCount = reader.GetInt32(reader.GetOrdinal("pointer_count")),
- LastUnit = reader.GetDouble(reader.GetOrdinal("last_unit")),
- NumInUpper = reader.GetInt32(reader.GetOrdinal("num_in_upper")),
- //MeterRegion = reader.GetString(reader.GetOrdinal("meter_region")),
- //FeatureRegion = reader.GetString(reader.GetOrdinal("feature_region")),
- MeterRegion = reader.GetString(reader.GetOrdinal("dial_region1")),
- FeatureRegion = reader.GetString(reader.GetOrdinal("feature_region1")),
- LastCompress = reader.GetInt32(reader.GetOrdinal("last_compress")),
- LatestValue = reader.GetInt64(reader.GetOrdinal("latest_value")),
- LatestTime = reader.GetString(reader.GetOrdinal("latest_time")),
- LatestComplete = reader.GetInt64(reader.GetOrdinal("latest_complete"))
- };
- patchDetails.Add(patchDetail);
- }
- }
- return patchDetails;
- }
- public static int GetPatchDetailsCountWithRunFlagZero(string patchId,string stationId)
- {
- string whereStation = "";
- if(!string.IsNullOrEmpty(stationId))
- {
- whereStation = " AND station_id = @StationId";
- }
- // 查询数据数量的 SQL
- string sql = $@"SELECT COUNT(*) FROM t_patch_detail WHERE patch_id = @PatchId AND run_flag = 0{whereStation}";
- // 定义参数
- SQLiteParameter[] parameters = new SQLiteParameter[]
- {
- new SQLiteParameter("@PatchId", patchId),
- new SQLiteParameter("@StationId",stationId)
- };
- // 执行查询并返回数据数量
- return Convert.ToInt32(SQLiteHelper.GetSingle(sql, parameters));
- }
- /// <summary>
- /// 根据 patch_detail_id 删除指定的记录
- /// </summary>
- /// <param name="patchDetailId">要删除的记录的 ID</param>
- /// <returns>删除成功返回 true,否则返回 false</returns>
- public static bool DeleteTPatchDetailById(string patchDetailId)
- {
- // 构建删除的 SQL 语句
- string sql = "DELETE FROM t_patch_detail WHERE patch_detail_id = @PatchDetailId";
- // 创建参数数组
- SQLiteParameter[] parameters = new SQLiteParameter[]
- {
- new SQLiteParameter("@PatchDetailId", patchDetailId)
- };
- 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>
- /// 根据 standDetailId 删除t_patch_detail与t_stand_detail中相关的数据
- /// </summary>
- /// <param name="standDetailId">要删除的记录的 模板详情ID</param>
- /// <returns>删除成功返回 true,否则返回 false</returns>
- public static bool Delete_TPatchDetail_TStandDetail_ByStand(string standDetailId)
- {
- // 构建删除的 SQL 语句
- //string sql = "DELETE FROM t_patch_detail WHERE patch_detail_id = @PatchDetailId";
- // 定义删除的 SQL 语句,使用事务来保证一致性
- string sql = @"
- BEGIN TRANSACTION;
- -- 删除 t_patch_detail 表中与 stand_id 相关的数据
- DELETE FROM t_patch_detail WHERE stand_detail_id = @StandDetailId;
- -- 删除 t_patch 表中与 patch_id 相关的数据
- DELETE FROM t_stand_detail WHERE stand_detail_id = @StandDetailId;
- COMMIT;";
- // 创建参数数组
- SQLiteParameter[] parameters = new SQLiteParameter[]
- {
- new SQLiteParameter("@StandDetailId", standDetailId)
- };
- 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;
- }
- }
- public static bool UpdatePatchName(string patchId, string patchName)
- {
- string sql = @"
- UPDATE t_patch
- SET patch_name = @PatchName
- WHERE patch_id = @PatchId;";
- // 创建 SQL 参数
- SQLiteParameter[] parameters = new SQLiteParameter[]
- {
- new SQLiteParameter("@PatchName", patchName),
- new SQLiteParameter("@PatchId", patchId)
- };
- // 执行更新操作并返回受影响的行数
- return SQLiteHelper.ExecuteNonQuery(sql, parameters) > 0;
- }
- public static bool UpdatePatchDetailMemo(string detailId,string memo)
- {
- // 定义 SQL 更新语句
- string sql = @"
- UPDATE t_patch_detail
- SET memo = @Memo
- WHERE patch_detail_id = @PatchDetailId;";
- // 创建 SQL 参数
- SQLiteParameter[] parameters = new SQLiteParameter[]
- {
- new SQLiteParameter("@PatchDetailId", detailId),
- new SQLiteParameter("@Memo", memo)
- };
- // 执行更新操作并返回受影响的行数
- return SQLiteHelper.ExecuteNonQuery(sql, parameters) > 0;
- }
- //升级数据库(t_patch_detail添加memo字段)
- public static void UpdateTPatchDetailSchema()
- {
- string sql = "PRAGMA table_info(t_patch_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_patch_detail ADD COLUMN memo TEXT NOT NULL DEFAULT ''";
- SQLiteHelper.ExecuteNonQuery(sql, null);
- }
- }//using
- }
-
- //////////////////////////////////////////////////////////
- }
- }
|