【.net core】【sqlsugar】联表查询与实体自动映射语法

本文介绍了如何在SqlSugar5x框架下,利用.NET进行联表查询(JoinTable)和LeftJoin操作,通过自动映射功能处理ClassA和ClassB之间的关系,并创建ViewClassB视图类。作者展示了使用SQLSUGAR语法进行条件筛选和全量字段选择的方法,最后通过ToListAsync获取数据。
摘要由CSDN通过智能技术生成

 官方文档:联表查询、关联查询、JoinTable、连表查询、Left Join - SqlSugar 5x - .NET果糖网

Join用法:语法糖2

Select 用法:自动映射

//类A 数据库字段与类成员一致
public class ClassA{
    //主键ID
    public int id{get;set;}
    //名称
    public string name{get;set;}
}
//类B 数据库字段与类成员一致
public class ClassB{
    //主键ID
    public int id{get;set;}
    //表A主键
    public int A_id{get;set;}
    //表B值
    public string value {get;set;}
}
//视图类B 继承ClassB,并增加子成员name(用于接收类A的name)
public class ViewClassB:ClassB{
    public string name{get;set;}
}

//使用SQLSUGAR语法进行查询
var query = db.Queryable<ClassB,ClassA>((a,b) => new JoinQueryInfos(
    JoinType.Left, a.A_id== b.id//以B为主表左连接A
    ))
    .Where(a => a.value != "")
    .Select((a, b) => new ViewClassB{
        //SelectAll为SqlSugar实体自动映射语法,使用实体中某一字段(类中任一成员)调用SelectAll进行实体自动映射
        //等于 sql中的 a.*   (SelectAll建议对一张表使用,多表会容易重名)
        value= a.value.SelectAll(),
        name = b.name
    } );

//获取列表数据
List<ViewClassB> viewList = await query.ToListAsync();

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
SQLSugar 是一款轻量级ORM框架,它支持自动生成实体类。在 .NET Core 中使用 SQLSugar 自动生成实体类的步骤如下: 1. 安装 SQLSugar 包:在 Visual Studio 中打开 NuGet 包管理器控制台,输入以下命令安装 SQLSugar 包: ``` Install-Package SqlSugar ``` 2. 配置数据库连接字符串:在 appsettings.json 文件中添加数据库连接字符串,例如: ``` "ConnectionStrings": { "DefaultConnection": "Server=localhost;Database=MyDatabase;User Id=myUsername;Password=myPassword;" } ``` 3. 创建实体类:在 Models 文件夹中创建一个类,例如: ``` public class User { public int Id { get; set; } public string Name { get; set; } public int Age { get; set; } } ``` 4. 自动生成实体类:在 Startup.cs 文件的 ConfigureServices 方法中添加以下代码: ``` services.AddScoped<ISqlSugarClient>(c => { var db = new SqlSugarClient(new ConnectionConfig() { ConnectionString = Configuration.GetConnectionString("DefaultConnection"), DbType = DbType.SqlServer, IsAutoCloseConnection = true, InitKeyType = InitKeyType.Attribute }); db.DbFirst.CreateClassFile("Models", "MyNamespace", "MyDatabase"); return db; }); ``` 这段代码会自动生成实体类文件,并保存到 Models 文件夹中。其中,MyNamespace 是你的命名空间,MyDatabase 是你的数据库名称。 5. 使用实体类:在控制器中注入 ISqlSugarClient,然后就可以使用自动生成的实体类了,例如: ``` public class UserController : ControllerBase { private readonly ISqlSugarClient _db; public UserController(ISqlSugarClient db) { _db = db; } [HttpGet] public IActionResult Get() { var users = _db.Queryable<User>().ToList(); return Ok(users); } } ``` 这段代码会查询 User 表中的所有数据,并返回给客户端。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值