You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

2182 lines
79 KiB

3 weeks ago
  1. using ICS.Data;
  2. using NFine.Code;
  3. using System;
  4. using System.Collections.Generic;
  5. using System.Configuration;
  6. using System.Data;
  7. using System.Data.Common;
  8. using System.Data.SqlClient;
  9. using System.IO;
  10. using System.Linq;
  11. using System.Net;
  12. using System.Security.Cryptography;
  13. using System.Text;
  14. using System.Text.RegularExpressions;
  15. using System.Threading.Tasks;
  16. using System.Web;
  17. namespace NFine.Data.Extensions
  18. {
  19. /// <summary>
  20. /// 数据库访问辅助类,add by ngye, on 2013-08-14.
  21. /// </summary>
  22. public static class SqlHelper
  23. {
  24. #region [ 连接串相关 ]
  25. /// <summary>
  26. /// 数据中心DB的连接字符串
  27. /// </summary>
  28. public static string DataCenterConnString = FromMd5(ConfigurationManager.ConnectionStrings["connstr"].ConnectionString);
  29. public static void ExecuteDataSet(DataSet data)
  30. {
  31. try
  32. {
  33. //DBHelper.ExecuteNonQuery(dsconn, CommandType.Text, sql);
  34. using (SqlConnection destinationConnection = new SqlConnection(DataCenterConnString))
  35. {
  36. destinationConnection.Open();//打开连接
  37. SqlTransaction bulkTran = destinationConnection.BeginTransaction();
  38. using (SqlBulkCopy bulkCopy = new SqlBulkCopy(destinationConnection, SqlBulkCopyOptions.CheckConstraints, bulkTran))
  39. {
  40. //将DataTable插入到后台
  41. bulkCopy.BulkCopyTimeout = 30;
  42. foreach (DataTable dt in data.Tables)
  43. {
  44. bulkCopy.DestinationTableName = dt.TableName;//目标数据表名
  45. try
  46. {
  47. bulkCopy.WriteToServer(dt);
  48. }
  49. catch (Exception eBulk)
  50. {
  51. bulkTran.Rollback();
  52. bulkCopy.Close();
  53. destinationConnection.Close();
  54. throw eBulk;
  55. }
  56. }
  57. bulkTran.Commit();
  58. bulkCopy.Close();
  59. }
  60. destinationConnection.Close();
  61. }
  62. }
  63. catch (Exception ex)
  64. {
  65. throw ex;
  66. }
  67. }
  68. #region 字符串加解密
  69. /// <summary>
  70. /// MD5加密
  71. /// </summary>
  72. /// <param name="str"></param>
  73. /// <returns></returns>
  74. public static string ToMd5(string str)
  75. {
  76. return Encrypt(str, "&%#@?,:*_");
  77. }
  78. /// <summary>
  79. /// MD5解密
  80. /// </summary>
  81. /// <param name="str"></param>
  82. /// <returns></returns>
  83. public static string FromMd5(string str)
  84. {
  85. //return str;
  86. return Decrypt(str, "&%#@?,:*_");
  87. }
  88. /// <summary>
  89. /// 加密
  90. /// </summary>
  91. /// <param name="strText"></param>
  92. /// <param name="strEncrKey"></param>
  93. /// <returns></returns>
  94. private static String Encrypt(String strText, String strEncrKey)
  95. {
  96. Byte[] byKey = { };
  97. Byte[] IV = { 0x12, 0x34, 0x56, 0x78, 0x90, 0xAB, 0xCD, 0xEF };
  98. try
  99. {
  100. byKey = System.Text.Encoding.UTF8.GetBytes(strEncrKey.Substring(0, 8));
  101. DESCryptoServiceProvider des = new DESCryptoServiceProvider();
  102. Byte[] inputByteArray = Encoding.UTF8.GetBytes(strText);
  103. MemoryStream ms = new MemoryStream();
  104. CryptoStream cs = new CryptoStream(ms, des.CreateEncryptor(byKey, IV),
  105. CryptoStreamMode.Write);
  106. cs.Write(inputByteArray, 0, inputByteArray.Length);
  107. cs.FlushFinalBlock();
  108. return Convert.ToBase64String(ms.ToArray());
  109. }
  110. catch (Exception ex)
  111. {
  112. return ex.Message;
  113. }
  114. }
  115. /// <summary>
  116. /// 解密
  117. /// </summary>
  118. /// <param name="strText"></param>
  119. /// <param name="sDecrKey"></param>
  120. /// <returns></returns>
  121. private static String Decrypt(String strText, String sDecrKey)
  122. {
  123. Byte[] byKey = { };
  124. Byte[] IV = { 0x12, 0x34, 0x56, 0x78, 0x90, 0xAB, 0xCD, 0xEF };
  125. Byte[] inputByteArray = new byte[strText.Length];
  126. try
  127. {
  128. byKey = System.Text.Encoding.UTF8.GetBytes(sDecrKey.Substring(0, 8));
  129. DESCryptoServiceProvider des = new DESCryptoServiceProvider();
  130. inputByteArray = Convert.FromBase64String(strText);
  131. MemoryStream ms = new MemoryStream();
  132. CryptoStream cs = new CryptoStream(ms, des.CreateDecryptor(byKey, IV),
  133. CryptoStreamMode.Write);
  134. cs.Write(inputByteArray, 0, inputByteArray.Length);
  135. cs.FlushFinalBlock();
  136. System.Text.Encoding encoding = System.Text.Encoding.UTF8;
  137. return encoding.GetString(ms.ToArray());
  138. }
  139. catch (Exception ex)
  140. {
  141. return ex.Message;
  142. }
  143. }
  144. #endregion
  145. /// <summary>
  146. /// 获取同步服务器的连接
  147. /// </summary>
  148. /// <returns></returns>
  149. public static SqlConnection GetDataCenterConn()
  150. {
  151. return new SqlConnection(DataCenterConnString);
  152. }
  153. /// <summary>
  154. /// 根据连接串获取连接
  155. /// </summary>
  156. /// <returns></returns>
  157. public static SqlConnection GetConnByStr(string connStr)
  158. {
  159. string ConnString = FromMd5(ConfigurationManager.ConnectionStrings[connStr].ConnectionString);
  160. return new SqlConnection(ConnString);
  161. }
  162. //public static SqlConnection SetDateBase(){
  163. // ConfigurationManager.ConnectionStrings["connstr"] = MD5DbTXT;
  164. // config.Save();
  165. // }
  166. /// <summary>
  167. /// 根据连接串获取连接
  168. /// </summary>
  169. /// <returns></returns>
  170. public static SqlConnection GetConnByString(string conn)
  171. {
  172. return new SqlConnection(conn);
  173. }
  174. /// <summary>
  175. /// 测试连接串是否能正确
  176. /// </summary>
  177. /// <param name="connectionString">连接串</param>
  178. /// <returns></returns>
  179. public static bool TestConnectionString(string connectionString)
  180. {
  181. bool result = true;
  182. try
  183. {
  184. using (SqlConnection conn = GetConnByString(connectionString))
  185. {
  186. try
  187. {
  188. conn.Open();
  189. }
  190. catch (Exception ex)
  191. {
  192. result = false;
  193. }
  194. }
  195. }
  196. catch (Exception)
  197. {
  198. result = false;
  199. }
  200. return result;
  201. }
  202. /// <summary>
  203. /// 测试连接串是否正确
  204. /// </summary>
  205. /// <param name="connectionString">连接串</param>
  206. /// <param name="timeOut">测试的超时秒数</param>
  207. /// <param name="errInfo">错误时输出的错误信息</param>
  208. /// <returns>是否能正常连接</returns>
  209. public static bool TestConnectionString(string connectionString, int timeOut, ref string errInfo)
  210. {
  211. bool result = true;
  212. string[] arr = connectionString.Split(new char[] { ';' });
  213. List<string> list = new List<string>();
  214. foreach (string s in arr)
  215. {
  216. if (s.ToLower().IndexOf("timeout") == -1)
  217. {
  218. list.Add(s);
  219. }
  220. else
  221. {
  222. list.Add(String.Format("Connection Timeout={0}", timeOut));
  223. }
  224. }
  225. SqlConnection con = null;
  226. try
  227. {
  228. con = new SqlConnection(string.Join(";", list.ToArray()));
  229. con.Open();
  230. }
  231. catch (Exception ex)
  232. {
  233. result = false;
  234. errInfo = ex.Message;
  235. }
  236. finally
  237. {
  238. if (con != null)
  239. {
  240. con.Close();
  241. con.Dispose();
  242. con = null;
  243. }
  244. }
  245. return result;
  246. }
  247. #endregion
  248. #region [ 超时设置 ]
  249. public static int CommandTimeout
  250. {
  251. get
  252. {
  253. return 7200;
  254. }
  255. }
  256. #endregion
  257. /// <summary>
  258. /// DataSet转Json字符串,主子结构
  259. /// 需要建立主子表关系,第一张表为主表
  260. /// 会排除关联列
  261. /// </summary>
  262. /// <param name="dataSet"></param>
  263. /// <param name="RelationName">关系名称</param>
  264. /// <returns></returns>
  265. public static string DataSetToJson(DataSet dataSet, string RelationName, string column)
  266. {
  267. DataRelation dataRelation = new DataRelation(RelationName, dataSet.Tables[0].Columns[column], dataSet.Tables[1].Columns[column], false);
  268. dataSet.Relations.Add(dataRelation);
  269. StringBuilder jsonString = new StringBuilder();
  270. //foreach (DataTable table in dataSet.Tables)
  271. //{
  272. DataTable table = dataSet.Tables[0];
  273. jsonString.Append("[");
  274. DataRowCollection drc = table.Rows;
  275. for (int i = 0; i < drc.Count; i++)
  276. {
  277. DataRow dataRow = drc[i];
  278. jsonString.Append("{");
  279. for (int j = 0; j < table.Columns.Count; j++)
  280. {
  281. string strKey = table.Columns[j].ColumnName;
  282. if (dataSet.Relations[RelationName].ParentColumns.Select(a => a.Caption).Contains(strKey))
  283. continue;
  284. string strValue = dataRow[j].ToString();
  285. Type type = table.Columns[j].DataType;
  286. jsonString.Append("\"" + strKey + "\":");
  287. strValue = StringFormat(strValue, type);
  288. if (j < table.Columns.Count - 1)
  289. {
  290. jsonString.Append(strValue + ",");
  291. }
  292. else
  293. {
  294. jsonString.Append(strValue);
  295. }
  296. }
  297. jsonString.Append(",\"" + RelationName + "\":");
  298. DataRow[] drs = dataRow.GetChildRows(RelationName);
  299. jsonString.Append("[");
  300. foreach (DataRow dr in drs)
  301. {
  302. DataTable dt = dr.Table;
  303. jsonString.Append("{");
  304. for (int j = 0; j < dt.Columns.Count; j++)
  305. {
  306. string strKey = dt.Columns[j].ColumnName;
  307. if (dataSet.Relations[RelationName].ChildColumns.Select(a => a.Caption).Contains(strKey))
  308. continue;
  309. string strValue = dr[j].ToString();
  310. Type type = dt.Columns[j].DataType;
  311. jsonString.Append("\"" + strKey + "\":");
  312. strValue = StringFormat(strValue, type);
  313. if (j < dt.Columns.Count - 1)
  314. {
  315. jsonString.Append(strValue + ",");
  316. }
  317. else
  318. {
  319. jsonString.Append(strValue);
  320. }
  321. }
  322. jsonString.Append("},");
  323. }
  324. if (drs.Length > 0)
  325. jsonString.Remove(jsonString.Length - 1, 1);
  326. jsonString.Append("]");
  327. jsonString.Append("},");
  328. }
  329. jsonString.Remove(jsonString.Length - 1, 1);
  330. jsonString.Append("]");
  331. //}
  332. string res = jsonString.ToString();
  333. return res;
  334. }
  335. /// <summary>
  336. /// 在事务中执行
  337. /// </summary>
  338. /// <param name="dbConn"></param>
  339. /// <param name="ExceptionAction"></param>
  340. public static void ExecuteWithTrans(Action<SqlConnection, SqlTransaction> dbConn, Action<Exception> ExceptionAction)
  341. {
  342. try
  343. {
  344. using (SqlConnection conn = SqlHelper.GetDataCenterConn())
  345. {
  346. SqlTransaction transaction = null;
  347. try
  348. {
  349. conn.Open();
  350. transaction = conn.BeginTransaction();
  351. dbConn?.Invoke(conn, transaction);
  352. transaction.Commit();
  353. }
  354. catch (Exception ex)
  355. {
  356. transaction?.Rollback();
  357. throw;
  358. }
  359. }
  360. }
  361. catch (Exception ex)
  362. {
  363. ExceptionAction?.Invoke(ex);
  364. }
  365. }
  366. public static int ExecuteNonQuery(SqlConnection conn, SqlTransaction transaction, string sql, params SqlParameter[] spArr)
  367. {
  368. SqlCommand cmd = new SqlCommand(sql, conn).AddTimeout();
  369. cmd.Transaction = transaction;
  370. if (spArr.Length > 0)
  371. cmd.Parameters.AddRange(spArr.SetDBNull());
  372. return cmd.ExecuteNonQuery();
  373. }
  374. public static SqlDataReader ExecuteReader(SqlConnection conn, SqlTransaction transaction, CommandType cmdType, string cmdText, params SqlParameter[] commandParameters)
  375. {
  376. SqlCommand cmd = new SqlCommand(cmdText, conn).AddTimeout();
  377. cmd.Transaction = transaction;
  378. // we use a try/catch here because if the method throws an exception we want to
  379. // close the connection throw code, because no datareader will exist, hence the
  380. // commandBehaviour.CloseConnection will not work
  381. try
  382. {
  383. PrepareCommand(cmd, conn, null, cmdType, cmdText, commandParameters);
  384. SqlDataReader rdr = cmd.ExecuteReader(CommandBehavior.CloseConnection);
  385. cmd.Parameters.Clear();
  386. return rdr;
  387. }
  388. catch
  389. {
  390. conn.Close();
  391. throw;
  392. }
  393. }
  394. /// <summary>
  395. /// 为即将执行准备一个命令
  396. /// </summary>
  397. /// <param name="cmd">SqlCommand对象</param>
  398. /// <param name="conn">SqlConnection对象</param>
  399. /// <param name="isOpenTrans">DbTransaction对象</param>
  400. /// <param name="cmdType">执行命令的类型(存储过程或T-SQL,等等)</param>
  401. /// <param name="cmdText">存储过程名称或者T-SQL命令行, e.g. Select * from Products</param>
  402. /// <param name="cmdParms">SqlParameters to use in the command</param>
  403. private static void PrepareCommand(SqlCommand cmd, SqlConnection conn, SqlTransaction transaction, CommandType cmdType, string cmdText, DbParameter[] cmdParms)
  404. {
  405. if (conn.State != ConnectionState.Open)
  406. conn.Open();
  407. cmd.Connection = conn;
  408. cmd.CommandText = cmdText;
  409. if (transaction != null)
  410. cmd.Transaction = transaction;
  411. cmd.CommandType = cmdType;
  412. if (cmdParms != null)
  413. {
  414. cmd.Parameters.AddRange(cmdParms);
  415. }
  416. }
  417. /// <summary>
  418. /// 过滤特殊字符
  419. /// </summary>
  420. /// <param name="s">字符串</param>
  421. /// <returns>json字符串</returns>
  422. private static string String2Json(String s)
  423. {
  424. StringBuilder sb = new StringBuilder();
  425. for (int i = 0; i < s.Length; i++)
  426. {
  427. char c = s.ToCharArray()[i];
  428. switch (c)
  429. {
  430. case '\"':
  431. sb.Append("\\\""); break;
  432. case '\\':
  433. sb.Append("\\\\"); break;
  434. case '/':
  435. sb.Append("\\/"); break;
  436. case '\b':
  437. sb.Append("\\b"); break;
  438. case '\f':
  439. sb.Append("\\f"); break;
  440. case '\n':
  441. sb.Append("\\n"); break;
  442. case '\r':
  443. sb.Append("\\r"); break;
  444. case '\t':
  445. sb.Append("\\t"); break;
  446. default:
  447. sb.Append(c); break;
  448. }
  449. }
  450. return sb.ToString();
  451. }
  452. /// <summary>
  453. /// 格式化字符型、日期型、布尔型
  454. /// </summary>
  455. /// <param name="str"></param>
  456. /// <param name="type"></param>
  457. /// <returns></returns>
  458. private static string StringFormat(string str, Type type)
  459. {
  460. if (type == typeof(string))
  461. {
  462. str = String2Json(str);
  463. str = "\"" + str + "\"";
  464. }
  465. else if (type == typeof(DateTime))
  466. {
  467. str = "\"" + str + "\"";
  468. }
  469. else if (type == typeof(bool))
  470. {
  471. str = str.ToLower();
  472. }
  473. else if (type != typeof(string) && string.IsNullOrEmpty(str))
  474. {
  475. str = "\"" + str + "\"";
  476. }
  477. return str;
  478. }
  479. #region [ ExecuteNonQuery ]
  480. /// <summary>
  481. /// 根据sql语句和参数,返回受影响行数
  482. /// </summary>
  483. /// <param name="sql">sql语句</param>
  484. /// <param name="spArr">可变参数</param>
  485. /// <returns>受影响行数</returns>
  486. public static int ExecuteNonQuery(string sql, params SqlParameter[] spArr)
  487. {
  488. using (SqlConnection conn = SqlHelper.GetDataCenterConn())
  489. {
  490. conn.Open();
  491. SqlCommand cmd = new SqlCommand(sql, conn).AddTimeout();
  492. if (spArr.Length > 0)
  493. cmd.Parameters.AddRange(spArr.SetDBNull());
  494. return cmd.ExecuteNonQuery();
  495. }
  496. }
  497. public static DataTable CmdExecuteDataTable(string sql)
  498. {
  499. try
  500. {
  501. string connString = SqlHelper.DataCenterConnString;
  502. SqlConnection conn = new System.Data.SqlClient.SqlConnection(connString);
  503. conn.Open();
  504. SqlTransaction sqlTran = conn.BeginTransaction();
  505. SqlCommand cmd = new SqlCommand();
  506. cmd.Transaction = sqlTran;
  507. cmd.Connection = conn;
  508. try
  509. {
  510. DataTable dt = SqlCommandHelper.SQlReturnData(sql, cmd);
  511. cmd.Transaction.Commit();
  512. return dt;
  513. }
  514. catch (Exception ex)
  515. {
  516. cmd.Transaction.Rollback();
  517. throw new Exception(ex.Message);
  518. }
  519. finally
  520. {
  521. if (conn.State == ConnectionState.Open)
  522. {
  523. conn.Close();
  524. }
  525. conn.Dispose();
  526. }
  527. }
  528. catch (Exception ex)
  529. {
  530. throw new Exception(ex.Message);
  531. }
  532. }
  533. public static DataTable CmdExecuteDataTable(SqlConnection conn, SqlTransaction transaction, string sql, params SqlParameter[] spArr)
  534. {
  535. SqlCommand cmd = new SqlCommand(sql, conn).AddTimeout();
  536. cmd.Transaction = transaction;
  537. if (spArr.Length > 0)
  538. cmd.Parameters.AddRange(spArr.SetDBNull());
  539. return cmd.ExecuteDataTable();
  540. }
  541. #region [ ExecuteScalar ]
  542. /// <summary>
  543. /// 根据sql语句和参数,返回Scalar结果
  544. /// </summary>
  545. /// <param name="sql">sql语句</param>
  546. /// <param name="spArr">可变参数</param>
  547. /// <returns>object</returns>
  548. public static object ExecuteScalar(SqlConnection conn, SqlTransaction transaction, string sql, params SqlParameter[] spArr)
  549. {
  550. SqlCommand cmd = new SqlCommand(sql, conn).AddTimeout();
  551. cmd.Transaction = transaction;
  552. if (spArr.Length > 0)
  553. cmd.Parameters.AddRange(spArr.SetDBNull());
  554. object obj = cmd.ExecuteScalar();
  555. return obj;
  556. }
  557. #endregion
  558. //多语句一起事务中执行(Li编写)
  559. public static int CmdExecuteNonQueryLi(string sql, params SqlParameter[] spArr)
  560. {
  561. using (SqlConnection conn = SqlHelper.GetDataCenterConn())
  562. {
  563. conn.Open();
  564. SqlTransaction sqlTran = conn.BeginTransaction();
  565. SqlCommand cmd = new SqlCommand();
  566. cmd.Transaction = sqlTran;
  567. cmd.Connection = conn;
  568. try
  569. {
  570. cmd.CommandText = sql;
  571. int RES = cmd.ExecuteNonQuery();
  572. cmd.Transaction.Commit();
  573. return RES;
  574. }
  575. catch (Exception ex)
  576. {
  577. cmd.Transaction.Rollback();
  578. throw new Exception(ex.Message);
  579. }
  580. finally
  581. {
  582. if (conn.State != ConnectionState.Closed)
  583. {
  584. conn.Close();
  585. conn.Dispose();
  586. }
  587. }
  588. return 0;
  589. }
  590. }
  591. public static int CmdExecuteNonQuery(string sql, params SqlParameter[] spArr)
  592. {
  593. using (SqlConnection conn = SqlHelper.GetDataCenterConn())
  594. {
  595. conn.Open();
  596. SqlCommand cmd = new SqlCommand(sql, conn).AddTimeout();
  597. SqlTransaction tx = conn.BeginTransaction();
  598. cmd.Transaction = tx;
  599. try
  600. {
  601. int RES = cmd.ExecuteNonQuery();
  602. tx.Commit();
  603. return RES;
  604. }
  605. catch (System.Data.SqlClient.SqlException E)
  606. {
  607. tx.Rollback();
  608. throw new Exception(E.Message);
  609. }
  610. finally
  611. {
  612. if (conn.State != ConnectionState.Closed)
  613. {
  614. conn.Close();
  615. conn.Dispose();
  616. }
  617. }
  618. return 0;
  619. }
  620. }
  621. public static int ExecuteNonQuery(string connStr, string sql, params SqlParameter[] spArr)
  622. {
  623. using (SqlConnection conn = new SqlConnection(connStr))
  624. {
  625. conn.Open();
  626. SqlCommand cmd = new SqlCommand(sql, conn).AddTimeout();
  627. if (spArr.Length > 0)
  628. cmd.Parameters.AddRange(spArr.SetDBNull());
  629. return cmd.ExecuteNonQuery();
  630. }
  631. }
  632. #endregion
  633. //有header头使用
  634. public static String httpGetByHeader(string url, string HeaderName, string HeaderValue)
  635. {
  636. HttpWebRequest request = (HttpWebRequest)WebRequest.Create(url);
  637. WebHeaderCollection headers = new WebHeaderCollection();
  638. headers.Add(HeaderName, HeaderValue);
  639. //headers.Add("Timespan", headerValue[1]);
  640. request.UserAgent = null;
  641. request.Headers = headers;
  642. request.Method = "GET";
  643. HttpWebResponse response = (HttpWebResponse)request.GetResponse();
  644. var httpStatusCode = (int)response.StatusCode;
  645. Console.WriteLine("返回码为 {0}", httpStatusCode);
  646. if (httpStatusCode == 200)
  647. {
  648. Stream myResponseStream = response.GetResponseStream();
  649. StreamReader myStreamReader = new StreamReader(myResponseStream, Encoding.GetEncoding("utf-8"));
  650. string retString = myStreamReader.ReadToEnd();
  651. myStreamReader.Close();
  652. myResponseStream.Close();
  653. return retString;
  654. }
  655. else
  656. {
  657. Console.WriteLine("未返回数据 {0}", httpStatusCode);
  658. throw new Exception("no data response");
  659. }
  660. }
  661. #region [ ExecuteScalar_ForProc ]
  662. /// <summary>
  663. /// 根据存储过程和参数,返回Scalar结果
  664. /// </summary>
  665. /// <param name="proc">存储过程</param>
  666. /// <param name="spArr">可变参数</param>
  667. /// <returns>object</returns>
  668. public static object ExecuteScalar_ForProc(string proc, params SqlParameter[] spArr)
  669. {
  670. using (SqlConnection conn = SqlHelper.GetDataCenterConn())
  671. {
  672. conn.Open();
  673. SqlCommand cmd = new SqlCommand(proc, conn).AddTimeout();
  674. cmd.CommandType = CommandType.StoredProcedure;
  675. if (spArr.Length > 0)
  676. cmd.Parameters.AddRange(spArr.SetDBNull());
  677. object obj = cmd.ExecuteScalar();
  678. return obj;
  679. }
  680. }
  681. /// <summary>
  682. /// 根据存储过程和参数,返回Scalar结果,但不加上超时设置 ( 避免循环做 AddTimeout )
  683. /// </summary>
  684. /// <param name="proc">存储过程</param>
  685. /// <param name="spArr">可变参数</param>
  686. /// <returns>object</returns>
  687. public static object ExecuteScalar_ForProc_WithoutAddTimeout(string proc, params SqlParameter[] spArr)
  688. {
  689. using (SqlConnection conn = SqlHelper.GetDataCenterConn())
  690. {
  691. conn.Open();
  692. SqlCommand cmd = new SqlCommand(proc, conn);
  693. cmd.CommandType = CommandType.StoredProcedure;
  694. if (spArr.Length > 0)
  695. cmd.Parameters.AddRange(spArr.SetDBNull());
  696. object obj = cmd.ExecuteScalar();
  697. return obj;
  698. }
  699. }
  700. #endregion
  701. #region [ ExecuteScalar ]
  702. /// <summary>
  703. /// 根据sql语句和参数,返回Scalar结果
  704. /// </summary>
  705. /// <param name="sql">sql语句</param>
  706. /// <param name="spArr">可变参数</param>
  707. /// <returns>object</returns>
  708. public static object ExecuteScalar(string sql, params SqlParameter[] spArr)
  709. {
  710. using (SqlConnection conn = SqlHelper.GetDataCenterConn())
  711. {
  712. conn.Open();
  713. SqlCommand cmd = new SqlCommand(sql, conn).AddTimeout();
  714. if (spArr.Length > 0)
  715. cmd.Parameters.AddRange(spArr.SetDBNull());
  716. object obj = cmd.ExecuteScalar();
  717. return obj;
  718. }
  719. }
  720. #endregion
  721. #region [ QueryByProc ]
  722. /// <summary>
  723. /// 根据存储过程及参数,返回DataSet
  724. /// </summary>
  725. /// <returns>DataSet</returns>
  726. public static DataSet GetDataSetByProc(string proc, params SqlParameter[] spArr)
  727. {
  728. using (SqlConnection conn = SqlHelper.GetDataCenterConn())
  729. {
  730. conn.Open();
  731. SqlCommand cmd = new SqlCommand(proc, conn).AddTimeout();
  732. cmd.CommandType = CommandType.StoredProcedure;
  733. if (spArr.Length > 0)
  734. cmd.Parameters.AddRange(spArr.SetDBNull());
  735. SqlDataAdapter adapter = new SqlDataAdapter(cmd);
  736. DataSet ds = new DataSet();
  737. adapter.Fill(ds);
  738. return ds;
  739. }
  740. }
  741. /// <summary>
  742. /// 根据存储过程及参数,返回DataTable
  743. /// </summary>
  744. /// <returns>DataTable</returns>
  745. public static DataTable GetDataTableByProc(string proc, params SqlParameter[] spArr)
  746. {
  747. using (SqlConnection conn = SqlHelper.GetDataCenterConn())
  748. {
  749. conn.Open();
  750. SqlCommand cmd = new SqlCommand(proc, conn).AddTimeout();
  751. cmd.CommandType = CommandType.StoredProcedure;
  752. if (spArr.Length > 0)
  753. cmd.Parameters.AddRange(spArr.SetDBNull());
  754. DataTable dt = cmd.ExecuteDataTable();
  755. return dt;
  756. }
  757. }
  758. /// <summary>
  759. /// 根据sql语句和参数,返回DataRow
  760. /// </summary>
  761. /// <param name="sql">sql语句</param>
  762. /// <param name="spArr">可变参数</param>
  763. /// <returns>DataRow</returns>
  764. public static DataRow GetDataRowByProc(string proc, params SqlParameter[] spArr)
  765. {
  766. DataTable dt = GetDataTableByProc(proc, spArr);
  767. if (dt == null || dt.Rows.Count == 0)
  768. return null;
  769. return dt.Rows[0];
  770. }
  771. #endregion
  772. #region [ Query ]
  773. /// <summary>
  774. /// 根据sql语句和参数,返回DataSet
  775. /// </summary>
  776. /// <param name="conn"></param>
  777. /// <param name="transaction"></param>
  778. /// <param name="sql"></param>
  779. /// <param name="spArr"></param>
  780. /// <returns></returns>
  781. public static DataSet GetDataSetBySql(SqlConnection conn, SqlTransaction transaction, string sql, params SqlParameter[] spArr)
  782. {
  783. SqlCommand cmd = new SqlCommand(sql, conn).AddTimeout();
  784. if (spArr.Length > 0)
  785. cmd.Parameters.AddRange(spArr.SetDBNull());
  786. cmd.Transaction = transaction;
  787. SqlDataAdapter adapter = new SqlDataAdapter(cmd);
  788. DataSet ds = new DataSet();
  789. adapter.Fill(ds);
  790. return ds;
  791. }
  792. //多语句一起事务中执行(Li编写)
  793. public static int CmdExecuteNonQueryLi(SqlConnection conn, SqlTransaction transaction, string sql, params SqlParameter[] spArr)
  794. {
  795. SqlCommand cmd = new SqlCommand(sql, conn).AddTimeout();
  796. cmd.Transaction = transaction;
  797. cmd.Connection = conn;
  798. try
  799. {
  800. cmd.CommandText = sql;
  801. int RES = cmd.ExecuteNonQuery();
  802. cmd.Transaction.Commit();
  803. return RES;
  804. }
  805. catch (Exception ex)
  806. {
  807. cmd.Transaction.Rollback();
  808. throw new Exception(ex.Message);
  809. }
  810. finally
  811. {
  812. if (conn.State != ConnectionState.Closed)
  813. {
  814. conn.Close();
  815. conn.Dispose();
  816. }
  817. }
  818. return 0;
  819. }
  820. /// <summary>
  821. /// 根据sql语句和参数,返回DataRow
  822. /// </summary>
  823. /// <param name="sql">sql语句</param>
  824. /// <param name="spArr">可变参数</param>
  825. /// <returns>DataRow</returns>
  826. public static DataRow GetDataRowBySql(SqlConnection conn, SqlTransaction transaction, string sql, params SqlParameter[] spArr)
  827. {
  828. DataTable dt = GetDataTableBySql(conn, transaction,sql, spArr);
  829. if (dt == null || dt.Rows.Count == 0)
  830. return null;
  831. return dt.Rows[0];
  832. }
  833. /// <summary>
  834. /// 根据sql语句和参数,返回DataTable
  835. /// </summary>
  836. /// <param name="sql">sql语句</param>
  837. /// <param name="spArr">可变参数</param>
  838. /// <returns>DataTable</returns>
  839. public static DataTable GetDataTableBySql(SqlConnection conn, SqlTransaction transaction, string sql, params SqlParameter[] spArr)
  840. {
  841. SqlCommand cmd = new SqlCommand(sql, conn).AddTimeout();
  842. if (spArr.Length > 0)
  843. cmd.Parameters.AddRange(spArr.SetDBNull());
  844. cmd.Transaction = transaction;
  845. DataTable dt = cmd.ExecuteDataTable();
  846. return dt;
  847. }
  848. /// <summary>
  849. /// 根据sql语句和参数,返回DataSet
  850. /// </summary>
  851. /// <param name="sql">sql语句</param>
  852. /// <param name="spArr">可变参数</param>
  853. /// <returns>DataSet</returns>
  854. public static DataSet GetDataSetBySql(string sql, params SqlParameter[] spArr)
  855. {
  856. using (SqlConnection conn = SqlHelper.GetDataCenterConn())
  857. {
  858. conn.Open();
  859. SqlCommand cmd = new SqlCommand(sql, conn).AddTimeout();
  860. if (spArr.Length > 0)
  861. cmd.Parameters.AddRange(spArr.SetDBNull());
  862. SqlDataAdapter adapter = new SqlDataAdapter(cmd);
  863. DataSet ds = new DataSet();
  864. adapter.Fill(ds);
  865. return ds;
  866. }
  867. }
  868. /// <summary>
  869. /// 根据sql语句和参数,返回DataTable
  870. /// </summary>
  871. /// <param name="sql">sql语句</param>
  872. /// <param name="spArr">可变参数</param>
  873. /// <returns>DataTable</returns>
  874. public static DataTable GetDataTableBySql(string sql, params SqlParameter[] spArr)
  875. {
  876. using (SqlConnection conn = SqlHelper.GetDataCenterConn())
  877. {
  878. conn.Open();
  879. SqlCommand cmd = new SqlCommand(sql, conn).AddTimeout();
  880. if (spArr.Length > 0)
  881. cmd.Parameters.AddRange(spArr.SetDBNull());
  882. DataTable dt = cmd.ExecuteDataTable();
  883. return dt;
  884. }
  885. }
  886. public static DataTable GetDataTableBySqlDH(string sql, params SqlParameter[] spArr)
  887. {
  888. using (SqlConnection conn = SqlHelper.GetDataCenterConn())
  889. {
  890. conn.Open();
  891. SqlCommand cmd = new SqlCommand(sql, conn).AddTimeout();
  892. cmd.CommandTimeout= 180;
  893. if (spArr.Length > 0)
  894. cmd.Parameters.AddRange(spArr.SetDBNull());
  895. DataTable dt = cmd.ExecuteDataTable();
  896. return dt;
  897. }
  898. }
  899. /// <summary>
  900. /// 根据sql语句和参数,返回DataRow
  901. /// </summary>
  902. /// <param name="sql">sql语句</param>
  903. /// <param name="spArr">可变参数</param>
  904. /// <returns>DataRow</returns>
  905. public static DataRow GetDataRowBySql(string sql, params SqlParameter[] spArr)
  906. {
  907. DataTable dt = GetDataTableBySql(sql, spArr);
  908. if (dt == null || dt.Rows.Count == 0)
  909. return null;
  910. return dt.Rows[0];
  911. }
  912. /// <summary>
  913. /// 根据sql语句和参数,返回DataSet
  914. /// </summary>
  915. /// <param name="sql">sql语句</param>
  916. /// <param name="ConnectStr">数据库链接名称</param>
  917. /// <param name="spArr">可变参数</param>
  918. /// <returns>DataSet</returns>
  919. public static DataSet GetDataSetBySql_OtherConn(string sql, string ConnectStr, params SqlParameter[] spArr)
  920. {
  921. using (SqlConnection conn = SqlHelper.GetConnByStr(ConnectStr))
  922. {
  923. conn.Open();
  924. SqlCommand cmd = new SqlCommand(sql, conn).AddTimeout();
  925. if (spArr.Length > 0)
  926. cmd.Parameters.AddRange(spArr.SetDBNull());
  927. SqlDataAdapter adapter = new SqlDataAdapter(cmd);
  928. DataSet ds = new DataSet();
  929. adapter.Fill(ds);
  930. return ds;
  931. }
  932. }
  933. /// <summary>
  934. /// 根据sql语句和参数,返回DataTable
  935. /// </summary>
  936. /// <param name="sql">sql语句</param>
  937. /// <param name="ConnectStr">数据库链接名称</param>
  938. /// <param name="spArr">可变参数</param>
  939. /// <returns>DataTable</returns>
  940. public static DataTable GetDataTableBySql_OtherConn(string sql, string ConnectStr, params SqlParameter[] spArr)
  941. {
  942. using (SqlConnection conn = SqlHelper.GetConnByStr(ConnectStr))
  943. {
  944. conn.Open();
  945. SqlCommand cmd = new SqlCommand(sql, conn).AddTimeout();
  946. if (spArr != null && spArr.Length > 0)
  947. cmd.Parameters.AddRange(spArr.SetDBNull());
  948. DataTable dt = cmd.ExecuteDataTable();
  949. return dt;
  950. }
  951. }
  952. /// <summary>
  953. /// 根据sql语句和参数,返回DataTable 分页显示
  954. /// </summary>
  955. /// <param name="sql">sql语句</param>
  956. /// <param name="ConnectStr">数据库链接名称</param>
  957. /// <param name="spArr">可变参数</param>
  958. /// <returns>DataTable</returns>
  959. public static DataTable GetDataTableBySql_OtherConn(string sql, string ConnectStr, ref Pagination jqgridparam, params SqlParameter[] spArr)
  960. {
  961. using (SqlConnection conn = SqlHelper.GetConnByStr(ConnectStr))
  962. {
  963. string orderField = jqgridparam.sidx;
  964. string orderType = jqgridparam.sord;
  965. int pageIndex = jqgridparam.page;
  966. int pageSize = jqgridparam.rows;
  967. int totalRow = 0;
  968. string OrderBy = "";
  969. if (pageIndex == 0)
  970. {
  971. pageIndex = 1;
  972. }
  973. int num = (pageIndex - 1) * pageSize;
  974. int num1 = (pageIndex) * pageSize;
  975. if (!string.IsNullOrEmpty(orderField))
  976. OrderBy = orderField + " " + orderType + "";
  977. conn.Open();
  978. SqlCommand cmd = new SqlCommand(sql, conn).AddTimeout();
  979. if (spArr != null && spArr.Length > 0)
  980. cmd.Parameters.AddRange(spArr.SetDBNull());
  981. DataTable dt = cmd.ExecuteDataTable();
  982. DataTable dtNew = dt.Clone();
  983. if (dt != null && dt.Rows.Count > 0)
  984. {
  985. jqgridparam.records = dt.Rows.Count;
  986. DataView dv = dt.DefaultView;
  987. dv.Sort = OrderBy;
  988. dt = dv.ToTable();
  989. if (dt.Rows.Count >= num)
  990. {
  991. for (int i = num; i < num1 && i < dt.Rows.Count; i++)
  992. {
  993. dtNew.ImportRow(dt.Rows[i]);
  994. }
  995. }
  996. }
  997. return dtNew;
  998. }
  999. }
  1000. /// <summary>
  1001. /// 根据sql语句和参数,返回DataRow
  1002. /// </summary>
  1003. /// <param name="sql">sql语句</param>
  1004. /// <param name="ConnectStr">数据库链接名称</param>
  1005. /// <param name="spArr">可变参数</param>
  1006. /// <returns>DataRow</returns>
  1007. public static DataRow GetDataRowBySql_OtherConn(string sql, string ConnectStr, params SqlParameter[] spArr)
  1008. {
  1009. DataTable dt = GetDataTableBySql_OtherConn(sql, ConnectStr, spArr);
  1010. if (dt == null || dt.Rows.Count == 0)
  1011. return null;
  1012. return dt.Rows[0];
  1013. }
  1014. #endregion
  1015. #region [ GetValue ]
  1016. public static object GetValue(DataRow dr, string fieldName, object replaceValue)
  1017. {
  1018. if (dr.IsNull(fieldName))
  1019. return replaceValue;
  1020. return dr[fieldName];
  1021. }
  1022. public static object GetValue(DataRow dr, int idx, object replaceValue)
  1023. {
  1024. if (dr.IsNull(idx))
  1025. return replaceValue;
  1026. return dr[idx];
  1027. }
  1028. #endregion
  1029. #region [ GetString ]
  1030. public static string GetString(DataRow dr, string fieldName, string replaceValue)
  1031. {
  1032. if (dr.IsNull(fieldName))
  1033. return replaceValue;
  1034. return Convert.ToString(dr[fieldName]);
  1035. }
  1036. public static string GetString(DataRow dr, int idx, string replaceValue)
  1037. {
  1038. if (dr.IsNull(idx))
  1039. return replaceValue;
  1040. return Convert.ToString(dr[idx]);
  1041. }
  1042. #endregion
  1043. #region [ GetDateTime ]
  1044. public static DateTime GetDateTime(DataRow dr, string fieldName, DateTime replaceValue)
  1045. {
  1046. if (dr.IsNull(fieldName))
  1047. return replaceValue;
  1048. return Convert.ToDateTime(dr[fieldName]);
  1049. }
  1050. public static DateTime GetDateTime(DataRow dr, int idx, DateTime replaceValue)
  1051. {
  1052. if (dr.IsNull(idx))
  1053. return replaceValue;
  1054. return Convert.ToDateTime(dr[idx]);
  1055. }
  1056. #endregion
  1057. #region [ 非数据中心库操作 ]
  1058. #region [ ExecuteScalar ]
  1059. /// <summary>
  1060. /// 根据sql语句和参数,返回Scalar结果
  1061. /// </summary>
  1062. /// <param name="connString">连接串</param>
  1063. /// <param name="sql">sql语句</param>
  1064. /// <param name="spArr">可变参数</param>
  1065. /// <returns>object</returns>
  1066. public static object ExecuteScalarWithConn(string connString, string sql, params SqlParameter[] spArr)
  1067. {
  1068. using (SqlConnection conn = SqlHelper.GetConnByString(connString))
  1069. {
  1070. conn.Open();
  1071. SqlCommand cmd = new SqlCommand(sql, conn).AddTimeout();
  1072. if (spArr.Length > 0)
  1073. cmd.Parameters.AddRange(spArr.SetDBNull());
  1074. object obj = cmd.ExecuteScalar();
  1075. return obj;
  1076. }
  1077. }
  1078. #endregion
  1079. #region [ ExecuteNonQuery ]
  1080. /// <summary>
  1081. /// 根据sql语句和参数,返回受影响行数
  1082. /// </summary>
  1083. /// <param name="connString">连接串</param>
  1084. /// <param name="sql">sql语句</param>
  1085. /// <param name="spArr">可变参数</param>
  1086. /// <returns>受影响行数</returns>
  1087. public static int ExecuteNonQueryWithConn(string connString, string sql, params SqlParameter[] spArr)
  1088. {
  1089. using (SqlConnection conn = SqlHelper.GetConnByString(connString))
  1090. {
  1091. conn.Open();
  1092. SqlCommand cmd = new SqlCommand(sql, conn).AddTimeout();
  1093. if (spArr.Length > 0)
  1094. cmd.Parameters.AddRange(spArr.SetDBNull());
  1095. return cmd.ExecuteNonQuery();
  1096. }
  1097. }
  1098. #endregion
  1099. #region [ Query ]
  1100. /// <summary>
  1101. /// 根据sql语句和参数,返回DataTable
  1102. /// </summary>
  1103. /// <param name="connString">连接串</param>
  1104. /// <param name="sql">sql语句</param>
  1105. /// <param name="spArr">可变参数</param>
  1106. /// <returns>DataTable</returns>
  1107. public static DataTable GetDataTableBySqlWithConn(string connString, string sql, params SqlParameter[] spArr)
  1108. {
  1109. using (SqlConnection conn = SqlHelper.GetConnByString(connString))
  1110. {
  1111. conn.Open();
  1112. SqlCommand cmd = new SqlCommand(sql, conn).AddTimeout();
  1113. if (spArr.Length > 0)
  1114. cmd.Parameters.AddRange(spArr.SetDBNull());
  1115. DataTable dt = cmd.ExecuteDataTable();
  1116. return dt;
  1117. }
  1118. }
  1119. /// <summary>
  1120. /// 根据sql语句和参数,返回DataRow
  1121. /// </summary>
  1122. /// <param name="connString">连接串</param>
  1123. /// <param name="sql">sql语句</param>
  1124. /// <param name="spArr">可变参数</param>
  1125. /// <returns>DataRow</returns>
  1126. public static DataRow GetDataRowBySqlWithConn(string connString, string sql, params SqlParameter[] spArr)
  1127. {
  1128. DataTable dt = GetDataTableBySqlWithConn(connString, sql, spArr);
  1129. if (dt == null || dt.Rows.Count == 0)
  1130. return null;
  1131. return dt.Rows[0];
  1132. }
  1133. #endregion
  1134. #endregion
  1135. #region [ 根据SQL文件路径执行 ]
  1136. /// <summary>
  1137. /// 执行SQL文件
  1138. /// </summary>
  1139. /// <param name="connString"></param>
  1140. /// <param name="filePath"></param>
  1141. /// <returns></returns>
  1142. public static bool ExecuteNonQueryWithConnAndSqlFilePath(string connString, string filePath)
  1143. {
  1144. string sql = System.IO.File.ReadAllText(filePath);
  1145. return ExecuteNonQueryWithConnAndGO(connString, sql);
  1146. }
  1147. #endregion
  1148. #region [ 执行带Go语句 ]
  1149. /// <summary>
  1150. /// 执行带"GO"的SQL,返回最后一条SQL的受影响行数
  1151. /// </summary>
  1152. /// <param name="connString">连接串</param>
  1153. /// <param name="sql">sql语句</param>
  1154. /// <returns>返回最后一条SQL的受影响行数</returns>
  1155. public static bool ExecuteNonQueryWithConnAndGO(string connString, string sql)
  1156. {
  1157. bool result = true;
  1158. string[] arr = System.Text.RegularExpressions.Regex.Split(sql, @"\bGO\b", System.Text.RegularExpressions.RegexOptions.IgnoreCase);
  1159. using (SqlConnection conn = GetConnByString(connString))
  1160. {
  1161. conn.Open();
  1162. SqlCommand cmd = new SqlCommand().AddTimeout();
  1163. cmd.Connection = conn;
  1164. SqlTransaction tx = conn.BeginTransaction();
  1165. cmd.Transaction = tx;
  1166. try
  1167. {
  1168. for (int n = 0; n < arr.Length; n++)
  1169. {
  1170. string strsql = arr[n];
  1171. if (strsql.Trim().Length > 1 && strsql.Trim().Replace(";", "") != "")
  1172. {
  1173. cmd.CommandText = strsql;
  1174. cmd.ExecuteNonQuery();
  1175. }
  1176. }
  1177. tx.Commit();
  1178. }
  1179. catch (System.Data.SqlClient.SqlException E)
  1180. {
  1181. tx.Rollback();
  1182. result = false;
  1183. //return -1;
  1184. throw new Exception(E.Message);
  1185. }
  1186. finally
  1187. {
  1188. if (conn.State != ConnectionState.Closed)
  1189. {
  1190. conn.Close();
  1191. conn.Dispose();
  1192. }
  1193. }
  1194. }
  1195. return result;
  1196. }
  1197. #endregion
  1198. /// <summary>
  1199. /// 设置Sql参数
  1200. /// </summary>
  1201. /// <param name="parameterName"></param>
  1202. /// <param name="value"></param>
  1203. /// <param name="dbType"></param>
  1204. /// <returns></returns>
  1205. public static SqlParameter SetSqlParameter(string parameterName, object value, SqlDbType dbType)
  1206. {
  1207. if (value == null || string.IsNullOrEmpty(value.ToString()))
  1208. {
  1209. return new SqlParameter(parameterName, DBNull.Value);
  1210. }
  1211. SqlParameter sp = new SqlParameter(parameterName, value);
  1212. sp.SqlDbType = dbType;
  1213. return sp;
  1214. }
  1215. public static void RemoveEmpty(DataTable dt)
  1216. {
  1217. List<DataRow> removelist = new List<DataRow>();
  1218. for (int i = 0; i < dt.Rows.Count; i++)
  1219. {
  1220. bool IsNull = true;
  1221. for (int j = 0; j < dt.Columns.Count; j++)
  1222. {
  1223. if (!string.IsNullOrEmpty(dt.Rows[i][j].ToString().Trim()))
  1224. {
  1225. IsNull = false;
  1226. }
  1227. }
  1228. if (IsNull)
  1229. {
  1230. removelist.Add(dt.Rows[i]);
  1231. }
  1232. }
  1233. for (int i = 0; i < removelist.Count; i++)
  1234. {
  1235. dt.Rows.Remove(removelist[i]);
  1236. }
  1237. }
  1238. /// <summary>
  1239. /// 大数据插入
  1240. /// </summary>
  1241. /// <param name="connectionString">目标库连接</param>
  1242. /// <param name="TableName">目标表</param>
  1243. /// <param name="dtSelect">来源数据</param>
  1244. public static void SqlBulkCopyByDatatable(string TableName, DataTable dtSelect)
  1245. {
  1246. using (SqlConnection conn = new SqlConnection(DataCenterConnString))
  1247. {
  1248. using (SqlBulkCopy sqlbulkcopy = new SqlBulkCopy(DataCenterConnString, SqlBulkCopyOptions.UseInternalTransaction))
  1249. {
  1250. try
  1251. {
  1252. sqlbulkcopy.DestinationTableName = TableName;
  1253. sqlbulkcopy.BatchSize = 20000;
  1254. sqlbulkcopy.BulkCopyTimeout = 0;//不限时间
  1255. for (int i = 0; i < dtSelect.Columns.Count; i++)
  1256. {
  1257. sqlbulkcopy.ColumnMappings.Add(dtSelect.Columns[i].ColumnName, dtSelect.Columns[i].ColumnName);
  1258. }
  1259. sqlbulkcopy.WriteToServer(dtSelect);
  1260. }
  1261. catch (System.Exception ex)
  1262. {
  1263. throw ex;
  1264. }
  1265. }
  1266. }
  1267. }
  1268. /// <summary>
  1269. /// 根据sql及带 in 的id参数列表, 得到DataTable
  1270. /// </summary>
  1271. /// <param name="sql">带in ( {0} )的sql</param>
  1272. /// <param name="ids">以逗号分隔的id字符串</param>
  1273. /// <param name="idDbType">id的Sql数据类型</param>
  1274. /// <returns>DataTable</returns>
  1275. public static DataTable GetDataTableWithIn(string sql, string ids, SqlDbType idDbType)
  1276. {
  1277. SqlParameter[] spArr = GetWithInSqlParameters(ref sql, ids, idDbType);
  1278. return GetDataTableBySql(sql, spArr);
  1279. }
  1280. /// <summary>
  1281. /// 根据sql及带 in 的id参数列表, 得到受影响行数
  1282. /// </summary>
  1283. /// <param name="sql">带in ( {0} )的sql</param>
  1284. /// <param name="ids">以逗号分隔的id字符串</param>
  1285. /// <param name="idDbType">id的Sql数据类型</param>
  1286. /// <returns>DataTable</returns>
  1287. public static int ExecuteNonQueryWithIn(string sql, string ids, SqlDbType idDbType)
  1288. {
  1289. SqlParameter[] spArr = GetWithInSqlParameters(ref sql, ids, idDbType);
  1290. return ExecuteNonQuery(sql, spArr);
  1291. }
  1292. #region [ 带 in 不确定参数的执行方法 ]
  1293. /// <summary>
  1294. /// 获取带 in 的sql参数列表
  1295. /// </summary>
  1296. /// <param name="sql">带in ( {0} )的sql</param>
  1297. /// <param name="ids">以逗号分隔的id字符串</param>
  1298. /// <param name="idDbType">id的Sql数据类型</param>
  1299. /// <returns>sql参数列表</returns>
  1300. public static SqlParameter[] GetWithInSqlParameters(ref string sql, string ids, SqlDbType idDbType)
  1301. {
  1302. if (string.IsNullOrEmpty(ids))
  1303. {
  1304. return null;
  1305. }
  1306. string[] idArr = ids.Split(',');
  1307. //组建sql在in中的字符串
  1308. StringBuilder sbCondition = new StringBuilder();
  1309. List<SqlParameter> spList = new List<SqlParameter>();
  1310. for (int i = 0; i < idArr.Length; i++)
  1311. {
  1312. string id = idArr[i];
  1313. string spName = string.Format("@id{0}", i);
  1314. sbCondition.AppendFormat("{0},", spName);
  1315. spList.Add(SetSqlParameter(spName, id, idDbType));
  1316. }
  1317. //重新构建sql
  1318. sql = string.Format(sql, sbCondition.ToString().TrimEnd(','));
  1319. return spList.ToArray();
  1320. }
  1321. #endregion
  1322. public static DataTable FindTablePageBySql_OtherTemp(string strSql, string TempName, string Droptable, DbParameter[] parameters, ref Pagination Pagination)
  1323. {
  1324. string orderField = Pagination.sidx;
  1325. string orderType = Pagination.sord;
  1326. int pageIndex = Pagination.page;
  1327. int pageSize = Pagination.rows;
  1328. int totalRow = Pagination.records;
  1329. DataTable dt = GetPageTable_EXISTSTemp(strSql, TempName, Droptable, parameters, orderField, orderType, pageIndex, pageSize, ref totalRow);
  1330. Pagination.records = totalRow;
  1331. return dt;
  1332. }
  1333. private static DataTable GetPageTable_EXISTSTemp(string sql, string sqlTempName, string Droptable, DbParameter[] param, string orderField, string orderType, int pageIndex, int pageSize, ref int count)
  1334. {
  1335. //StringBuilder strSql = new StringBuilder();
  1336. if (pageIndex == 0)
  1337. {
  1338. pageIndex = 1;
  1339. }
  1340. int num = (pageIndex - 1) * pageSize;
  1341. int num1 = (pageIndex) * pageSize;
  1342. string OrderBy = " ORDER BY NUM,GroupCode ASC ";
  1343. using (SqlConnection conn = SqlHelper.GetDataCenterConn())
  1344. {
  1345. conn.Open();
  1346. sql += " Select Count(1) From " + sqlTempName;
  1347. sql += " Select * From (Select ROW_NUMBER() Over (" + OrderBy + ") ";
  1348. sql += " As rowNum, * From " + sqlTempName + " ) As N Where rowNum > " + num + " And rowNum <= " + num1 + " ";
  1349. sql += Droptable;
  1350. SqlCommand cmd = new SqlCommand(sql, conn).AddTimeout();
  1351. SqlDataAdapter adapter = new SqlDataAdapter(cmd);
  1352. DataSet ds = new DataSet();
  1353. adapter.Fill(ds);
  1354. //string ss = ds.Tables[1].Rows[0][0].ToString();
  1355. if (ds.Tables[1].Rows.Count <= 0)
  1356. {
  1357. return null;
  1358. }
  1359. count = Convert.ToInt32(ds.Tables[1].Rows[0][0].ToString());
  1360. return ds.Tables[1];
  1361. }
  1362. }
  1363. public static DataTable FindTablePageBySql_OtherTempSORRFQ(string strSql, string TempName, string Droptable, DbParameter[] parameters, ref Pagination Pagination)
  1364. {
  1365. string orderField = Pagination.sidx;
  1366. string orderType = Pagination.sord;
  1367. int pageIndex = Pagination.page;
  1368. int pageSize = Pagination.rows;
  1369. int totalRow = Pagination.records;
  1370. DataTable dt = GetPageTable_EXISTSTempSORRFQ(strSql, TempName, Droptable, parameters, orderField, orderType, pageIndex, pageSize, ref totalRow);
  1371. Pagination.records = totalRow;
  1372. return dt;
  1373. }
  1374. private static DataTable GetPageTable_EXISTSTempSORRFQ(string sql, string sqlTempName, string Droptable, DbParameter[] param, string orderField, string orderType, int pageIndex, int pageSize, ref int count)
  1375. {
  1376. //StringBuilder strSql = new StringBuilder();
  1377. if (pageIndex == 0)
  1378. {
  1379. pageIndex = 1;
  1380. }
  1381. int num = (pageIndex - 1) * pageSize;
  1382. int num1 = (pageIndex) * pageSize;
  1383. string OrderBy = " order by ListCode desc ";
  1384. //if (!string.IsNullOrEmpty(orderField))
  1385. // OrderBy = "Order By " + orderField + " " + orderType + "";
  1386. //else
  1387. // OrderBy = "order by (select 0)";
  1388. //strSql.Append(sql+@" Select * From (Select ROW_NUMBER() Over (" + OrderBy + ")");
  1389. //strSql.Append(" As rowNum, * From " + sqlTempName + " ) As N Where rowNum > " + num + " And rowNum <= " + num1 + " " + Droptable);
  1390. //count = Convert.ToInt32(ExecuteScalar(CommandType.Text, sql + " Select Count(1) From " + sqlTempName +" "+ Droptable, param));
  1391. //IDataReader dr = ExecuteReader(CommandType.Text, strSql.ToString(), param);
  1392. //return DatabaseReader.ReaderToDataTable(dr);
  1393. using (SqlConnection conn = SqlHelper.GetDataCenterConn())
  1394. {
  1395. conn.Open();
  1396. sql += " Select Count(1) From " + sqlTempName;
  1397. sql += " Select * From (Select ROW_NUMBER() Over (" + OrderBy + ") ";
  1398. sql += " As rowNum, * From " + sqlTempName + " ) As N Where rowNum > " + num + " And rowNum <= " + num1 + " ";
  1399. sql += Droptable;
  1400. SqlCommand cmd = new SqlCommand(sql, conn).AddTimeout();
  1401. SqlDataAdapter adapter = new SqlDataAdapter(cmd);
  1402. DataSet ds = new DataSet();
  1403. adapter.Fill(ds);
  1404. //string ss = ds.Tables[1].Rows[0][0].ToString();
  1405. count = Convert.ToInt32(ds.Tables[1].Rows[0][0].ToString());
  1406. return ds.Tables[0];
  1407. }
  1408. }
  1409. public static DataTable FindTablePageBySql_OtherTempByRole(string strSql, string TempName, string ParentId,string UserCode, DbParameter[] parameters,string groupsql, ref Pagination Pagination)
  1410. {
  1411. string orderField = Pagination.sidx;
  1412. string orderType = Pagination.sord;
  1413. int pageIndex = Pagination.page;
  1414. int pageSize = Pagination.rows;
  1415. int totalRow = Pagination.records;
  1416. DataTable dt = GetPageTable_EXISTSTempByRole(strSql, TempName, ParentId, UserCode, parameters, orderField, orderType, groupsql, pageIndex, pageSize, ref totalRow);
  1417. Pagination.records = totalRow;
  1418. return dt;
  1419. }
  1420. private static DataTable GetPageTable_EXISTSTempByRole(string sql, string sqlTempName, string ParentId, string UserCode,DbParameter[] param, string orderField, string orderType, string groupsql, int pageIndex, int pageSize, ref int count)
  1421. {
  1422. if (pageIndex == 0)
  1423. {
  1424. pageIndex = 1;
  1425. }
  1426. int num = (pageIndex - 1) * pageSize;
  1427. int num1 = (pageIndex) * pageSize;
  1428. string OrderBy = " order by " + orderField + " " + orderType + " ";
  1429. using (SqlConnection conn = SqlHelper.GetDataCenterConn())
  1430. {
  1431. conn.Open();
  1432. sql = @" with
  1433. CTE
  1434. as
  1435. (
  1436. select * from Sys_SRM_Organize where F_Id='" + ParentId + @"'
  1437. union all
  1438. select G.* from CTE inner join Sys_SRM_Organize as G
  1439. on CTE.F_Id=G.F_ParentID
  1440. ) Select * From (Select ROW_NUMBER() Over (" + OrderBy + ") ";
  1441. sql += @" As rowNum, * From (" + sqlTempName + @" AND (CreatePerson=(select c.F_Account from Sys_SRM_Organize a
  1442. inner join Sys_SRM_Role b on b.F_OrganizeId=a.F_Id
  1443. inner join Sys_SRM_User c on c.F_RoleId=b.F_Id
  1444. where a.F_Id='"+ ParentId + @"' and F_Account='"+ UserCode + @"') OR CreatePerson IN
  1445. (select F_Account from CTE a
  1446. inner JOIN sys_SRM_Role b ON a.F_ID=b.F_OrganizeId
  1447. inner JOIN sys_srm_user c ON b.F_ID=c.F_RoleID
  1448. WHERE a.F_parentID='" + ParentId + @"'
  1449. ))"+ groupsql+") As T ) As N ";
  1450. SqlCommand cmd = new SqlCommand(sql, conn).AddTimeout();
  1451. SqlDataAdapter adapter = new SqlDataAdapter(cmd);
  1452. DataSet ds = new DataSet();
  1453. adapter.Fill(ds);
  1454. int ss = ds.Tables[0].Rows.Count;
  1455. count = ds.Tables[0].Rows.Count <= 0 ? 0 : ss;
  1456. return ds.Tables[0];
  1457. }
  1458. }
  1459. public static string GetItemsDetailEnabledMark(string F_EnCode)
  1460. {
  1461. string sql = @"select b.F_ItemCode as Code , b.F_ItemName as Name from Sys_SRM_Items a left join Sys_SRM_ItemsDetail b on a.F_Id= b.F_ItemId
  1462. where a.F_EnCode= '{0}'AND b.F_EnabledMark= '1' order by cast(b.F_SortCode as int) asc";
  1463. sql = string.Format(sql, F_EnCode);
  1464. DataTable dt = GetDataTableBySql(sql);
  1465. string Code = string.Empty;
  1466. if (dt.Rows.Count > 0)
  1467. {
  1468. Code = dt.Rows[0]["Code"].ToString();
  1469. }
  1470. else
  1471. {
  1472. Code = "";
  1473. }
  1474. return Code;
  1475. }
  1476. /// <summary>
  1477. /// 根据大类获取前缀
  1478. /// </summary>
  1479. /// <param name="ClassCode"></param>
  1480. /// <returns></returns>
  1481. public static string GetInventoryQZ(string ClassCode)
  1482. {
  1483. string QZ = string.Empty;
  1484. ClassCode = ClassCode.Substring(0, 2);
  1485. switch (ClassCode)
  1486. {
  1487. case "01":
  1488. QZ = "YL";
  1489. break;
  1490. case "02":
  1491. QZ = "CP";
  1492. break;
  1493. case "0A":
  1494. QZ = "CP";
  1495. break;
  1496. case "0B":
  1497. QZ = "CP";
  1498. break;
  1499. case "07":
  1500. QZ = "CP";
  1501. break;
  1502. case "08":
  1503. QZ = "CP";
  1504. break;
  1505. case "05":
  1506. QZ = "PSL";
  1507. break;
  1508. case "04":
  1509. QZ = "ZLL";
  1510. break;
  1511. case "03":
  1512. QZ = "BHM";
  1513. break;
  1514. }
  1515. return QZ;
  1516. }
  1517. /// <summary>
  1518. /// 根据年两位计算以此类推
  1519. /// </summary>
  1520. /// <returns></returns>
  1521. public static int GetYear()
  1522. {
  1523. int Year = 10;
  1524. string dt = DateTime.Now.ToString("yy");
  1525. if (dt == "23")
  1526. {
  1527. return Year;
  1528. }
  1529. else
  1530. {
  1531. int Num = Convert.ToInt32(dt) - 23;
  1532. Year = Year + Num;
  1533. }
  1534. return Year;
  1535. }
  1536. public static string GetLOTNumber(string ClassCode, string WorkPoint)
  1537. {
  1538. string LOTNO = string.Empty;
  1539. string QZLot = GetInventoryQZ(ClassCode);
  1540. string MothLot = DateTime.Now.ToString("MM");
  1541. int Years = GetYear();
  1542. string Pre = QZLot + Years.ToString() + MothLot;
  1543. LOTNO = GetSerialCode(WorkPoint, "ICSInventoryLot", "LotNO", Pre, 5);
  1544. return LOTNO;
  1545. }
  1546. public static string GetSerialCode(string workPointCode, string tbName, string colName, string Pre, int numLen)
  1547. {
  1548. string sql = "EXEC Addins_GetSerialCode '{0}','{1}','{2}','{3}',{4}";
  1549. sql = string.Format(sql, new object[] { workPointCode, tbName, colName, Pre, numLen });
  1550. //return Repository().FindTableBySql(sql.ToString());
  1551. return SqlHelper.ExecuteScalar(sql).ToString();
  1552. //return DbHelper.ExecuteScalar(CommandType.Text, sql).ToString();
  1553. }
  1554. /// <summary>
  1555. /// 根据大类获取自制批次
  1556. /// </summary>
  1557. /// <param name="ClassCode"></param>
  1558. /// <param name="WorkPoint"></param>
  1559. /// <returns></returns>
  1560. public static string GetZZNumber(string ClassCode)
  1561. {
  1562. string QZ = string.Empty;
  1563. switch (ClassCode)
  1564. {
  1565. case "1":
  1566. QZ = "YZ";
  1567. break;
  1568. case "2":
  1569. QZ = "BZ";
  1570. break;
  1571. case "3":
  1572. QZ = "CZ";
  1573. break;
  1574. case "4":
  1575. QZ = "FZ";
  1576. break;
  1577. case "5":
  1578. QZ = "PZ";
  1579. break;
  1580. case "6":
  1581. QZ = "DZ";
  1582. break;
  1583. case "7":
  1584. QZ = "GZ";
  1585. break;
  1586. case "8":
  1587. QZ = "LZ";
  1588. break;
  1589. }
  1590. return QZ;
  1591. }
  1592. public static string GetWGNumber(string ClassCode)
  1593. {
  1594. string result = string.Empty;
  1595. switch (ClassCode)
  1596. {
  1597. case "1":
  1598. result = "YW";
  1599. break;
  1600. case "2":
  1601. result = "BW";
  1602. break;
  1603. case "3":
  1604. result = "CW";
  1605. break;
  1606. case "4":
  1607. result = "FW";
  1608. break;
  1609. case "5":
  1610. result = "PW";
  1611. break;
  1612. case "6":
  1613. result = "DW";
  1614. break;
  1615. case "7":
  1616. result = "GW";
  1617. break;
  1618. case "8":
  1619. result = "LW";
  1620. break;
  1621. }
  1622. return result;
  1623. }
  1624. public static string Organize_F_ParentId(string F_Account)
  1625. {
  1626. string F_ParentId = string.Empty;
  1627. string sql = @"
  1628. SELECT c.F_ID,c.F_ParentId FROM sys_srm_user a
  1629. LEFT JOIN sys_SRM_Role b ON a.F_RoleID=b.F_ID
  1630. LEFT JOIN Sys_SRM_Organize c ON b.F_OrganizeId=c.F_ID
  1631. WHERE a.F_Account='{0}'";
  1632. sql = string.Format(sql, F_Account);
  1633. DataTable dt = GetDataTableBySql(sql);
  1634. if (dt.Rows.Count > 0)
  1635. {
  1636. sql = "select * from Sys_SRM_Organize a WHERE a.F_parentID='" + dt.Rows[0]["F_ID"].ToString() + "'";
  1637. DataTable dts = GetDataTableBySql(sql);
  1638. if (dt.Rows[0]["F_ParentId"].ToString() == "0" || dts.Rows.Count <= 0)
  1639. {
  1640. F_ParentId = "0";
  1641. }
  1642. else
  1643. {
  1644. F_ParentId = dt.Rows[0]["F_ID"].ToString();
  1645. }
  1646. }
  1647. return F_ParentId;
  1648. }
  1649. public static string GetEATTRIBUTE(string sqllist, string Tabname, string TablenameJC, string wheresql, string WorkPoint)
  1650. {
  1651. string col = ",";
  1652. string value = ",";
  1653. string sql = @"select TableCode, ColumnCode AS Code,Name from ICSColumnEnable
  1654. where Enable=1 and TableCode='" + Tabname + "' order by MTIME";
  1655. DataTable dt = GetDataTableBySql(sql);
  1656. Dictionary<string, string> values = new Dictionary<string, string>();
  1657. for (int i = 0; i < dt.Rows.Count; i++)
  1658. {
  1659. values.Add(Tabname + "_" + dt.Rows[i]["Code"].ToString(), "" + TablenameJC + "" + dt.Rows[i]["Code"].ToString() + " as " + Tabname + "_" + dt.Rows[i]["Code"].ToString() + "");
  1660. //SqlKey += "" + TablenameJC + "." + dt.Rows[i]["Code"].ToString() + ",";
  1661. }
  1662. foreach (var item in values)
  1663. {
  1664. col += item.Key + ",";
  1665. value += item.Value + ",";
  1666. }
  1667. sqllist = string.Format(sqllist, wheresql, WorkPoint, value.TrimEnd(','), col.TrimEnd(','));
  1668. return sqllist;
  1669. }
  1670. public static string InsertSQL(string TableName, Dictionary<string, string> values)
  1671. {
  1672. try
  1673. {
  1674. string col = string.Empty;
  1675. string value = string.Empty;
  1676. foreach (var item in values)
  1677. {
  1678. col += item.Key + ",";
  1679. value += item.Value + ",";
  1680. }
  1681. if (!string.IsNullOrWhiteSpace(value))
  1682. {
  1683. return string.Format("INSERT INTO {0} ({1}) Values ({2}) ", TableName, col.TrimEnd(','), value.TrimEnd(','));
  1684. }
  1685. return value;
  1686. }
  1687. catch (Exception ex)
  1688. {
  1689. throw;
  1690. }
  1691. }
  1692. public static string GetEATTRIBUTE(string sqllist, List<string> Tabnames, List<string> TablenameJC, string wheresql, string WorkPoint)
  1693. {
  1694. string col = ",";
  1695. string value = ",";
  1696. for (int i = 0; i < Tabnames.Count; i++)
  1697. {
  1698. string sql = @"select TableCode, ColumnCode AS Code,Name from ICSColumnEnable
  1699. where Enable=1 and TableCode='" + Tabnames[i] + "' order by MTIME";
  1700. DataTable dt = GetDataTableBySql(sql);
  1701. Dictionary<string, string> values = new Dictionary<string, string>();
  1702. for (int j = 0; j < dt.Rows.Count; j++)
  1703. {
  1704. values.Add($"{Tabnames[i]}_{dt.Rows[j]["Code"]}", $"{TablenameJC[i]}{dt.Rows[j]["Code"]} as {Tabnames[i]}_{dt.Rows[j]["Code"]}");
  1705. //SqlKey += "" + TablenameJC + "." + dt.Rows[i]["Code"].ToString() + ",";
  1706. }
  1707. foreach (var item in values)
  1708. {
  1709. col += item.Key + ",";
  1710. value += item.Value + ",";
  1711. }
  1712. }
  1713. sqllist = string.Format(sqllist, wheresql, WorkPoint, value.TrimEnd(','), col.TrimEnd(','));
  1714. return sqllist;
  1715. }
  1716. public static void UserPwdValid(string User, string Pwd)
  1717. {
  1718. if (string.IsNullOrWhiteSpace(User))
  1719. {
  1720. Regex regex = new Regex(@"^(?=.*[A-Za-z])(?=.*\d)(?=.*[~?!@#$%^&*_-])[A-Za-z\d~?!@#$%^&*_-]{8,}$");
  1721. //string rex = @"^(?=.*[A-Za-z])(?=.*\d)(?=.*[~?!@#$%^&*_-])[A-Za-z\d~?!@#$%^&*_-]{8,}$";
  1722. if (!regex.IsMatch(Pwd))
  1723. {
  1724. throw new Exception("密码不符合规则,至少8位,至少包含一个英文字母(区分大小写),至少包含一个数字,至少包含一个特殊字符.");
  1725. }
  1726. }
  1727. }
  1728. public static void ExecuteDate( string sql)
  1729. {
  1730. try
  1731. {
  1732. using (SqlConnection con = new SqlConnection(DataCenterConnString))
  1733. {
  1734. con.Open();
  1735. try
  1736. {
  1737. Dictionary<string, string> dictionary = new Dictionary<string, string>();
  1738. using (SqlTransaction tran = con.BeginTransaction())
  1739. {
  1740. using (SqlCommand command = new SqlCommand())
  1741. {
  1742. command.Connection = con;
  1743. command.Transaction = tran;
  1744. command.CommandTimeout = 600;
  1745. command.CommandText = sql;
  1746. try
  1747. {
  1748. int result = command.ExecuteNonQuery();
  1749. tran.Commit();
  1750. }
  1751. catch (Exception ex)
  1752. {
  1753. tran.Rollback();
  1754. // log.Error(ex.ToString() + Environment.NewLine + "异常SQL:" + Environment.NewLine + sql);
  1755. throw ex;
  1756. }
  1757. }
  1758. }
  1759. }
  1760. catch (Exception ex)
  1761. {
  1762. /// log.Error(ex.ToString());
  1763. throw ex;
  1764. }
  1765. finally
  1766. {
  1767. if (con.State == ConnectionState.Open)
  1768. con.Close();
  1769. con.Dispose();
  1770. }
  1771. }
  1772. }
  1773. catch (Exception ex)
  1774. {
  1775. // log.Error(ex.ToString());
  1776. throw ex;
  1777. }
  1778. }
  1779. private static HashSet<string> UpdateWithoutClos = new HashSet<string>
  1780. {
  1781. "ID","RCVQuantity","SDNQuantity","DABDOCQuantity","InQuantity","OutQuantity","ReleaseState","SSDQuantity","TransferQuantity"
  1782. };
  1783. public static string InsertSQLKingDee(string TableName, Dictionary<string, string> values, string pk)
  1784. {
  1785. try
  1786. {
  1787. string col = string.Join(",", values.Keys);
  1788. string value = string.Join(",", values.Values);
  1789. StringBuilder updateCols = new StringBuilder();//更新拼接字段
  1790. foreach (var item in values)
  1791. {
  1792. if (UpdateWithoutClos.Contains(item.Key))
  1793. continue;
  1794. if (TableName == "ICSMOPick" && item.Key == "Sequence")
  1795. continue;
  1796. if (TableName != "ICSMOPick" && item.Key == "IssueQuantity")
  1797. continue;
  1798. if (TableName == "ICSINVENTORY" && (item.Key == "EATTRIBUTE1" || item.Key == "EffectiveDays" || item.Key == "BatchEnable" || item.Key == "InvIQC" || item.Key == "InvFQC" || item.Key == "InvOQc" || item.Key == "EffectiveEnable" || item.Key == "LotEnable"))
  1799. continue;
  1800. if (TableName == "ICSMOPick" && item.Key == "IssueQuantity")
  1801. updateCols.Append($"{item.Key}=CASE WHEN {item.Key}>0 Then {item.Key} ELSE {item.Value} END,");
  1802. else
  1803. {
  1804. updateCols.Append($"{item.Key}={item.Value},");
  1805. }
  1806. }
  1807. if (!string.IsNullOrWhiteSpace(value))
  1808. {
  1809. return string.Format(@" if not EXISTS(select 1 from {0} where {3})
  1810. begin
  1811. INSERT INTO {0} ({1}) values ({2})
  1812. end
  1813. ELSE
  1814. begin
  1815. update {0} set {4} where {3}
  1816. end
  1817. ", TableName, col.TrimEnd(','), value.TrimEnd(','), pk, updateCols.ToString().TrimEnd(','));
  1818. }
  1819. return value;
  1820. }
  1821. catch (Exception ex)
  1822. {
  1823. //log.Error(ex.ToString());
  1824. throw ex;
  1825. }
  1826. }
  1827. /// <summary>
  1828. /// 返回一个数据表
  1829. /// </summary>
  1830. /// <param name="connectionString">数据库连接字符串</param>
  1831. /// <param name="cmdType">命令类型</param>
  1832. /// <param name="cmdText">SQL语句</param>
  1833. /// <param name="commandParameters">参数</param>
  1834. /// <param name="strTableName">数据表名</param>
  1835. /// <param name="bIsLoadStru">是否加载数据表结构</param>
  1836. /// <returns></returns>
  1837. public static DataTable ExecuteTable( string cmdText)
  1838. {
  1839. try
  1840. {
  1841. using (SqlConnection con = new SqlConnection(DataCenterConnString))
  1842. {
  1843. con.Open();
  1844. try
  1845. {
  1846. Dictionary<string, string> dictionary = new Dictionary<string, string>();
  1847. using (SqlCommand command = new SqlCommand())
  1848. {
  1849. command.CommandText = cmdText;
  1850. DataSet ds = new DataSet();
  1851. SqlDataAdapter da = new SqlDataAdapter(command);
  1852. da.SelectCommand.Connection = con; //加上这个
  1853. //da.FillSchema(ds, SchemaType.Source);
  1854. da.Fill(ds);
  1855. return ds.Tables[0];
  1856. }
  1857. }
  1858. catch (Exception ex)
  1859. {
  1860. // log.Error(ex.ToString());
  1861. throw ex;
  1862. }
  1863. finally
  1864. {
  1865. if (con.State == ConnectionState.Open)
  1866. con.Close();
  1867. con.Dispose();
  1868. }
  1869. }
  1870. }
  1871. catch (Exception ex)
  1872. {
  1873. //log.Error(ex.ToString());
  1874. throw ex;
  1875. }
  1876. }
  1877. public static string InsertSQLKingDeeEx(string TableName, Dictionary<string, string> values,string WorkPoint)
  1878. {
  1879. try
  1880. {
  1881. string col = string.Join(",", values.Keys);
  1882. string value = string.Join(",", values.Values);
  1883. string checksql = string.Empty;
  1884. if (values.ContainsKey("Colspan"))
  1885. checksql = $"if not EXISTS(select id from ICSExtension where Colspan= {values["Colspan"]} and WorkPoint='{WorkPoint}') ";
  1886. if (!string.IsNullOrWhiteSpace(value))
  1887. {
  1888. return $"{checksql} begin INSERT INTO {TableName} ({col}) values ({value}) end ";
  1889. }
  1890. return value;
  1891. }
  1892. catch (Exception ex)
  1893. {
  1894. // log.Error(ex.ToString());
  1895. throw ex;
  1896. }
  1897. }
  1898. public static string GetNewid()
  1899. {
  1900. string sql = "select newid() AS ID";
  1901. return ExecuteTable(sql).Rows[0]["ID"].ToString();
  1902. }
  1903. }//end of class
  1904. #region [ SqlHelper 的扩展方法类 ]
  1905. /// <summary>
  1906. /// 扩展方法类
  1907. /// </summary>
  1908. public static class SqlHelperExtensionMethods
  1909. {
  1910. /// <summary>
  1911. /// 新建SqlCommand对象时, 自动加上指定的 CommandTimeout. by ngye, on 2013-07-11.
  1912. /// </summary>
  1913. /// <param name="cmd">SqlCommand对象</param>
  1914. /// <returns>SqlCommand对象</returns>
  1915. public static SqlCommand AddTimeout(this SqlCommand cmd)
  1916. {
  1917. cmd.CommandTimeout = SqlHelper.CommandTimeout;
  1918. return cmd;
  1919. }
  1920. /// <summary>
  1921. /// 新建SqlBulkCopy对象时, 自动加上指定的 BulkCopyTimeout. by ngye, on 2013-08-30.
  1922. /// </summary>
  1923. /// <param name="cmd">SqlBulkCopy对象</param>
  1924. /// <returns>SqlBulkCopy对象</returns>
  1925. public static SqlBulkCopy AddTimeout(this SqlBulkCopy bulkCopy)
  1926. {
  1927. bulkCopy.BulkCopyTimeout = SqlHelper.CommandTimeout;
  1928. return bulkCopy;
  1929. }
  1930. /// <summary>
  1931. /// 执行cmd得到 DataTable. by ngye, on 2013-08-01
  1932. /// </summary>
  1933. /// <param name="cmd"></param>
  1934. /// <returns></returns>
  1935. public static DataTable ExecuteDataTable(this SqlCommand cmd)
  1936. {
  1937. DataTable dt = new DataTable();
  1938. using (SqlDataAdapter adapter = new SqlDataAdapter(cmd))
  1939. {
  1940. adapter.Fill(dt);
  1941. }
  1942. return dt;
  1943. }
  1944. /// <summary>
  1945. /// 为SqlParameter设置参数. by ngye, on 2013-08-15.
  1946. /// </summary>
  1947. /// <param name="sp"></param>
  1948. /// <returns></returns>
  1949. public static SqlParameter SetValue(this SqlParameter sp, object value)
  1950. {
  1951. sp.Value = value;
  1952. return sp;
  1953. }
  1954. /// <summary>
  1955. /// 为SqlParameter设置SqlDbType. by ngye, on 2013-09-03.
  1956. /// </summary>
  1957. /// <param name="sp"></param>
  1958. /// <returns></returns>
  1959. public static SqlParameter SetSqlDbType(this SqlParameter sp, SqlDbType dbType)
  1960. {
  1961. sp.SqlDbType = dbType;
  1962. return sp;
  1963. }
  1964. /// <summary>
  1965. /// 对可以为空的值作这样的处理,一旦其为空,就设置为DBNull.value.
  1966. /// </summary>
  1967. /// <param name="sp"></param>
  1968. /// <returns></returns>
  1969. public static SqlParameter[] SetDBNull(this SqlParameter[] spArr)
  1970. {
  1971. if (spArr == null || spArr.Length == 0)
  1972. return spArr;
  1973. for (int i = 0; i < spArr.Length; i++)
  1974. {
  1975. SqlParameter sp = spArr[i];
  1976. if (sp.Value == null)
  1977. sp.Value = DBNull.Value;
  1978. }
  1979. return spArr;
  1980. }
  1981. }
  1982. #endregion
  1983. }