基於NET6平台WebApi嘗鮮項目: 基於最新的.NET6平台,完全拋棄繁雜的接口,采用.NET最經典的三層架構,結合簡化的DDD設計模式... (gitee.com)
1、目前Sqlsugar已經具備操作數據庫的能力,根據微軟電子書,我們按照如下結構創建文件夾來完善我們的項目
2、我們分別在對應的文件夾中為Address創建Dto和ViewModel,代碼如下:
namespace NET6.Domain.Dtos { public class AddressDto { /// <summary> /// 收件人姓名 /// </summary> public string Name { get; set; } /// <summary> /// 收件人手機號 /// </summary> public string Phone { get; set; } /// <summary> /// 省份 /// </summary> public string Province { get; set; } /// <summary> /// 城市 /// </summary> public string City { get; set; } /// <summary> /// 區域 /// </summary> public string Area { get; set; } /// <summary> /// 詳細地址 /// </summary> public string Detail { get; set; } /// <summary> /// 是否是默認地址 /// </summary> public bool IsDefault { get; set; } } }
namespace NET6.Domain.ViewModels { public class AddressView { /// <summary> /// 編號 /// </summary> public string Id { get; set; } /// <summary> /// 收件人姓名 /// </summary> public string Name { get; set; } /// <summary> /// 收件人手機號 /// </summary> public string Phone { get; set; } /// <summary> /// 省份 /// </summary> public string Province { get; set; } /// <summary> /// 城市 /// </summary> public string City { get; set; } /// <summary> /// 區域 /// </summary> public string Area { get; set; } /// <summary> /// 詳細地址 /// </summary> public string Detail { get; set; } /// <summary> /// 是否是默認地址 /// </summary> public bool IsDefault { get; set; } } }
3、接下來我們為Address創建倉儲,為了更好的開發,我們先創建一個泛型的BaseRepository,並在其中編寫常用的CRUD方法,然后創建AddressRepository繼承於BaseRepository,代碼如下
using NET6.Domain.Entities; using NET6.Domain.Enums; using SqlSugar; using System.Data; using System.Linq.Expressions; namespace NET6.Infrastructure.Repositories { public class BaseRepository<TEntity, TDto> where TEntity : EntityBase, new() { public SqlSugarClient _sqlSugar; public BaseRepository(SqlSugarClient sqlSugar) { _sqlSugar = sqlSugar; } #region 多租戶 /// <summary> /// 變更數據庫 /// </summary> /// <param name="db"></param> public void ChangeDataBase(DBEnum db) { _sqlSugar.ChangeDatabase(db); } #endregion #region 原生Sql public virtual Task<int> ExecuteCommandAsync(string sql) { return _sqlSugar.Ado.ExecuteCommandAsync(sql); } public virtual Task<DataTable> GetDataTableAsync(string sql) { return _sqlSugar.Ado.GetDataTableAsync(sql); } public virtual Task<object> GetScalarAsync(string sql) { return _sqlSugar.Ado.GetScalarAsync(sql); } #endregion #region 事務操作 public void BeginTran() { _sqlSugar.BeginTran(); } public void CommitTran() { _sqlSugar.CommitTran(); } public void RollbackTran() { _sqlSugar.RollbackTran(); } #endregion #region 庫表管理 public bool CreateDataBase() { return _sqlSugar.DbMaintenance.CreateDatabase(); } public bool CopyTable(string oldname, string newname) { if (!_sqlSugar.DbMaintenance.IsAnyTable(newname, false)) { return _sqlSugar.DbMaintenance.BackupTable(oldname, newname, 0); } return false; } public bool TruncateTable(string tablename) { return _sqlSugar.DbMaintenance.TruncateTable(tablename); } public void CreateTable(Type entityType) { _sqlSugar.CodeFirst.SetStringDefaultLength(200).BackupTable().InitTables(entityType); } public void CreateTable(Type[] entityTypes) { _sqlSugar.CodeFirst.SetStringDefaultLength(200).BackupTable().InitTables(entityTypes); } #endregion public virtual Task<bool> AnyAsync(Expression<Func<TEntity, bool>> exp) { return _sqlSugar.Queryable<TEntity>().AnyAsync(exp); } public virtual ISugarQueryable<TEntity> Query(Expression<Func<TEntity, bool>> exp) { return _sqlSugar.Queryable<TEntity>().Where(a => !a.IsDeleted).Where(exp); } public virtual ISugarQueryable<TDto> QueryDto(Expression<Func<TEntity, bool>> exp) { return _sqlSugar.Queryable<TEntity>().Where(a => !a.IsDeleted).Where(exp).Select<TDto>(); } public virtual Task<TDto> GetDtoAsync(Expression<Func<TEntity, bool>> exp) { return _sqlSugar.Queryable<TEntity>().Where(s => !s.IsDeleted).Where(exp).Select<TDto>().FirstAsync(); } public virtual Task<int> AddAsync(TEntity entity) { return _sqlSugar.Insertable(entity).ExecuteCommandAsync(); } public virtual Task<TEntity> GetAsync(Expression<Func<TEntity, bool>> exp) { return _sqlSugar.Queryable<TEntity>().FirstAsync(exp); } public virtual async Task<bool> DeleteAsync(Expression<Func<TEntity, bool>> wherexp) { var result = await _sqlSugar.Deleteable<TEntity>().Where(wherexp).ExecuteCommandAsync(); return result > 0; } public virtual async Task<bool> UpdateAsync(Expression<Func<TEntity, bool>> wherexp, Expression<Func<TEntity, TEntity>> upexp) { var result = await _sqlSugar.Updateable<TEntity>().Where(wherexp).SetColumns(upexp).ExecuteCommandAsync(); return result > 0; } public virtual async Task<bool> SoftDeleteAsync(string id) { var result = await _sqlSugar.Updateable<TEntity>().Where(a => a.Id.Equals(id)).SetColumns(a => new TEntity() { IsDeleted = true, DeleteTime = DateTime.Now }).ExecuteCommandAsync(); return result > 0; } public virtual async Task<bool> SoftDeleteAsync(Expression<Func<TEntity, bool>> wherexp) { var result = await _sqlSugar.Updateable<TEntity>().Where(wherexp).SetColumns(a => new TEntity() { IsDeleted = true, DeleteTime = DateTime.Now }).ExecuteCommandAsync(); return result > 0; } #region 泛型CRUD public virtual Task<bool> AnyAsync<T>(Expression<Func<T, bool>> exp) where T : EntityBase, new() { return _sqlSugar.Queryable<T>().Where(s => !s.IsDeleted).AnyAsync(exp); } public virtual Task<Dto> GetDtoAsync<T, Dto>(Expression<Func<T, bool>> exp) where T : EntityBase, new() { return _sqlSugar.Queryable<T>().Where(s => !s.IsDeleted).Where(exp).Select<Dto>().FirstAsync(); } public virtual ISugarQueryable<Dto> QueryDto<T, Dto>(Expression<Func<T, bool>> exp) where T : EntityBase, new() { return _sqlSugar.Queryable<T>().Where(a => !a.IsDeleted).Where(exp).Select<Dto>(); } public virtual Task<int> AddAsync<T>(T entity) where T : EntityBase, new() { return _sqlSugar.Insertable(entity).ExecuteCommandAsync(); } public virtual ISugarQueryable<T> Query<T>(Expression<Func<T, bool>> exp) where T : EntityBase, new() { return _sqlSugar.Queryable<T>().Where(s => !s.IsDeleted).Where(exp); } public virtual Task<T> GetAsync<T>(Expression<Func<T, bool>> exp) where T : EntityBase, new() { return _sqlSugar.Queryable<T>().Where(s => !s.IsDeleted).Where(exp).FirstAsync(); } public virtual async Task<bool> UpdateAsync<T>(Expression<Func<T, bool>> wherexp, Expression<Func<T, T>> upexp) where T : EntityBase, new() { var result = await _sqlSugar.Updateable<T>().Where(wherexp).SetColumns(upexp).ExecuteCommandAsync(); return result > 0; } public virtual async Task<bool> DeleteAsync<T>(Expression<Func<T, bool>> wherexp) where T : EntityBase, new() { var result = await _sqlSugar.Deleteable<T>().Where(wherexp).ExecuteCommandAsync(); return result > 0; } public virtual async Task<bool> SoftDeleteAsync<T>(string id) where T : EntityBase, new() { var result = await _sqlSugar.Updateable<TEntity>().Where(a => a.Id.Equals(id)).SetColumns(a => new TEntity() { IsDeleted = true, DeleteTime = DateTime.Now }).ExecuteCommandAsync(); return result > 0; } public virtual async Task<bool> SoftDeleteAsync<T>(Expression<Func<TEntity, bool>> wherexp) where T : EntityBase, new() { var result = await _sqlSugar.Updateable<TEntity>().Where(wherexp).SetColumns(a => new TEntity() { IsDeleted = true, DeleteTime = DateTime.Now }).ExecuteCommandAsync(); return result > 0; } #endregion } }
using NET6.Domain.Entities; using NET6.Domain.ViewModels; using SqlSugar; namespace NET6.Infrastructure.Repositories { public class AddressRepository : BaseRepository<Address, AddressView> { public AddressRepository(SqlSugarClient sqlSugar) : base(sqlSugar) { } } }
4、倉儲創建完畢,我們將其注入到項目中,使用Autofac能更方便的實現該功能,打開Nuget,搜索安裝Autofac。
5、打開Program.cs,添加如下代碼
#region 引入注冊Autofac builder.Host.UseServiceProviderFactory(new AutofacServiceProviderFactory()); var hostBuilder = builder.Host.ConfigureContainer<ContainerBuilder>(builder => { try { var assemblyServices = Assembly.Load("NET6.Infrastructure"); builder.RegisterAssemblyTypes(assemblyServices).Where(a => a.Name.EndsWith("Repository")).AsSelf(); } catch (Exception ex) { throw new Exception(ex.Message + "\n" + ex.InnerException); } }); #endregion
到此,Autofac便配置完成,NET6.Infrastructure項目中所有以Repository結尾的文件都會被注入到項目之中。