ViseManager.cs 4.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118
  1. using Sugar.Enties;
  2. using SqlSugar;
  3. using System;
  4. using System.Collections.Generic;
  5. using WebAPIBase.Utils;
  6. /// <summary>
  7. /// 待审签证管理类
  8. /// </summary>
  9. public class ViseManager : DbContext<Vise>
  10. {
  11. //当前类已经继承了 DbContext增、删、查、改的方法
  12. //这里面写的代码不会给覆盖,如果要重新生成请删除 ViseManager.cs
  13. /// <summary>
  14. /// 获取待审签证列表
  15. /// </summary>
  16. /// <param name="projectCode"></param>
  17. /// <param name="searchValue"></param>
  18. /// <returns></returns>
  19. public List<ViseDTO> GetVises(string projectCode, string searchValue = "")
  20. {
  21. var sql = $"SELECT v.ViseCode,v.ViseId,v.ViseName,v.ViseType,CONVERT(VARCHAR(10),v.ViseDate,120) ViseDate,v.State,dbo.GetUnitFullName(v.UnitCode) unitFullName, c.ContractName,v.ContractCode from Vise v INNER JOIN dbo.Contract c ON v.ContractCode=c.ContractCode where (dbo.GetUnitFullCode(v.UnitCode) like ('100000%')) and v.ProjectCode = '{projectCode}' and v.State ='0' ";
  22. if (searchValue.IsNotNullAndEmpty())
  23. {
  24. sql += $" and (v.ViseId='{searchValue}' or v.ViseName like '%{searchValue}%')";
  25. }
  26. sql += " order by v.ViseCode desc";
  27. var list = Db.Ado.SqlQuery<ViseDTO>(sql);
  28. return list;
  29. }
  30. /// <summary>
  31. /// 根据签证编码获取待审签证实例
  32. /// </summary>
  33. /// <param name="viseCode"></param>
  34. /// <returns></returns>
  35. public ViseDTO GetVise(string viseCode)
  36. {
  37. var sql = $"SELECT v.*,dbo.GetUnitFullName(v.UnitCode) unitFullName, c.ContractName from Vise v INNER JOIN dbo.Contract c ON v.ContractCode=c.ContractCode where v.viseCode = '{viseCode}' ";
  38. var entity = Db.Ado.SqlQuerySingle<ViseDTO>(sql);
  39. return entity;
  40. }
  41. #region 教学方法
  42. /// <summary>
  43. /// 如果DbContext中的增删查改方法满足不了你,你可以看下具体用法
  44. /// </summary>
  45. public void Study()
  46. {
  47. /*********查询*********/
  48. var data1 = ViseDb.GetById(1);//根据ID查询
  49. var data2 = ViseDb.GetList();//查询所有
  50. var data3 = ViseDb.GetList(it => 1 == 1); //根据条件查询
  51. //var data4 = ViseDb.GetSingle(it => 1 == 1);//根据条件查询一条,如果超过一条会报错
  52. var p = new PageModel() { PageIndex = 1, PageSize = 2 };// 分页查询
  53. var data5 = ViseDb.GetPageList(it => 1 == 1, p);
  54. Console.Write(p.PageCount);//返回总数
  55. var data6 = ViseDb.GetPageList(it => 1 == 1, p, it => SqlFunc.GetRandom(), OrderByType.Asc);// 分页查询加排序
  56. Console.Write(p.PageCount);//返回总数
  57. List<IConditionalModel> conModels = new List<IConditionalModel>(); //组装条件查询作为条件实现 分页查询加排序
  58. conModels.Add(new ConditionalModel() { FieldName = typeof(Vise).GetProperties()[0].Name, ConditionalType = ConditionalType.Equal, FieldValue = "1" });//id=1
  59. var data7 = ViseDb.GetPageList(conModels, p, it => SqlFunc.GetRandom(), OrderByType.Asc);
  60. ViseDb.AsQueryable().Where(x => 1 == 1).ToList();//支持了转换成queryable,我们可以用queryable实现复杂功能
  61. //我要用事务
  62. var result = Db.Ado.UseTran(() =>
  63. {
  64. //写事务代码
  65. });
  66. if (result.IsSuccess)
  67. {
  68. //事务成功
  69. }
  70. //多表查询地址 http://www.codeisbug.com/Doc/8/1124
  71. /*********插入*********/
  72. var insertData = new Vise() { };//测试参数
  73. var insertArray = new Vise[] { insertData };
  74. ViseDb.Insert(insertData);//插入
  75. ViseDb.InsertRange(insertArray);//批量插入
  76. var id = ViseDb.InsertReturnIdentity(insertData);//插入返回自增列
  77. ViseDb.AsInsertable(insertData).ExecuteCommand();//我们可以转成 Insertable实现复杂插入
  78. /*********更新*********/
  79. var updateData = new Vise() { };//测试参数
  80. var updateArray = new Vise[] { updateData };//测试参数
  81. ViseDb.Update(updateData);//根据实体更新
  82. ViseDb.UpdateRange(updateArray);//批量更新
  83. //ViseDb.Update(it => new Vise() { Name = "a", CreateTime = DateTime.Now }, it => it.id==1);// 只更新Name列和CreateTime列,其它列不更新,条件id=1
  84. ViseDb.AsUpdateable(updateData).ExecuteCommand();
  85. /*********删除*********/
  86. var deldata = new Vise() { };//测试参数
  87. ViseDb.Delete(deldata);//根据实体删除
  88. ViseDb.DeleteById(1);//根据主键删除
  89. ViseDb.DeleteById(new int[] { 1, 2 });//根据主键数组删除
  90. ViseDb.Delete(it => 1 == 2);//根据条件删除
  91. ViseDb.AsDeleteable().Where(it => 1 == 2).ExecuteCommand();//转成Deleteable实现复杂的操作
  92. }
  93. #endregion
  94. }