SqlSugarTool.cs 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353
  1. using SKMC.Api.Common.File;
  2. using Newtonsoft.Json;
  3. using SqlSugar;
  4. using System;
  5. using System.Collections.Generic;
  6. using System.Data;
  7. using System.Linq;
  8. using System.Linq.Expressions;
  9. using System.Text;
  10. using DbType = SqlSugar.DbType;
  11. using SKMC.Api.Common.Logger;
  12. namespace SKMC.Api.Common.DB
  13. {
  14. /// <summary>
  15. /// SqlSugar的工具类
  16. /// </summary>
  17. public class SqlSugarTool
  18. {
  19. private static readonly ILogger log = LogFactory.Get();
  20. private static readonly AppConfig appConfig = AppConfig.Instance();
  21. /// <summary>
  22. /// 从配置库文件获取数据库实例
  23. /// </summary>
  24. /// <returns></returns>
  25. public static SqlSugarClient GetConfigDB() => GetDB("DB_CONFIG");
  26. /// <summary>
  27. /// 从运行库文件获取数据库实例
  28. /// </summary>
  29. /// <returns></returns>
  30. public static SqlSugarClient GetRuntimeDB() => GetDB("DB_RUNDATA");
  31. private static SqlSugarClient GetDB(string dbName)
  32. {
  33. SqlSugarClient db = new SqlSugarClient(new ConnectionConfig()
  34. {
  35. ConnectionString = String.Format(appConfig.ReadStringValue(dbName, "connection.datasource"), System.Environment.CurrentDirectory),
  36. DbType = DbType.Sqlite,
  37. // 自动释放数据务,如果存在事务,在事务结束后释放
  38. IsAutoCloseConnection = appConfig.ReadBoolValue(dbName, "connection.autoclosed"),
  39. // 从数据库系统表读取主键信息中(InitKeyType.Attribute从实体特性中读取主键自增列信息)
  40. InitKeyType = InitKeyType.Attribute
  41. // 暂不设置数据库缓存
  42. });
  43. // 调试SQL,AOP ,日志
  44. db.Aop.OnLogExecuted = (sql, pars) => // SQL执行完事件
  45. {
  46. // 获取执行后的总毫秒数
  47. double sqlExecutionTotalMilliseconds = db.Ado.SqlExecutionTime.TotalMilliseconds;
  48. };
  49. db.Aop.OnLogExecuting = (sql, pars) => // SQL执行前事件。可在这里查看生成的sql
  50. {
  51. string tempSQL = LookSQL(sql, pars);
  52. };
  53. db.Aop.OnError = (exp) =>// 执行SQL 错误事件
  54. {
  55. // exp.sql exp.parameters 可以拿到参数和错误Sql
  56. StringBuilder sb_SugarParameterStr = new StringBuilder("###SugarParameter参数为:");
  57. var parametres = exp.Parametres as SugarParameter[];
  58. if (parametres != null)
  59. {
  60. sb_SugarParameterStr.Append(JsonConvert.SerializeObject(parametres));
  61. }
  62. StringBuilder sb_error = new StringBuilder();
  63. sb_error.AppendLine("SqlSugarClient执行sql异常信息:" + exp.Message);
  64. sb_error.AppendLine("###赋值后sql:" + LookSQL(exp.Sql, parametres));
  65. sb_error.AppendLine("###带参数的sql:" + exp.Sql);
  66. sb_error.AppendLine("###参数信息:" + sb_SugarParameterStr.ToString());
  67. sb_error.AppendLine("###StackTrace信息:" + exp.StackTrace);
  68. log.Error(sb_error.ToString());
  69. };
  70. db.Aop.OnExecutingChangeSql = (sql, pars) => // SQL执行前 可以修改SQL
  71. {
  72. // 判断update或delete方法是否有where条件。如果真的想删除所有数据,请where(p=>true)或where(p=>p.id>0)
  73. if (sql.TrimStart().IndexOf("delete ", StringComparison.CurrentCultureIgnoreCase) == 0)
  74. {
  75. if (sql.IndexOf("where", StringComparison.CurrentCultureIgnoreCase) <= 0)
  76. {
  77. throw new Exception("delete删除方法需要有where条件!!");
  78. }
  79. }
  80. else if (sql.TrimStart().IndexOf("update ", StringComparison.CurrentCultureIgnoreCase) == 0)
  81. {
  82. if (sql.IndexOf("where", StringComparison.CurrentCultureIgnoreCase) <= 0)
  83. {
  84. throw new Exception("update更新方法需要有where条件!!");
  85. }
  86. }
  87. return new KeyValuePair<string, SugarParameter[]>(sql, pars);
  88. };
  89. // db.Aop.OnDiffLogEvent = it =>// 数据库操作前和操作后的数据变化。
  90. // {
  91. // var editBeforeData = it.BeforeData;
  92. // var editAfterData = it.AfterData;
  93. // var sql = it.Sql;
  94. // var parameter = it.Parameters;
  95. // var data = it.BusinessData;
  96. // var time = it.Time;
  97. // var diffType = it.DiffType;// 枚举值 insert 、update 和 delete 用来作业务区分
  98. // 日志方法
  99. // };
  100. // db.Ado.CommandTimeOut // 设置sql执行超时等待时间(毫秒单位)
  101. // db.Ado.Connection.ConnectionTimeout // 设置数据库连接等待时间(毫秒单位)
  102. return db;
  103. }
  104. ///<summary>
  105. ///查看赋值后的sql
  106. ///</summary>
  107. ///<param name="sql"></param>
  108. ///<param name="pars">参数</param>
  109. ///<returns></returns>
  110. private static string LookSQL(string sql, SugarParameter[] pars)
  111. {
  112. if (pars == null || pars.Length == 0) return sql;
  113. StringBuilder sb_sql = new StringBuilder(sql);
  114. var tempOrderPars = pars.Where(p => p.Value != null).OrderByDescending(p => p.ParameterName.Length).ToList();// 防止 @par1错误替换@par12
  115. for (var index = 0; index < tempOrderPars.Count; index++)
  116. {
  117. sb_sql.Replace(tempOrderPars[index].ParameterName, "'" + tempOrderPars[index].Value.ToString() + "'");
  118. }
  119. return sb_sql.ToString();
  120. }
  121. /// <summary>
  122. /// 获取一个实体
  123. /// </summary>
  124. /// <typeparam name="T"></typeparam>
  125. /// <param name="id">主键</param>
  126. /// <param name="db"></param>
  127. /// <returns></returns>
  128. public static T GetModel<T>(object id, SqlSugarClient db)
  129. {
  130. return db.Queryable<T>().InSingle(id);
  131. }
  132. /// <summary>
  133. /// 从缓存中获取一个实体
  134. /// </summary>
  135. /// <typeparam name="T"></typeparam>
  136. /// <param name="id">主键</param>
  137. /// <param name="db"></param>
  138. /// <returns></returns>
  139. public static T GetModel_WithCache<T>(object id, SqlSugarClient db)
  140. {
  141. return db.Queryable<T>().WithCache().InSingle(id);
  142. }
  143. /// <summary>
  144. /// 添加实体数据,并返回主键值(主键为自增int类型id,实体需要设置主键特性)(为null字段不更新,注意model有默认值的情况)
  145. /// </summary>
  146. /// <typeparam name="T"></typeparam>
  147. /// <param name="t"></param>
  148. /// <param name="db">(事务的db对象)</param>
  149. /// <returns></returns>
  150. public static int InsertModel<T>(T t, SqlSugarClient db) where T : class, new()
  151. {
  152. // Where(true/*不插入null值的列*/,false/*不插入主键值*/)
  153. return db.Insertable(t).
  154. // IgnoreColumns(p=>p.Equals("id",StringComparison.InvariantCultureIgnoreCase)).
  155. IgnoreColumns(true, false).ExecuteReturnIdentity();
  156. }
  157. /// <summary>
  158. /// 添加实体数据,并返回主键值(主键为自增long类型id,实体需要设置主键特性)(为null字段不更新,注意model有默认值的情况)
  159. /// </summary>
  160. /// <typeparam name="T"></typeparam>
  161. /// <param name="t"></param>
  162. /// <param name="db">(事务的db对象)</param>
  163. /// <returns></returns>
  164. public static long InsertModel_BigIdentity<T>(T t, SqlSugarClient db) where T : class, new()
  165. {
  166. // Where(true/*不插入null值的列*/,false/*不插入主键值*/)
  167. return db.Insertable(t).
  168. // IgnoreColumns(p=>p.Equals("id",StringComparison.InvariantCultureIgnoreCase)).
  169. IgnoreColumns(true, false).ExecuteReturnBigIdentity();
  170. }
  171. /// <summary>
  172. /// 添加实体数据,删除缓存,并返回主键值(主键为自增int类型id,实体需要设置主键特性)(为null字段不更新,注意model有默认值的情况)
  173. /// </summary>
  174. /// <typeparam name="T"></typeparam>
  175. /// <param name="t"></param>
  176. /// <param name="db">(事务的db对象)</param>
  177. /// <returns></returns>
  178. public static int InsertModel_RemoveDataCache<T>(T t, SqlSugarClient db) where T : class, new()
  179. {
  180. // Where(true/*不插入null值的列*/,false/*不插入主键值*/)
  181. return db.Insertable(t).
  182. // IgnoreColumns(p=>p.Equals("id",StringComparison.InvariantCultureIgnoreCase)).
  183. IgnoreColumns(true, false).RemoveDataCache().ExecuteReturnIdentity();
  184. }
  185. /// <summary>
  186. /// 添加实体数据,并返回主键值(主键为自增long类型id,实体需要设置主键特性)(为null字段不更新,注意model有默认值的情况)
  187. /// </summary>
  188. /// <typeparam name="T"></typeparam>
  189. /// <param name="t"></param>
  190. /// <param name="db">(事务的db对象)</param>
  191. /// <returns></returns>
  192. public static long InsertModel_BigIdentity_RemoveDataCache<T>(T t, SqlSugarClient db) where T : class, new()
  193. {
  194. // Where(true/*不插入null值的列*/,false/*不插入主键值*/)
  195. return db.Insertable(t).
  196. // IgnoreColumns(p=>p.Equals("id",StringComparison.InvariantCultureIgnoreCase)).
  197. IgnoreColumns(true, false).RemoveDataCache().ExecuteReturnBigIdentity();
  198. }
  199. /// <summary>
  200. /// 根据主键更新实体,返回影响条数(实体字段要有主键特性)
  201. /// </summary>
  202. /// <typeparam name="T"></typeparam>
  203. /// <param name="t"></param>
  204. /// <param name="db">(事务的db对象)</param>
  205. /// <returns></returns>
  206. public static int UpdateModelByKey<T>(T t, SqlSugarClient db) where T : class, new()
  207. {
  208. // 字段null,不进行更新
  209. return db.Updateable(t).IgnoreColumns(ignoreAllNullColumns: true).ExecuteCommand();
  210. }
  211. /// <summary>
  212. /// 根据条件表达式更新实体(为null字段不更新,注意model有默认值的情况),返回影响条数
  213. /// </summary>
  214. /// <typeparam name="T"></typeparam>
  215. /// <param name="t"></param>
  216. /// <param name="expressionWhere">条件表达式</param>
  217. /// <param name="db">(事务的db对象)</param>
  218. /// <returns></returns>
  219. public static int UpdateModelsIgnoreNull<T>(T t, Expression<Func<T, bool>> expressionWhere, SqlSugarClient db) where T : class, new()
  220. {
  221. return db.Updateable(t).IgnoreColumns(ignoreAllNullColumns: true).Where(expressionWhere).ExecuteCommand();
  222. }
  223. /// <summary>
  224. /// 根据条件表达式更新实体(指定要更新的列),返回影响条数
  225. /// </summary>
  226. /// <typeparam name="T"></typeparam>
  227. /// <param name="t"></param>
  228. /// <param name="columns"></param>
  229. /// <param name="expressionWhere">条件表达式</param>
  230. /// <param name="db">(事务的db对象)</param>
  231. /// <returns></returns>
  232. public static int UpdateModels<T>(T t, Expression<Func<T, object>> columns, Expression<Func<T, bool>> expressionWhere, SqlSugarClient db) where T : class, new()
  233. {
  234. return db.Updateable(t).UpdateColumns(columns).Where(expressionWhere).ExecuteCommand();
  235. }
  236. /// <summary>
  237. /// 动态更新
  238. /// </summary>
  239. /// <typeparam name="T"></typeparam>
  240. /// <param name="columns">要更新的字段</param>
  241. /// <param name="expressionWhere">where条件表达式</param>
  242. /// <param name="db"></param>
  243. /// <returns></returns>
  244. public static int Update<T>(Expression<Func<T, T>> columns, Expression<Func<T, bool>> expressionWhere, SqlSugarClient db) where T : class, new()
  245. {
  246. return db.Updateable<T>().SetColumns(columns).
  247. // IgnoreColumns(ignoreAllNullColumns: true).// 不能加此方法,会有“CommandText 属性尚未初始化”异常
  248. Where(expressionWhere).ExecuteCommand();
  249. /* 调用示例
  250. Update<Entity.SysAdmin>(p => new Entity.SysAdmin { photo = photo, Password = newPwd }
  251. ,p => p.ID == sm.id && p.Password == oldPwd ,db) > 0;
  252. */
  253. }
  254. /// <summary>
  255. /// 根据主键更新实体,返回影响条数(实体字段要有主键特性)并删除缓存,返回影响条数(实体字段要有主键特性)
  256. /// </summary>
  257. /// <typeparam name="T"></typeparam>
  258. /// <param name="t"></param>
  259. /// <param name="db">(事务的db对象)</param>
  260. /// <returns></returns>
  261. public static int UpdateModelByKey_RemoveDataCache<T>(T t, SqlSugarClient db) where T : class, new()
  262. {
  263. // 字段null,不进行更新
  264. return db.Updateable(t).IgnoreColumns(ignoreAllNullColumns: true).RemoveDataCache().ExecuteCommand();
  265. }
  266. /// <summary>
  267. /// 根据条件表达式更新实体(指定要更新的列)并删除缓存,返回影响条数
  268. /// </summary>
  269. /// <typeparam name="T"></typeparam>
  270. /// <param name="t"></param>
  271. /// <param name="columns"></param>
  272. /// <param name="expressionWhere">条件表达式</param>
  273. /// <param name="db">(事务的db对象)</param>
  274. /// <returns></returns>
  275. public static int UpdateModels_RemoveDataCache<T>(T t, Expression<Func<T, object>> columns, Expression<Func<T, bool>> expressionWhere, SqlSugarClient db) where T : class, new()
  276. {
  277. return db.Updateable(t).UpdateColumns(columns).Where(expressionWhere).RemoveDataCache().ExecuteCommand();
  278. }
  279. /// <summary>
  280. /// 动态更新,并删除缓存
  281. /// </summary>
  282. /// <typeparam name="T"></typeparam>
  283. /// <param name="columns">要更新的字段</param>
  284. /// <param name="expressionWhere">where条件表达式</param>
  285. /// <param name="db"></param>
  286. /// <returns></returns>
  287. public static int Update_RemoveDataCache<T>(Expression<Func<T, T>> columns, Expression<Func<T, bool>> expressionWhere, SqlSugarClient db) where T : class, new()
  288. {
  289. return db.Updateable<T>().SetColumns(columns).
  290. // IgnoreColumns(ignoreAllNullColumns: true).// 不能加此方法,会有“CommandText 属性尚未初始化”异常
  291. Where(expressionWhere).RemoveDataCache().ExecuteCommand();
  292. /* 调用示例
  293. Update<Entity.SysAdmin>(p => new Entity.SysAdmin { photo = photo, Password = newPwd }
  294. ,p => p.ID == sm.id && p.Password == oldPwd ,db) > 0;
  295. */
  296. }
  297. /// <summary>
  298. /// 删除ids集合条件的字符串(高效率写法,注意防止注入攻击)
  299. /// </summary>
  300. /// <param name="ids">ids为字符串 "1,2,3"或"1" 形式</param>
  301. /// <param name="db">(事务的db对象)</param>
  302. /// <param name="key">主键字段</param>
  303. /// <returns></returns>
  304. public static bool DeleteByWhereSql_ids<T>(string ids, SqlSugarClient db, string key = "id") where T : class, new()
  305. {
  306. return db.Deleteable<T>().Where(string.Format(" {0} IN ({1})", key, ids)).ExecuteCommand() > 0;
  307. }
  308. /// <summary>
  309. /// 根据条件表达式删除,返回影响条数
  310. /// </summary>
  311. /// <typeparam name="T"></typeparam>
  312. /// <param name="expression">表达式</param>
  313. /// <param name="db">(事务的db对象)</param>
  314. /// <returns></returns>
  315. public static int DeleteModels<T>(Expression<Func<T, bool>> expression, SqlSugarClient db) where T : class, new()
  316. {
  317. return db.Deleteable<T>().Where(expression).ExecuteCommand();
  318. }
  319. }
  320. }