SqlSugarTool.cs 16 KB

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