RepositoryTask.cs 3.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889
  1. using NPOI.SS.Formula.Functions;
  2. using SqlSugar;
  3. using System;
  4. using System.Collections.Generic;
  5. using System.Linq;
  6. using System.Linq.Expressions;
  7. using System.Text;
  8. using wms.dto;
  9. using wms.dto.request.hj;
  10. using wms.dto.request.hj.dto;
  11. using wms.sqlsugar.model;
  12. using wms.sqlsugar.model.hj;
  13. using wms.util.Check;
  14. using static wms.dto.request.hj.dto.ReportResponse;
  15. namespace wms.sqlsugar
  16. {
  17. /// <summary>
  18. /// 创建仓储
  19. /// </summary>
  20. /// <typeparam name="T"></typeparam>
  21. public class RepositoryTask<T> : SimpleClient<T> where T : class, new()
  22. {
  23. public RepositoryTask()
  24. {
  25. //固定数据库用法
  26. base.Context = SqlSugarHelper.Db.GetConnectionScopeWithAttr<T>();
  27. //动态库用法一般用于维护数据库连接字符串根据用法
  28. //if (!SqlSugarHelper.Db.IsAnyConnection("用户读出来的数据库ConfigId"))
  29. //{
  30. // SqlSugarHelper.Db.AddConnection(new ConnectionConfig() { 数据库读出来信息 });
  31. //}
  32. //base.Context = SqlSugarHelper.Db.GetConnectionScope("用户读出来的数据库ConfigId");
  33. }
  34. public T InsertReturnEntity(T t)
  35. {
  36. return base.Context.Insertable(t).ExecuteReturnEntity();
  37. }
  38. public int InsertableSplitTable(T t)
  39. {
  40. return base.Context.Insertable(t).SplitTable().ExecuteCommand();
  41. }
  42. public int InsertableSplitTable(List<T> t)
  43. {
  44. return base.Context.Insertable(t).SplitTable().ExecuteCommand();
  45. }
  46. /// <summary>
  47. /// 该方法默认不更新CreatedUserId,CreatedTime
  48. /// </summary>
  49. /// <param name="entity"></param>
  50. /// <returns></returns>
  51. public bool UpdateEntity(T entity)
  52. {
  53. return base.Context.Updateable(entity).IgnoreColumns(new string[] { "AddWho", "AddTime" }).ExecuteCommand() > 0;
  54. }
  55. public bool UpdateModelColumns(Expression<Func<T, T>> Columns, Expression<Func<T, bool>> WhereExpression)
  56. {
  57. return base.Update(Columns, WhereExpression);
  58. }
  59. public bool UpdateSplitTableModelColumns(Expression<Func<T, T>> Columns, Expression<Func<T, bool>> WhereExpression)
  60. {
  61. return base.Context.Updateable<T>().SetColumns(Columns).Where(WhereExpression).SplitTable(x => x.Take(2)).ExecuteCommand() > 0;
  62. }
  63. public T GetModelByExpression(Expression<Func<T, bool>> WhereExpression)
  64. {
  65. return base.GetSingle(WhereExpression);
  66. }
  67. public List<hjSysConfig> GetTunList(TunnelRequest request)
  68. {
  69. var list = base.Context.Queryable<hjSysConfig>()
  70. .WhereIF(!string.IsNullOrEmpty(request.WareHouse), p => p.Default2 == request.WareHouse)
  71. .WhereIF(!string.IsNullOrEmpty(request.Tunnel), p => p.Default1 == request.Tunnel)
  72. .ToList();
  73. return list;
  74. }
  75. public bool UpdateTunStatu(long id, string statu, long userId)
  76. {
  77. return base.Context.Updateable<hjSysConfig>().SetColumns(it => new hjSysConfig()
  78. {
  79. SContent = statu,
  80. EditTime = DateTime.Now
  81. }).Where(it => it.Id == id).ExecuteCommand() > 0;
  82. }
  83. }
  84. }