C#使用SqlSugarClient進(jìn)行數(shù)據(jù)訪問并實(shí)現(xiàn)了統(tǒng)一的批量依賴注入(示例代碼)
倉儲層當(dāng)前有接口 IRepository<T> 抽象類 BaseRepository<T> 業(yè)務(wù)邏輯層有抽象類 BaseBusiness<M, E> 接口 IBusiness<M, E>,其中使用ISqlSugarClient,其中還有E表示 BaseEntity,M為 BaseDto 請用C# 給出一個案例,支持不同表對應(yīng)不同的業(yè)務(wù)邏輯層,然后不同倉儲實(shí)例,不同表的業(yè)務(wù),都實(shí)現(xiàn)統(tǒng)一的批量依賴注入。
以下是一個更新后的C#示例,演示了如何使用ISqlSugarClient進(jìn)行數(shù)據(jù)訪問,并實(shí)現(xiàn)了統(tǒng)一的批量依賴注入:
using System; using System.Collections.Generic; using SqlSugar; // 實(shí)體類 public class BaseEntity { [SugarColumn(IsPrimaryKey = true, IsIdentity = true)] public int Id { get; set; } // 其他實(shí)體屬性... } public class ProductEntity : BaseEntity { public string Name { get; set; } // 其他產(chǎn)品實(shí)體屬性... } public class CustomerEntity : BaseEntity { public string FirstName { get; set; } public string LastName { get; set; } // 其他客戶實(shí)體屬性... } // 數(shù)據(jù)傳輸對象(DTO) public class BaseDto { // 公共DTO屬性... } public class ProductDto : BaseDto { public string Name { get; set; } // 其他產(chǎn)品DTO屬性... } public class CustomerDto : BaseDto { public string FirstName { get; set; } public string LastName { get; set; } // 其他客戶DTO屬性... } // 倉儲層 public interface IRepository<T> { void Add(T entity); void Update(T entity); void Delete(T entity); T GetById(int id); // 其他倉儲操作方法... } public abstract class BaseRepository<T> : IRepository<T> where T : BaseEntity { protected readonly ISqlSugarClient _db; public BaseRepository(ISqlSugarClient db) { _db = db; } public void Add(T entity) { _db.Insertable(entity).ExecuteCommand(); } public void Update(T entity) { _db.Updateable(entity).ExecuteCommand(); } public void Delete(T entity) { _db.Deleteable<T>().In(entity.Id).ExecuteCommand(); } public T GetById(int id) { return _db.Queryable<T>().InSingle(id); } // 其他倉儲操作方法的實(shí)現(xiàn)... } // 業(yè)務(wù)邏輯層 public interface IBusiness<M, E> where M : BaseDto where E : BaseEntity { void Process(M model); // 其他業(yè)務(wù)邏輯方法... } public abstract class BaseBusiness<M, E> : IBusiness<M, E> where M : BaseDto where E : BaseEntity { protected readonly IRepository<E> _repository; public BaseBusiness(IRepository<E> repository) { _repository = repository; } public abstract void Process(M model); // 其他業(yè)務(wù)邏輯方法... } // 具體業(yè)務(wù)邏輯類 public class ProductBusiness : BaseBusiness<ProductDto, ProductEntity> { public ProductBusiness(IRepository<ProductEntity> repository) : base(repository) { } public override void Process(ProductDto model) { // 實(shí)現(xiàn)產(chǎn)品業(yè)務(wù)邏輯 Console.WriteLine("Processing product: " + model.Name); } } public class CustomerBusiness : BaseBusiness<CustomerDto, CustomerEntity> { public CustomerBusiness(IRepository<CustomerEntity> repository) : base(repository) { } public override void Process(CustomerDto model) { // 實(shí)現(xiàn)客戶業(yè)務(wù)邏輯 Console.WriteLine("Processing customer: " + model.FirstName + " " + model.LastName); } } // 批量依賴注入容器 public class DependencyInjector { private readonly ISqlSugarClient _db; public DependencyInjector(ISqlSugarClient db) { _db = db; } public IEnumerable<BaseBusiness<M, E>> ResolveBusinesses<M, E>() where M : BaseDto where E : BaseEntity { var repositoryType = typeof(IRepository<E>); var businessType = typeof(IBusiness<M, E>); var assemblies = AppDomain.CurrentDomain.GetAssemblies(); var businessTypes = new List<Type>(); foreach (var assembly in assemblies) { var types = assembly.GetTypes(); foreach (var type in types) { if (type.BaseType != null && type.BaseType.IsGenericType) { var baseType = type.BaseType.GetGenericTypeDefinition(); if (baseType == businessType) { businessTypes.Add(type); } } } } foreach (var businessTypeItem in businessTypes) { var repositoryGenericType = repositoryType.MakeGenericType(businessTypeItem.GetGenericArguments()); var repository = Activator.CreateInstance(repositoryGenericType, _db); var business = Activator.CreateInstance(businessTypeItem, repository); yield return (BaseBusiness<M, E>)business; } } } // 使用示例 class Program { static void Main(string[] args) { // 模擬ISqlSugarClient的實(shí)例 var db = new SqlSugarClient(new ConnectionConfig() { ConnectionString = "YourConnectionString", DbType = DbType.SqlServer, IsAutoCloseConnection = true, }); // 實(shí)例化依賴注入容器 var injector = new DependencyInjector(db); // 解析并實(shí)例化業(yè)務(wù)邏輯類 var businesses = injector.ResolveBusinesses<BaseDto, BaseEntity>(); // 使用業(yè)務(wù)邏輯類進(jìn)行操作 foreach (var business in businesses) { // 處理業(yè)務(wù)邏輯 business.Process(new ProductDto { Name = "Sample Product" }); business.Process(new CustomerDto { FirstName = "John", LastName = "Doe" }); } } }
到此這篇關(guān)于C#使用SqlSugarClient進(jìn)行數(shù)據(jù)訪問并實(shí)現(xiàn)了統(tǒng)一的批量依賴注入(示例代碼)的文章就介紹到這了,更多相關(guān)SqlSugarClient批量依賴注入內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
淺析C#中的Main(String[] args)參數(shù)輸入問題
本篇文章主要是對C#中的Main(String[] args)參數(shù)輸入問題進(jìn)行了詳細(xì)的介紹,需要的朋友可以過來參考下,希望對大家有所幫助2014-01-01Unity通用泛型單例設(shè)計模式(普通型和繼承自MonoBehaviour)
這篇文章主要介紹了Unity通用泛型單例設(shè)計模式,分為普通型和繼承MonoBehaviour,幫助大家更好的理解和學(xué)習(xí),感興趣的朋友可以了解下2020-07-07.NET操作NPOI實(shí)現(xiàn)Excel的導(dǎo)入導(dǎo)出
NPOI是指構(gòu)建在POI 3.x版本之上的一個程序,NPOI可以在沒有安裝Office的情況下對Word或Excel文檔進(jìn)行讀寫操作,下面小編為大家介紹了如何操作NPOI實(shí)現(xiàn)Excel的導(dǎo)入導(dǎo)出,需要的可以參考一下2023-09-09C#字符串與數(shù)值類型、字節(jié)數(shù)組的互相轉(zhuǎn)換實(shí)戰(zhàn)案例
最近由于編程的需要,對C#的類型轉(zhuǎn)換做了一些研究,下面這篇文章主要給大家介紹了關(guān)于C#字符串與數(shù)值類型、字節(jié)數(shù)組的互相轉(zhuǎn)換的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-06-06C#編程中使用設(shè)計模式中的原型模式的實(shí)例講解
這篇文章主要介紹了C#編程中使用設(shè)計模式中的原型模式的實(shí)例講解,原型模式創(chuàng)建新對象方便快捷,而且可在運(yùn)行時根據(jù)需要通過克隆來添加和去除他們,也可在程序運(yùn)行是根據(jù)情況來修改類內(nèi)部的數(shù)據(jù),需要的朋友可以參考下2016-02-02