CNAS取数仪器端升级
Ви не можете вибрати більше 25 тем Теми мають розпочинатися з літери або цифри, можуть містити дефіси (-) і не повинні перевищувати 35 символів.

4 місяці тому
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using System.Text;
  5. using System.Data;
  6. using CnasSynchronousCommon;
  7. using CnasSynchrousModel;
  8. using System.Reflection;
  9. using Devart.Common;
  10. using Npgsql;
  11. using Kdbndp;
  12. namespace CnasSynchronusDAL
  13. {
  14. public class KingbaseDAL
  15. {
  16. public void CreateConnectString(string strIP, string strPort, string strName, string strUser, string strPwd)
  17. {
  18. KingbaseHelper.InitConnectionString(strIP, strPort, strName, strUser, strPwd);
  19. }
  20. public void CreateConnectString(string strConnectString)
  21. {
  22. KingbaseHelper.InitConnectionString(strConnectString);
  23. }
  24. //获取所有表单名称
  25. public DataTable GetTableNames(string strName)
  26. {
  27. DataTable dt = new DataTable();
  28. //string strSql = string.Format("SELECT table_name as TABNAME FROM information_schema.TABLES WHERE table_schema='{0}'", strName);
  29. string strSql = string.Format("SELECT table_name as TABNAME FROM information_schema.TABLES WHERE table_catalog='{0}' and table_schema='public'", strName);
  30. try
  31. {
  32. dt = KingbaseHelper.ExecuteDataSet(strSql).Tables[0];
  33. }
  34. catch (Exception ex)
  35. {
  36. AppLog.Error(ex.Message);
  37. }
  38. return dt;
  39. }
  40. /// <summary>
  41. /// 获取某表的表结构
  42. /// </summary>
  43. /// <param name="strTableName"></param>
  44. /// <returns></returns>
  45. public DataTable GetTableStruct(string strTableName, string strViewName, string strViewSql)
  46. {
  47. DataTable dt = new DataTable();
  48. if (strTableName.Length <= 0) return dt;
  49. string strSql = "";
  50. if (strViewName == strTableName && !string.IsNullOrWhiteSpace(strViewName))
  51. strSql = strViewSql + " where 0=1";
  52. else
  53. strSql = string.Format("SELECT * FROM {0} Where 0=1", strTableName);
  54. try
  55. {
  56. AppLog.Error("===-222-===" + strTableName + strSql);
  57. dt = KingbaseHelper.ExecuteDataSet(strSql).Tables[0];
  58. AppLog.Error("===-333-===" + strTableName + "KingbaseHelper.ExecuteDataSet(strSql)" + dt);
  59. }
  60. catch (Exception ex)
  61. {
  62. AppLog.Error(ex.Message);
  63. }
  64. return dt;
  65. }
  66. /// <summary>
  67. /// 获取某表的表结构和类型长度
  68. /// </summary>
  69. /// <param name="strTableName"></param>
  70. /// <returns></returns>
  71. public DataTable GetTableTypeAndLenth(string strTableName)
  72. {
  73. DataTable dt = new DataTable();
  74. string strSql = string.Format("select COLUMN_NAME AS 'ColumnName',IS_NULLABLE AS 'IsNullable',DATA_TYPE AS 'DataType',CHARACTER_MAXIMUM_LENGTH AS 'CharMaxLenth',CHARACTER_OCTET_LENGTH AS 'CharOcterLenth',NUMERIC_PRECISION AS 'NumericPrecision',NUMERIC_SCALE AS 'NumericScale' FROM information_schema.COLUMNS WHERE TABLE_NAME LIKE '{0}'", strTableName);
  75. try
  76. {
  77. dt = KingbaseHelper.ExecuteDataSet(strSql).Tables[0];
  78. }
  79. catch (Exception ex)
  80. {
  81. AppLog.Error(ex.Message);
  82. }
  83. return dt;
  84. }
  85. /// <summary>
  86. /// 逐行批量插入数据
  87. /// </summary>
  88. /// <param name="dt"></param>
  89. /// <returns></returns>
  90. public int InsertCnasData(DataTable dt, List<SyncParamasInfo> syncParamasInfos, List<CnasConditionMapValue> lstFixedValue, string strInsumentColumn)
  91. {
  92. int iReturn = 0;
  93. if (dt.Rows.Count <= 0) return 0;
  94. try
  95. {
  96. //获取唯一健组(关键字段)
  97. var query = from p in syncParamasInfos
  98. where p.IfPrimaryKey == true
  99. select new
  100. {
  101. p.TargetField
  102. };
  103. List<string> lstKeyColumns = new List<string>();
  104. foreach (var item in query)
  105. {
  106. lstKeyColumns.Add(item.TargetField);
  107. }
  108. //构建SQL语句
  109. string strSql_part1 = "";
  110. string strSql_part2 = "";
  111. List<string> lstColumnName = new List<string>();
  112. foreach (var item in syncParamasInfos)
  113. {
  114. if (!lstColumnName.Contains(item.TargetField.ToLower()))
  115. {
  116. strSql_part1 += item.TargetField + ",";
  117. strSql_part2 += string.Format("@{0},", item.TargetField.ToLower());
  118. lstColumnName.Add(item.TargetField.ToLower());
  119. }
  120. }
  121. //如果映射列中不包含固定列,则需要将这些列添加到SQL语句中
  122. if (lstFixedValue != null)
  123. {
  124. foreach (var cnasfield in lstFixedValue)
  125. {
  126. if (cnasfield.TableName != syncParamasInfos[0].TargetTable) continue;
  127. if (!lstColumnName.Contains(cnasfield.ColumnName.ToLower()))
  128. {
  129. strSql_part1 += cnasfield.ColumnName + ",";
  130. strSql_part2 += string.Format("@{0},", cnasfield.ColumnName.ToLower());
  131. lstColumnName.Add(cnasfield.ColumnName.ToLower());
  132. }
  133. }
  134. }
  135. //增加仪器编号数据
  136. if (!string.IsNullOrWhiteSpace(strInsumentColumn) && !lstColumnName.Contains(strInsumentColumn.ToLower()))
  137. {
  138. strSql_part1 += strInsumentColumn + ",";
  139. strSql_part2 += string.Format("@{0},", strInsumentColumn);
  140. lstColumnName.Add(strInsumentColumn.ToLower());
  141. }
  142. string strInsertSql = string.Format("insert into {0}({1}) values({2})", syncParamasInfos[0].TargetTable, strSql_part1.Substring(0, strSql_part1.Length - 1), strSql_part2.Substring(0, strSql_part2.Length - 1));
  143. string strUpdateSql = "";
  144. DataTable dtSelect = new DataTable();
  145. foreach (DataRow dr in dt.Rows)
  146. {
  147. //插入参数值
  148. KdbndpParameter[] parameters = new KdbndpParameter[lstColumnName.Count];
  149. int i = 0;
  150. foreach (var item in lstColumnName)
  151. {
  152. parameters[i++] = new KdbndpParameter(item, dr[item]);
  153. }
  154. //插入时发现已经在数据库中存在该值,则进行更新操作
  155. int ifHavaValue = ExistSingleCnasData(lstKeyColumns, syncParamasInfos[0].TargetTable, dr, ref dtSelect);
  156. if (ifHavaValue == 1)
  157. {
  158. if (dtSelect.Rows.Count == 1)
  159. {
  160. //比对获取的数据跟准备更新的数据是否一样
  161. if (!CompareObjectOperation.DataRowCompare(dtSelect.Rows[0], dr, lstColumnName))
  162. {
  163. //构造更新语句
  164. strUpdateSql = GetUpdateSql(lstColumnName, lstKeyColumns, syncParamasInfos[0].TargetTable, dr);
  165. //执行UpdateSql语句
  166. iReturn += KingbaseHelper.ExecuteNonQuery(strUpdateSql, parameters);
  167. }
  168. else
  169. {
  170. iReturn = -2;
  171. AppLog.Info("更新时发现在数据库中相同关键字段数据一致。");
  172. }
  173. }
  174. else
  175. {
  176. AppLog.Error("更新时发现在数据库中多条相同关键字段数据,请重新配置关键字段。");
  177. }
  178. }
  179. else if (ifHavaValue == 0)
  180. {
  181. //执行InsertSQL语句
  182. iReturn += KingbaseHelper.ExecuteNonQuery(strInsertSql, parameters);
  183. }
  184. }
  185. }
  186. catch (Exception ex)
  187. {
  188. if (!LinkCnasTest())
  189. {
  190. iReturn = -1; //用于表示插入时无法正常数据库连接问题
  191. }
  192. //此处添加错误日志
  193. AppLog.Error(ex.Message);
  194. }
  195. return iReturn;
  196. }
  197. /// <summary>
  198. /// 拼接Update语句
  199. /// </summary>
  200. /// <param name="lstColumnName"></param>
  201. /// <param name="lstPrimaryColumn"></param>
  202. /// <param name="dr"></param>
  203. private string GetUpdateSql(List<string> lstColumnName, List<string> lstPrimaryColumn, string strTableName, DataRow dr)
  204. {
  205. //构造关键字段条件
  206. string strsql_partial = "";
  207. foreach (var item in lstPrimaryColumn)
  208. {
  209. if (dr.Table.Columns.Contains(item.ToString()))
  210. if (dr[item.ToString()].ToString() != "")
  211. strsql_partial += $"{item.ToString()}='{dr[item.ToString()].ToString()}' and ";
  212. else
  213. strsql_partial += $"({item.ToString()}='{dr[item.ToString()].ToString()}' or {item.ToString()} is null) and ";
  214. }
  215. //构造Update语句
  216. string strUpdateSql = "";
  217. string strsql_partial2 = "";
  218. foreach (var item in lstColumnName)
  219. {
  220. strsql_partial2 += $"{item}=@{item},";
  221. }
  222. if (strsql_partial.Length > 3 && strsql_partial2.Length > 0)
  223. strUpdateSql = $"update {strTableName} set {strsql_partial2.Substring(0, strsql_partial2.Length - 1)} where {strsql_partial.Substring(0, strsql_partial.Length - 4)}";
  224. return strUpdateSql;
  225. }
  226. internal bool CheckMacMessage(string strMac)
  227. {
  228. bool bIfChecked = false;
  229. string strSql = string.Format("select * FROM macaddress WHERE MAC_ADDRESS='{0}'", strMac);
  230. try
  231. {
  232. DataTable dt = KingbaseHelper.ExecuteDataSet(strSql).Tables[0];
  233. if (dt != null && dt.Rows.Count > 0)
  234. {
  235. bIfChecked = true;
  236. }
  237. }
  238. catch (Exception ex)
  239. {
  240. AppLog.Error(ex.Message);
  241. }
  242. return bIfChecked;
  243. }
  244. /// <summary>
  245. /// 是否数据库中已经存在数据,如果存在返回1,并且传递返回的数据;如果不存在,返回0;如果发生了异常,返回-1
  246. /// </summary>
  247. /// <param name="lstPrimaryColumn"></param>
  248. /// <param name="strTableName"></param>
  249. /// <param name="dr"></param>
  250. /// <param name="dtSelect"></param>
  251. /// <returns></returns>
  252. private int ExistSingleCnasData(List<string> lstPrimaryColumn, string strTableName, DataRow dr, ref DataTable dtSelect)
  253. {
  254. int bIfHaveValue = 0; //如果存在,返回1;如果不存在,返回0;如果发生了异常,返回-1
  255. string strsql_partial = "";
  256. string strSql = "";
  257. foreach (var item in lstPrimaryColumn)
  258. {
  259. if (dr.Table.Columns.Contains(item.ToString()))
  260. if (dr[item.ToString()].ToString() != "")
  261. strsql_partial += $"{item.ToString()}='{dr[item.ToString()].ToString()}' and ";
  262. else
  263. strsql_partial += $"({item.ToString()}='{dr[item.ToString()].ToString()}' or {item.ToString()} is null) and ";
  264. }
  265. if (strsql_partial.Length > 3)
  266. strSql = $"select * from {strTableName} where {strsql_partial.Substring(0, strsql_partial.Length - 4)}";
  267. if (strsql_partial.Length > 3 && (strTableName.Equals("tcoalweight") || strTableName.Equals("TCOALWEIGHT")))
  268. strSql = $"select * from {strTableName} where (idbatch is null or idbatch = '') and {strsql_partial.Substring(0, strsql_partial.Length - 4)}";
  269. if (strSql != "")
  270. {
  271. DataTable dt = KingbaseHelper.ExecuteDataTable(strSql, new KdbndpParameter[] { });
  272. if (dt != null && dt.Rows.Count > 0)
  273. {
  274. bIfHaveValue = 1;
  275. dtSelect = dt;
  276. AppLog.Info($"插入前查询时存在重复数据:{strSql}");
  277. }
  278. else if (dt == null)
  279. {
  280. bIfHaveValue = -1;
  281. AppLog.Info($"插入前查询时发生了异常:{strSql}");
  282. }
  283. }
  284. return bIfHaveValue;
  285. }
  286. internal DataTable GetLoginNameByPwd(string strUserName, string strPwd)
  287. {
  288. DataTable dt = new DataTable();
  289. string strSql = string.Format("select * FROM user WHERE userid='{0}' and password='{1}'", strUserName, strPwd);
  290. try
  291. {
  292. dt = KingbaseHelper.ExecuteDataSet(strSql).Tables[0];
  293. }
  294. catch (Exception ex)
  295. {
  296. AppLog.Error(ex.Message);
  297. }
  298. return dt;
  299. }
  300. public bool LinkCnasTest()
  301. {
  302. return KingbaseHelper.TestConnectKingbase();
  303. }
  304. /// <summary>
  305. /// 获得表中该列中最大时间
  306. /// </summary>
  307. /// <param name="dt"></param>
  308. /// <returns></returns>
  309. public string GetMaxTimeByTableName(string strTableName, string strDateColumn, string strInstrumentColumn, string strInstrumentValue)
  310. {
  311. string strReturnTime = "";
  312. //因为数据库用varchar存储日期字段,从而格式不固定,需要使用多种格式读取
  313. try
  314. {
  315. #region 旧的获取时间方法
  316. ////string strSql_1 = string.Format("SELECT max(STR_TO_DATE({0},'%Y-%m-%d %H:%i:%s')) FROM {1} ", strDateColumn, strTableName);
  317. ////string strSql_2 = string.Format("SELECT max(STR_TO_DATE({0},'%Y/%m/%d %H:%i:%s')) FROM {1} ", strDateColumn, strTableName);
  318. //string strSql_2 = string.Format("SELECT max(Convert({0},datetime)) FROM {1} ", strDateColumn, strTableName);
  319. ////string strDateTime_1 = GetMaxTimeByTableName(strSql_1);
  320. //string strDateTime_2= GetMaxTimeByTableName(strSql_2);
  321. ////AppLog.Info($"读取到最大的时间(1):表-{strTableName},列-{strDateColumn},值-{strDateTime_1}");
  322. //AppLog.Info($"读取到最大的时间(2):表-{strTableName},列-{strDateColumn},值-{strDateTime_2}");
  323. //List<DateTime> lstTime = new List<DateTime>();
  324. ////DateTime dateTime_1 = DateTime.Now;
  325. //DateTime dateTime_2 = DateTime.Now;
  326. ////if (DateTime.TryParse(strDateTime_1, out dateTime_1))
  327. ////{
  328. //// lstTime.Add(dateTime_1);
  329. ////}
  330. //if (DateTime.TryParse(strDateTime_2, out dateTime_2))
  331. //{
  332. // if (!lstTime.Contains(dateTime_2))
  333. // lstTime.Add(dateTime_2);
  334. //}
  335. //if (lstTime.Count > 0)
  336. //{
  337. // strReturnTime = lstTime.Max<DateTime>().ToString();
  338. // AppLog.Info($"返回最大的时间(3):表-{strTableName},列-{strDateColumn},值-{strReturnTime}");
  339. //}
  340. # endregion
  341. string strSql = string.Format("SELECT Convert(max(Convert({0},datetime)) using utf8) FROM {1}", strDateColumn, strTableName, strInstrumentColumn, strInstrumentValue);
  342. if (!string.IsNullOrWhiteSpace(strInstrumentColumn) && !string.IsNullOrWhiteSpace(strInstrumentValue))
  343. strSql += string.Format(" where {0}='{1}'", strInstrumentColumn, strInstrumentValue);
  344. string strDateTime = GetMaxTimeByTableName(strSql);
  345. DateTime dateTime = DateTime.Now;
  346. if (DateTime.TryParse(strDateTime, out dateTime))
  347. {
  348. strReturnTime = strDateTime;
  349. }
  350. }
  351. catch (Exception ex)
  352. {
  353. //if (!LinkCnasTest())
  354. //{
  355. // strReturnTime = "1899-1-1"; //用于表示插入时无法正常数据库连接问题
  356. //}
  357. //只要发生异常,就返回这个结果
  358. strReturnTime = "1899-1-1";
  359. AppLog.Error(ex.Message);
  360. }
  361. return strReturnTime;
  362. }
  363. internal DataTable GetDataByDateColumn(string strDBName, string strViewName, string strViewSql, string strTableName, string strDateColumn, string strDate)
  364. {
  365. DataTable dtReturn = new DataTable();
  366. try
  367. {
  368. string strSql = "";
  369. if (strViewName == strTableName && !string.IsNullOrWhiteSpace(strViewName))
  370. strSql = strViewSql + $" where {strDateColumn} >convert( '{strDate}',datetime)";
  371. else
  372. strSql = $"select * from {strDBName}.public.{strTableName} where \"{strDateColumn}\">TO_TIMESTAMP('{strDate}', 'YYYY-MM-DD HH24:MI:SS');";
  373. DataTable dt = KingbaseHelper.ExecuteDataSet(strSql).Tables[0];
  374. Dictionary<string, string> dictFiled = GetSpecialOperaField(strDBName, strTableName);
  375. if (dictFiled.Count > 0)
  376. dtReturn = DateAndTimeTypeOpera(dt, dictFiled);
  377. else
  378. dtReturn = dt;
  379. }
  380. catch (Exception ex)
  381. {
  382. //发生异常,写入日志
  383. AppLog.Error(ex.Message);
  384. throw ex;
  385. }
  386. return dtReturn;
  387. }
  388. internal Dictionary<string, DataTable> GetAllTableNameAndStructure(string strDBName)
  389. {
  390. Dictionary<string, DataTable> dictTables = new Dictionary<string, DataTable>();
  391. try
  392. {
  393. DataTable TablesName = GetTableNames(strDBName);//得到所有表
  394. foreach (DataRow dr in TablesName.Rows)
  395. {
  396. string strTableName = dr[0].ToString();
  397. AppLog.Error("===---===" + strTableName + "GetTableStruct(strTableName, )");
  398. dictTables.Add(strTableName.ToUpper(), GetTableStruct(strTableName, "", ""));
  399. }
  400. }
  401. catch (Exception ex)
  402. {
  403. //发生异常,写入日志
  404. AppLog.Error(ex.Message);
  405. //throw ex;
  406. }
  407. return dictTables;
  408. }
  409. public string GetMaxTimeByTableName(string strSql)
  410. {
  411. string strDateTime = "";
  412. try
  413. {
  414. DataTable dt = KingbaseHelper.ExecuteDataSet(strSql).Tables[0];
  415. AppLog.Info($"执行语句获得最晚时间:{strSql}");
  416. if (dt != null && dt.Rows.Count == 1)
  417. {
  418. strDateTime = dt.Rows[0][0].ToString();
  419. AppLog.Info($"执行语句获得最晚时间:行数-({dt.Rows.Count}),列数-({dt.Columns.Count}),值-({strDateTime})");
  420. }
  421. }
  422. catch (Exception ex)
  423. {
  424. if (!LinkCnasTest())
  425. {
  426. strDateTime = "1899-1-1"; //用于表示插入时无法正常数据库连接问题
  427. }
  428. AppLog.Error(ex.Message);
  429. }
  430. return strDateTime;
  431. }
  432. /// <summary>
  433. /// 获取所有数据字段,然后记录其中是否存在需要特殊处理的字段
  434. /// </summary>
  435. /// <returns></returns>
  436. private static Dictionary<string, string> GetSpecialOperaField(string strDBName, string strTableName)
  437. {
  438. Dictionary<string, string> DictFiled = new Dictionary<string, string>();
  439. DataTable dt = new DataTable();
  440. try
  441. {
  442. string sql = string.Format("SELECT * FROM INFORMATION_SCHEMA.COLUMNS WHERE TABLE_NAME='{0}' and table_schema='{1}'", strTableName, strDBName); //查询字符串
  443. dt = KingbaseHelper.ExecuteDataSet(sql).Tables[0];
  444. foreach (DataRow dr in dt.Rows)
  445. {
  446. if (dr["data_type"].ToString().ToLower() == "date" || dr["data_type"].ToString().ToLower() == "time")
  447. {
  448. DictFiled.Add(dr["column_name"].ToString(), dr["data_type"].ToString());
  449. }
  450. }
  451. }
  452. catch (Exception ex)
  453. {
  454. //发生异常,写入日志
  455. AppLog.Error(ex.Message);
  456. }
  457. return DictFiled;
  458. }
  459. /// <summary>
  460. /// 获取数据时,单独处理某些(Date和Time)类型数据,并把数据类型转换为字符串类型
  461. /// </summary>
  462. private static DataTable DateAndTimeTypeOpera(DataTable dt, Dictionary<string, string> DictSpecialField)
  463. {
  464. DataTable dtNewFormat = new DataTable();
  465. //添加列
  466. foreach (DataColumn dc in dt.Columns)
  467. {
  468. if (DictSpecialField.ContainsKey(dc.ColumnName))
  469. {
  470. string strDateType = DictSpecialField[dc.ColumnName];
  471. switch (strDateType.ToUpper())
  472. {
  473. case "DATE":
  474. case "TIME":
  475. dtNewFormat.Columns.Add(dc.ColumnName, typeof(string)); //使用字符串来存储该字段,而不是采用它的数据库格式(C#无法区分Date, Time,DateTime,前两种格式会自动补充数据,导致数据的不准确)
  476. break;
  477. default:
  478. dtNewFormat.Columns.Add(dc.ColumnName, dc.DataType);
  479. break;
  480. }
  481. }
  482. else
  483. {
  484. dtNewFormat.Columns.Add(dc.ColumnName, dc.DataType);
  485. }
  486. }
  487. //添加数据行
  488. foreach (DataRow dr in dt.Rows)
  489. {
  490. DataRow drNewRow = dtNewFormat.NewRow();
  491. foreach (DataColumn dc in dtNewFormat.Columns)
  492. {
  493. if (!DictSpecialField.ContainsKey(dc.ColumnName))
  494. drNewRow[dc.ColumnName] = dr[dc.ColumnName];
  495. else
  496. {
  497. switch (DictSpecialField[dc.ColumnName].ToUpper())
  498. {
  499. case "DATE":
  500. if (dr[dc.ColumnName] != null && dr[dc.ColumnName].ToString() != "")
  501. drNewRow[dc.ColumnName] = Convert.ToDateTime(dr[dc.ColumnName]).ToString("yyyy-MM-dd");
  502. break;
  503. case "TIME":
  504. if (dr[dc.ColumnName] != null && dr[dc.ColumnName].ToString() != "")
  505. drNewRow[dc.ColumnName] = Convert.ToDateTime(dr[dc.ColumnName].ToString()).ToString("HH:mm:ss");
  506. break;
  507. default:
  508. drNewRow[dc.ColumnName] = dr[dc.ColumnName];
  509. break;
  510. }
  511. }
  512. }
  513. dtNewFormat.Rows.Add(drNewRow);
  514. }
  515. //返回数据
  516. return dtNewFormat;
  517. }
  518. /// <summary>
  519. /// 获取某个表的数据
  520. /// </summary>
  521. /// <param name="strSql"></param>
  522. /// <returns></returns>
  523. public DataTable GetTableData(string strSql)
  524. {
  525. DataTable dt = new DataTable();
  526. try
  527. {
  528. dt = KingbaseHelper.ExecuteDataSet(strSql).Tables[0];
  529. }
  530. catch (Exception ex)
  531. {
  532. AppLog.Error(ex.Message);
  533. }
  534. return dt;
  535. }
  536. /// <summary>
  537. /// 插入某个表的数据
  538. /// </summary>
  539. /// <param name="strSql"></param>
  540. /// <returns></returns>
  541. public bool InsertTableData(string strSql)
  542. {
  543. try
  544. {
  545. return KingbaseHelper.ExecuteNonQuery(strSql) > 0;
  546. }
  547. catch (Exception ex)
  548. {
  549. AppLog.Error(ex.Message);
  550. }
  551. return false;
  552. }
  553. }
  554. }