SqlExtension.cs 5.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124
  1. using System.Linq.Expressions;
  2. using SqlSugar;
  3. namespace ServiceCenter.Extensions
  4. {
  5. public static class SqlExtension
  6. {
  7. /// <summary>
  8. /// 不添加共享锁和排它锁,当这个选项生效后,可能读到未提交读的数据或“脏数据”,这个选项仅仅应用于SELECT语句
  9. /// </summary>
  10. /// <typeparam name="T"></typeparam>
  11. /// <param name="obj"></param>
  12. /// <returns></returns>
  13. public static ISugarQueryable<T> NoLock<T>(this ISugarQueryable<T> obj)
  14. {
  15. return obj.With(SqlWith.NoLock);
  16. }
  17. /// <summary>
  18. /// 跳过已经加锁的数据行,这个选项将使事务读取数据时跳过那些已经被其他事务锁定的数据行,而不是阻塞直到其他事务释放锁,ReadPast仅仅应用于READ COMMITTED隔离性级别下事务操作中的SELECT语句操作。
  19. /// </summary>
  20. /// <typeparam name="T"></typeparam>
  21. /// <param name="obj"></param>
  22. /// <returns></returns>
  23. public static ISugarQueryable<T> ReadPast<T>(this ISugarQueryable<T> obj)
  24. {
  25. return obj.With(SqlWith.ReadPast);
  26. }
  27. /// <summary>
  28. /// 指定在读表中数据时设置更新锁(update lock)而不是设置共享锁,该锁一直保持到这个语句或整个事务结束,使用UpdLock的作用是允许用户先读取数据(而且不阻塞其他用户读数据),并且保证在后来再更新数据时,这一段时间内这些数据没有被其他用户修改。
  29. /// 默认持有行级更新锁
  30. /// </summary>
  31. /// <typeparam name="T"></typeparam>
  32. /// <param name="obj"></param>
  33. /// <returns></returns>
  34. public static ISugarQueryable<T> UpdLock<T>(this ISugarQueryable<T> obj)
  35. {
  36. return obj.With("WITH(ROWLOCK)");
  37. }
  38. /// <summary>
  39. /// 跳过加锁数据行并指定在读表中数据时设置更新锁(update lock)而不是设置共享锁,该锁一直保持到这个语句或整个事务结束,使用UpdLock的作用是允许用户先读取数据(而且不阻塞其他用户读数据),并且保证在后来再更新数据时,这一段时间内这些数据没有被其他用户修改。
  40. /// 默认持有行级更新锁
  41. /// </summary>
  42. /// <typeparam name="T"></typeparam>
  43. /// <param name="obj"></param>
  44. /// <returns></returns>
  45. public static ISugarQueryable<T> ReadPastUpdLock<T>(this ISugarQueryable<T> obj)
  46. {
  47. return obj.With("WITH(READPAST,ROWLOCK)");
  48. }
  49. /// <summary>
  50. /// 使用行级锁,而不使用粒度更粗的页级锁和表级锁。
  51. /// </summary>
  52. /// <typeparam name="T"></typeparam>
  53. /// <param name="obj"></param>
  54. /// <returns></returns>
  55. public static ISugarQueryable<T> RowLock<T>(this ISugarQueryable<T> obj)
  56. {
  57. return obj.With(SqlWith.RowLock);
  58. }
  59. /// <summary>
  60. /// 更新时使用行级锁
  61. /// </summary>
  62. /// <typeparam name="T"></typeparam>
  63. /// <param name="scope"></param>
  64. /// <param name="updateObj"></param>
  65. /// <returns></returns>
  66. public static IUpdateable<T> UpdateableRowLock<T>(this SqlSugarScopeProvider scope, T updateObj) where T : class, new() => scope.ScopedContext.Updateable<T>(updateObj).With(SqlWith.RowLock);
  67. public static bool UpdateWhereColumns<T>(this IUpdateable<T> db, Expression<Func<T, T>> columns,Expression<Func<T, bool>> whereExpression) where T : class, new()
  68. {
  69. return db.SetColumns(columns).Where(whereExpression).ExecuteCommand() > 0;
  70. }
  71. /// <summary>
  72. /// 更新时使用行级锁
  73. /// </summary>
  74. /// <typeparam name="T"></typeparam>
  75. /// <param name="scope"></param>
  76. /// <param name="updateObj"></param>
  77. /// <returns></returns>
  78. public static IUpdateable<T> UpdateableRowLock<T>(this SqlSugarScopeProvider scope, List<T> updateObj) where T : class, new() => scope.ScopedContext.Updateable<T>(updateObj).With(SqlWith.RowLock);
  79. /// <summary>
  80. /// 插入时使用行级锁
  81. /// </summary>
  82. /// <typeparam name="T"></typeparam>
  83. /// <param name="scope"></param>
  84. /// <param name="updateObj"></param>
  85. /// <returns></returns>
  86. public static IInsertable<T> InsertableRowLock<T>(this SqlSugarScopeProvider scope, T insertObj) where T : class, new() => scope.ScopedContext.Insertable<T>(insertObj).With(SqlWith.RowLock);
  87. /// <summary>
  88. /// 插入时使用行级锁
  89. /// </summary>
  90. /// <typeparam name="T"></typeparam>
  91. /// <param name="scope"></param>
  92. /// <param name="updateObj"></param>
  93. /// <returns></returns>
  94. public static IInsertable<T> InsertableRowLock<T>(this SqlSugarScopeProvider scope, List<T> insertObj) where T : class, new() => scope.ScopedContext.Insertable<T>(insertObj).With(SqlWith.RowLock);
  95. /// <summary>
  96. /// 删除时使用行级锁
  97. /// </summary>
  98. /// <typeparam name="T"></typeparam>
  99. /// <param name="scope"></param>
  100. /// <param name="deleteObj"></param>
  101. /// <returns></returns>
  102. public static IDeleteable<T> DeleteableRowLock<T>(this SqlSugarScopeProvider scope, T deleteObj) where T : class, new() => scope.ScopedContext.Deleteable<T>(deleteObj).With(SqlWith.RowLock);
  103. /// <summary>
  104. /// 删除时使用行级锁
  105. /// </summary>
  106. /// <typeparam name="T"></typeparam>
  107. /// <param name="scope"></param>
  108. /// <param name="deleteObj"></param>
  109. /// <returns></returns>
  110. public static IDeleteable<T> DeleteableRowLock<T>(this SqlSugarScopeProvider scope, List<T> deleteObj) where T : class, new() => scope.ScopedContext.Deleteable<T>(deleteObj).With(SqlWith.RowLock);
  111. }
  112. }