不使用ORM的ABP
创始人
2024-12-29 05:00:01
0

在ABP框架中,ORM(对象关系映射)是一种常用的数据访问方式。但是如果你想在ABP中不使用ORM,可以使用Dapper、ADO.NET或者原生SQL语句来实现数据访问。

以下是一个使用Dapper实现数据访问的示例:

  1. 首先,创建一个接口来定义数据访问的方法:
public interface IMyRepository
{
    Task> GetAllAsync();
    Task GetAsync(int id);
    Task CreateAsync(MyEntity entity);
    Task UpdateAsync(MyEntity entity);
    Task DeleteAsync(int id);
}
  1. 创建一个实现该接口的类,使用Dapper来实现数据访问逻辑:
public class MyRepository : IMyRepository
{
    private readonly IDbConnection _dbConnection;
    
    public MyRepository(IDbConnection dbConnection)
    {
        _dbConnection = dbConnection;
    }
    
    public async Task> GetAllAsync()
    {
        var sql = "SELECT * FROM MyEntities";
        return (await _dbConnection.QueryAsync(sql)).ToList();
    }
    
    public async Task GetAsync(int id)
    {
        var sql = "SELECT * FROM MyEntities WHERE Id = @Id";
        return await _dbConnection.QueryFirstOrDefaultAsync(sql, new { Id = id });
    }
    
    public async Task CreateAsync(MyEntity entity)
    {
        var sql = "INSERT INTO MyEntities (Name) VALUES (@Name)";
        await _dbConnection.ExecuteAsync(sql, entity);
    }
    
    public async Task UpdateAsync(MyEntity entity)
    {
        var sql = "UPDATE MyEntities SET Name = @Name WHERE Id = @Id";
        await _dbConnection.ExecuteAsync(sql, entity);
    }
    
    public async Task DeleteAsync(int id)
    {
        var sql = "DELETE FROM MyEntities WHERE Id = @Id";
        await _dbConnection.ExecuteAsync(sql, new { Id = id });
    }
}
  1. 注册该Repository类到ABP的依赖注入系统中:
public override void ConfigureServices(ServiceConfigurationContext context)
{
    // ...
    Configure(options =>
    {
        options.ConnectionStrings.Default = "YourDbConnectionString";
    });
    // ...
    
    context.Services.AddTransient();
}

现在,你可以在应用程序的其他地方通过依赖注入来使用刚刚创建的IMyRepository接口,而无需使用ORM。例如:

public class MyApplicationService : ApplicationService
{
    private readonly IMyRepository _myRepository;
    
    public MyApplicationService(IMyRepository myRepository)
    {
        _myRepository = myRepository;
    }
    
    public async Task> GetAllAsync()
    {
        var entities = await _myRepository.GetAllAsync();
        return ObjectMapper.Map, List>(entities);
    }
    
    // other methods...
}

相关内容

热门资讯

5分钟总结!永州扯胡子到底有没... 5分钟总结!永州扯胡子到底有没有外 挂,wpk微扑克真的有辅助插件(详细透视辅助黑科技教程);实战中...
3分钟教学!非常麻将发牌规律,... 1、3分钟教学!非常麻将发牌规律,aa扑克软件(详细透视辅助挂教程)。2、非常麻将发牌规律透视辅助简...
2分钟教程!中至棋牌麻将,we... 中至棋牌麻将赢率提升策略‌;2分钟教程!中至棋牌麻将,wepoke系统(详细透视辅助脚本教程);详细...
8分钟透明!丽水都莱罗松,aa... 8分钟透明!丽水都莱罗松,aapoker有猫腻(详细透视辅助挂教程)准备好在丽水都莱罗松 ia的高塔...
9分钟总结!白金岛放炮罚有挂吗... 9分钟总结!白金岛放炮罚有挂吗,红龙扑克是真正规的(详细透视辅助软件教程) 科技详细教程;75744...
八分钟教程!广西老友玩游戏辅助... 八分钟教程!广西老友玩游戏辅助器,德扑ai软件(详细透视辅助app教程);广西老友玩游戏辅助器软件透...
七分钟教程!多乐跑胡子有挂吗,... 七分钟教程!多乐跑胡子有挂吗,德扑之星真的有辅(详细透视辅助黑科技教程);多乐跑胡子有挂吗软件透明挂...
7分钟黑科技!微信斗地主小程序... 7分钟黑科技!微信斗地主小程序有挂吗,德州app辅助器(详细透视辅助工具教程)是一款可以让一直输的玩...
4分钟教学!雀神麻将功能,云扑... 4分钟教学!雀神麻将功能,云扑克内置辅助器(详细透视辅助软件教程);值得一提的是,雀神麻将功能计算辅...
3分钟介绍!吉祥三公外挂,微扑... 1、3分钟介绍!吉祥三公外挂,微扑克有后台控制(详细透视辅助脚本教程);该软件可以轻松地帮助玩家将吉...