SqlSugar有实体CURD应用-C#

news2024/10/5 6:44:07
  • 本文所述开发环境:.C#、NET8、Visual Studio2022

SqlSugar有实体查询数据表

首先根据《SqlSugar使用DbFirst对象根据数据库表结构创建实体类-C#》中的描述的表结构创建所有表的实体类如下:

表名创建的实体类名
tb_studentStudent
tb_teacherTeacher
tb_classCClass
tb_statusStatus
tb_subject_selectionSubjectSelection
以下通过将对应的 sql 语句转换为 SqlSugar 的语法方式经行讲解。了解更多可以查看SqlSugar官网

为了可以直观的看到SqlSugar语法最终执行的sql语句,可以使用如下代码,将Sql语句输出到控制台,调试的时候用的较多。

using (SqlSugarClient sugarClient = new(connectionConfig))
{
	sugarClient.Aop.OnLogExecuting = (s, p) =>
	{
	    Console.WriteLine("===================================");
	    Console.WriteLine($"Sql语句:{ s }");
	};
	// 接下来编辑执行的SqlSugar代码
}
1. 单表查询
  • 查询 tb_student表中的数据

Sql语句:select * from tb_student
代码如下:

List<Student> students = sugarClient.Queryable<Student>().ToList(); // list类型接收
// 或者
DataTable studentDT = sugarClient.Queryable<Student>().ToDataTable(); // DataTable类型接收

执行后控制台会输出对应的Sql语句,如下:
输出执行的sql语句
后面对于输出的语句不做再多的说明。

继续

Sql语句:select count(*) from tb_student
代码如下:

int nCount = sugarClient.Queryable<Student>().Count();

Sql语句:select top 1 * from tb_student
代码如下:

Student student = sugarClient.Queryable<Student>().First();
//或者
List<Student> student = sugarClient.Queryable<Student>().Take(1).ToList();

Sql语句:select top 10 * from tb_student
代码如下:

List<Student> student = sugarClient.Queryable<Student>().Take(10).ToList(); //和其它方法连用时, Task() 方法放在最后

Sql语句:select * from tb_student order by [身高]
代码如下:

List<Student> students = sugarClient.Queryable<Student>()
	.OrderBy("[身高]").ToList();
// 或者
List<Student> students = sugarClient.Queryable<Student>()
	.OrderBy(it=>it.身高).ToList();

Sql语句:select * from tb_student order by [身高] desc
代码如下:

List<Student> students = sugarClient.Queryable<Student>()
	.OrderBy("[身高] DESC").ToList();
// 或者
List<Student> students = sugarClient.Queryable<Student>()
	.OrderBy(it=>it.身高, OrderByType.Desc)
	.ToList();

Sql语句:select * from tb_student order by [年龄],[身高]
代码如下:

List<Student> students = sugarClient.Queryable<Student>()
	.OrderBy("[年龄]")
	.OrderBy("[身高]")
	.ToList();
//或者
List<Student> students = sugarClient.Queryable<Student>()
	.OrderBy("[年龄],[身高]").ToList();
//或者
List<Student> students = sugarClient.Queryable<Student>()
	.OrderBy(it=>new { it.年龄, it.身高})
	.ToList();

Sql语句:select * from tb_student order by [年龄] asc ,[身高] desc
代码如下:

List<Student> students = sugarClient.Queryable<Student>()
	.OrderBy(it=>new { it.年龄, 身高=SqlFunc.Desc(it.身高)})
	.ToList();
//或者
List<Student> students = sugarClient.Queryable<Student>()
	.OrderBy(it=>it.年龄)
	.OrderBy(it=>it.身高, OrderByType.Desc)
	.ToList();
// 或者
List<Student> students = sugarClient.Queryable<Student>()
	.OrderBy("[年龄], [身高] DESC")
	.ToList();

Sql语句:select 姓名,性别 from tb_student
代码如下:

List<Student> students = sugarClient.Queryable<Student>()
.Select("姓名,性别").ToList();
//或者
List<Student> students = sugarClient.Queryable<Student>()
.Select(it=>new { it.姓名, it.性别}).ToList();

Sql语句:select * from tb_student where 班级ID=1003
代码如下:

List<Student> students = sugarClient.Queryable<Student>()
	.Where(it=>it.班级ID==1003).ToList();
//或者
List<Student> students = sugarClient.Queryable<Student>()
	.Where("班级ID=1003").ToList();

Sql语句:select 姓名,性别 from tb_student where 班级ID=1003 and 身高>165
代码如下:

var students = sugarClient.Queryable<Student>()
	.Where(it=>it.班级ID == 1003)
	.Where(it=>it.身高 > 165)
	.Select(it=>new { it.姓名, it.性别}).ToList();
//或者
var students = sugarClient.Queryable<Student>()
	.Where("班级ID = @classid and 身高 > @high", new { classid = 1003, high = 165 })
	.Select("姓名, 性别").ToList();

Sql语句:select * from tb_subject_selection where 课程 like ‘%化学%’
代码如下:

List<SubjectSelection> subjectsels = sugarClient.Queryable<SubjectSelection>()
   .Where("课程 like '%化学%'")
   .ToList();
//或者
List<SubjectSelection> subjectsels = sugarClient.Queryable<SubjectSelection>()
   .Where(it=>it.课程.Contains("化学"))
   .ToList();

Sql语句:select * from tb_student where 状态ID in (2, 3)
代码如下:

List<Student> students = sugarClient.Queryable<Student>()
   .Where("状态ID in (2, 3)")
   .ToList();
//或者
List<Student> students = sugarClient.Queryable<Student>()
   .Where("状态ID in (@statuslist)", new { statuslist = new[] { 2, 3 } })
   .ToList();
//或者
var statuslist = new[] { 2, 3 };
List<Student> students = sugarClient.Queryable<Student>()
	.Where(it=> statuslist.Contains(it.状态ID))
	.ToList();
在实际的项目中存在这样一种情况:有一个工具类,类中的字段只有对应表中的几个字段,如果直接用表实体类查询的话,会获取到全部的字段,那么如何将实体类中的对应几个字段赋值给工具类呢。

比如,以下是一个学生的工具类:MiniStudent,在整个项目就只用到了:学生ID、姓名、班级ID三个字段。

public class MiniStudent
{
    public int Id { get; set; }
    public string Name { get; set; }
    public int Class { get; set; }
}

使用SqlSugar将查询结果的相关字段赋值给工具类,代码如下:

  • 方法一
List<MiniStudent> students = sugarClient.Queryable<Student>()
	.Select(it => new MiniStudent
	{
	     Id = it.学生ID,
	     Name = it.姓名,
	     Class = it.班级ID
	 }).ToList();

这种方式显然不是很好,为了得到MiniStudent,需要有一个实体类Student,感觉多此一举。

  • 方法二

直接将工具类MiniStudent绑定到tb_student表结构岂不是美哉。这种需要在MiniStudent类的上面添加SugarTable属性,并且类中的属性名都要是表中有的字段名
代码如下:

[SugarTable("tb_student")]
public class MiniStudent
{
    public int 学生ID { get; set; }
    public string 姓名 { get; set; }
    public int 班级ID { get; set; }
}

List<MiniStudent> miniStudents = sugarClient.Queryable<MiniStudent>().ToList();

这种相对好一点,但是有一个问题,假如类的属性名就是想用英文的怎么办,能否实现sql语句中的 AS 语法的功能呢。例如:

select 学生ID as Id, 姓名 as Name, 班级ID as Class from tb_student

  • 方法三

在实体类中使用字段属性 [SugarColumn(ColumnName = “xxxx”)],这个意思就是告诉SqlSugar,要将表中的哪个字段赋值给实体类中的修饰属性字段。代码如下:

[SugarTable("tb_student")]
public class MiniStudent
{
    [SugarColumn(ColumnName = "学生ID")]
    public int Id { get; set; }

    [SugarColumn(ColumnName = "姓名")]
    public string Name { get; set; }

    [SugarColumn(ColumnName = "班级ID")]
    public int Class { get; set; }
}

List<MiniStudent> miniStudents = sugarClient.Queryable<MiniStudent>().ToList();

上面这样就可以了,属性SugarColumn告诉SqlSugar:

  • 将表字段 学生ID 的内容赋值给 Id 类字段
  • 将表字段 姓名 的内容赋值给 Name 类字段
  • 将表字段 班级ID 的内容赋值给 Class 类字段
另一种情况:实体类中除了表字段对应的属性字段,还有一些不是表字段中对应的属性,而这些属性又是要用到的,如果还是像上面一样查询就是异常。

例如:还是工具类MiniStudent,但是定义如下:

[SugarTable("tb_student")]
public class MiniStudent
{
    [SugarColumn(ColumnName = "学生ID")]
    public int Id { get; set; }

    [SugarColumn(ColumnName = "姓名")]
    public string Name { get; set; }

    [SugarColumn(ColumnName = "班级ID")]
    public int Class { get; set; }

    public string strKey { get; set; }
}

类中多了一个 strKey 的属性字段,这个属性并不是从表中查询获取,但后续代码又会用到,那能不能忽略这个属性字段进行查询呢?答案是肯定的,只需要将要忽略查询的字段加上属性 [SugarColumn(IsIgnore = true)] 即可,代码如下:

[SugarTable("tb_student")]
public class MiniStudent
{
    [SugarColumn(ColumnName = "学生ID")]
    public int Id { get; set; }

    [SugarColumn(ColumnName = "姓名")]
    public string Name { get; set; }

    [SugarColumn(ColumnName = "班级ID")]
    public int Class { get; set; }

    [SugarColumn(IsIgnore = true)]
    public string strKey { get; set; }
}

List<MiniStudent> miniStudents = sugarClient.Queryable<MiniStudent>().ToList();

再谈一种情况:给实体类和类中每个属性字段都加上SqlSugar的字段属性标签太麻烦了,不想这样,能不能直接用SqlSugar的方法实现?答案也是肯定的。

例如:MiniStudent 类定义如下:

public class MiniStudent
{
    public int Id { get; set; }

    public string Name { get; set; }

    public int Class { get; set; }

    public string strKey { get; set; }
}
// 可以用以下方法实现
List<MiniStudent> students = sugarClient.Queryable<MiniStudent>()
    .AS("tb_student") // 指定要查的表名
    .IgnoreColumns(it=>it.strKey)  // 指定实体类中要忽略的属性字段
    .Select("学生ID as Id, 姓名 as Name, 班级ID as Class") // 指定表字段别名
    .ToList();

2. 多表查询

Sql语句:select 班级名称, 姓名 as 班主任 from tb_class a left join tb_teacher b on a.班主任 = b.教师ID
代码如下:

var result = sugarClient.Queryable<CClass>()
	.LeftJoin<Teacher>((a, b) => a.班主任 == b.教师ID)
	.Select((a, b) => new { a.班级名称, 班主任 = b.姓名 })
	.ToList();
// 或者
var queryable = sugarClient.Queryable<CClass>();
var result = sugarClient.Queryable(queryable)
	.LeftJoin<Teacher>((a, b) => a.班主任 == b.教师ID)
	.Select((a, b) => new { a.班级名称, 班主任 = b.姓名 })
	.ToDataTable();

RightJoin与LeftJoin一样,两个表以上的联合查询也类似,不断的连接起来就可以了。

SqlSugar有实体增加表中数据

  • 向表tb_student中插入一行新的记录

代码如下

Student newstudent = new Student()
{
    学生ID = 110,
    姓名 = "黄同学",
    班级ID = 1002,
    状态ID = 1,
    性别 = "男",
    年龄 = 30,
    身高 = 175,
    体重 = 69
};

int insertnum = sugarClient.Insertable(newstudent).ExecuteCommand(); // 返回插入的行数

  • 批量插入多条数据
List<Student> newStudents = [];

for (int i = 0; i < 10; i++)
{
    Student newstudent = new Student()
    {
        学生ID = 111 + i,
        姓名 = $"黄同学{i}",
        班级ID = 1002,
        状态ID = 1,
        性别 = i>5?"男":"女",
        年龄 = 30 + i,
        身高 = 175 + i / 10.0,
        体重 = 69 + i / 10.0
    };

    newStudents.Add(newstudent);
}

int insertnum = sugarClient.Insertable(newStudents).ExecuteCommand(); // 返回插入的行数

SqlSugar有实体更新表中数据

  • 更新表中单个字段

Sql语句:update tb_student set 班级ID=1001 where 学生ID=109
代码如下:

sugarClient.Updateable<Student>()
	.SetColumns(it=>it.班级ID == 1001) // 注意:这里也是两个等号
	.Where(it=>it.学生ID == 109)
	.ExecuteCommand();
  • 跟新表中多个字段

Sql语句:update tb_student set 班级ID=1001, 状态ID=3 where 学生ID=109

sugarClient.Updateable<Student>()
	.SetColumns(it=>it.班级ID == 1001) // 注意:这里也是两个等号
	.SetColumns(it=>it.状态ID == 3)
	.Where(it=>it.学生ID == 109)
	.ExecuteCommand();
// 或者
sugarClient.Updateable<Student>()
	.SetColumns(it=> new Student() { 班级ID = 1002, 状态ID = 2 }) // 注意:这里也是两个等号
	.Where(it=>it.学生ID == 109)
	.ExecuteCommand();

SqlSugar有实体删除表中数据

  • 删除符合条件的记录

Sql语句:delete from tb_student where 学生ID=120
代码如下:

sugarClient.Deleteable<Student>(it=>it.学生ID == 120).ExecuteCommand();
// 或者
sugarClient.Deleteable<Student>(new Student() { 学生ID=120}).ExecuteCommand();
  • 清空表记录

Sql语句:truncate table tb_student
代码如下:

sugarClient.DbMaintenance.TruncateTable<Student>();

好了,分享到这里,感谢翻阅,希望帮到你。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1819371.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

在Lua解释器中注册自定义函数库

本文目录 1、引言2、注册原理3、实例4、程序验证 文章对应视频教程&#xff1a; 暂无&#xff0c;可以关注我的B站账号等待更新。 点击图片或链接访问我的B站主页~~~ 1、引言 在现代软件开发中&#xff0c;Lua因其轻量级、高效和可嵌入性而被广泛使用。作为一种灵活的脚本语言…

(五)React受控表单、获取DOM

1. React受控表单 概念&#xff1a;使用React组件的状态&#xff08;useState&#xff09;控制表单的状态 准备一个React状态值 const [value, setValue] useState()通过value属性绑定状态&#xff0c;通过onChange属性绑定状态同步的函数 <input type"text"…

STL入门指南:从容器到算法的完美结合

目录 ​编辑 一、什么是STL 二、STL的版本 三、STL的六大组件 1. 容器&#xff08;Containers&#xff09;&#xff1a; 2. 算法&#xff08;Algorithms&#xff09;&#xff1a; 3. 迭代器&#xff08;Iterators&#xff09;&#xff1a; 4. 仿函数&#xff08;Functo…

群晖NAS安装配置Joplin Server用来存储同步Joplin笔记内容

一、Joplin Server简介 1.1、Joplin Server介绍 Joplin支持多种方式进行同步用户的笔记数据&#xff08;如&#xff1a;Joplin自己提供的收费的云服务Joplin Cloud&#xff0c;还有第三方的云盘如Dropbox、OneDrive&#xff0c;还有自建的云盘Nextcloud、或者通过WebDAV协议来…

我的高考往事

高考对于每一个参加过的人来说&#xff0c;都是一段非常难忘的回忆。 我参加高考&#xff0c;是在2001年。虽然迄今已经过去了23年&#xff0c;但很多细节仍然记忆犹新。 今天这篇文章&#xff0c;我就和大家分享一下&#xff0c;我的高考往事。 █ 青少年时代 我的老家是在江西…

波拉西亚战记加速器 台服波拉西亚战记免费加速器

波拉西亚战记是一款新上线的MMORPG游戏&#xff0c;游戏内我们有多个角色职业可以选择&#xff0c;可以体验不同的战斗流派玩法&#xff0c;开放式的地图设计&#xff0c;玩家可以自由的进行探索冒险&#xff0c;寻找各种物资。各种随机事件可以触发&#xff0c;让玩家的冒险过…

OZON芒果店长erp,OZON平台支持什么ERP

在跨境电商的浪潮中&#xff0c;OZON平台凭借其独特的优势&#xff0c;吸引了众多卖家入驻。然而&#xff0c;随着业务规模的不断扩大&#xff0c;如何高效管理商品、处理订单、优化仓储物流等成为了卖家们亟需解决的问题。此时&#xff0c;一款强大的ERP&#xff08;企业资源规…

第19篇 Intel FPGA Monitor Program的使用<二>

Q&#xff1a;Intel FPGA Monitor Program里集成的Computer System是什么架构的呢&#xff1f; A&#xff1a;我们以DE2-115的DE2-115_Computer System为例介绍&#xff0c;简单说DE2-115_Computer System就是一个Qsys系统&#xff0c;该系统包含Nios II处理器以及DE2-115开发…

不停“整活”的零食很忙,怎么就跨入万店时代了?

6月12日&#xff0c;合并后的零食很忙、赵一鸣零食宣布&#xff0c;全国门店总数已突破10000家。同时&#xff0c;集团名称也变更为鸣鸣很忙集团。根据第三方机构弗若斯特沙利文认证&#xff0c;鸣鸣很忙集团全国门店数位居零食连锁行业第一。 在此之前&#xff0c;尽管零食很…

8个宝藏级物联网平台推荐

随着物联网技术的飞速发展&#xff0c;越来越多的企业开始寻求高效、可靠的物联网平台来实现设备连接、数据收集和智能分析。以下是8个宝藏级的物联网平台推荐&#xff0c;它们以其独特的功能和优势&#xff0c;帮助企业加速数字化转型。 1. ThingsKit物联网平台 ThingsKit 是…

windows 11中如何设置默认为英文输入法

由于工作需要&#xff0c;我一直在windows7下使用VB6&#xff0c;以前尝试着使用新的系统&#xff0c;但都无法正常安装vb&#xff0c;最近几天由于系统一次作死操作&#xff0c;逼着我安装了win11&#xff0c;并且在其上正常安装了vb6&#xff0c;本想着十分高兴&#xff0c;终…

垂直业务系统权限设计

遵循 RBAC 的原则&#xff0c;以更贴近日常工作的业务处理流程&#xff0c;设计一套与总公司分公司相吻合的组织、部门、岗位结构&#xff0c;配套可以继承的权限组和特定的岗位权限&#xff0c;实现系统授权的操作简化和权限的集成应用简化。 RBAC&#xff08;Role-Based Acce…

C++中的结构体——结构体指针

作用&#xff1a;通过指针访问结构体中的成员 利用操作符 -> 可以通过结构体指针访问结构体属性 示例 运行结果

新研究使VQE算法成功扩展到12个量子比特,误差抑制在两个数量级

量子计算化学已成为量子计算的一个潜在应用领域。 混合量子-经典计算方法&#xff0c;如变分量子本征求解器&#xff0c;已被设计为解决量子化学问题有希望的解决方案。但该计算方法面对着因理论复杂性和实验不完善所带来的挑战&#xff0c;在实现可靠和准确结果方面被限制。因…

史上最全盘点:一文告诉你什么是erp?erp系统厂商分别有哪些?

✅ 什么是ERP&#xff1f; ERP是Enterprise Resource Planning&#xff08;企业资源计划&#xff09;的简称&#xff0c;ERP是针对物资资源管理&#xff08;物流&#xff09;、人力资源管理&#xff08;人流&#xff09;、财务资源管理&#xff08;资金流&#xff09;、信息资…

东胜物流软件 GetProParentModuTreeList SQL注入漏洞复现

0x01 产品简介 东胜物流软件是青岛东胜伟业软件有限公司一款集订单管理、仓库管理、运输管理等多种功能于一体的物流管理软件。该公司初创于2004年11月(前身为青岛景宏物流信息技术有限公司),专注于航运物流相关环节的产品和服务。东胜物流信息管理系统货代版采用MS-SQLser…

LeetCode刷题之HOT100之验证二叉搜索树

1、题目描述 2、逻辑分析 要求给定的根节点是否是有效的二叉树。有效的二叉搜索树定义如上。那么如何求解呢&#xff1f;题解给出了两张求解方法&#xff1a;递归、中序遍历。这边倾向于中序遍历&#xff0c;中序遍历后的二叉树是升序排序的&#xff0c;以这个性质即可解题。 …

【GD32】 TIMER通用定时器学习+PWM输出占空比控制LED

扩展&#xff1a;PWM波形输出捕获 这里写目录标题 一、简介二、具体功能描述1、时钟源的选择&#xff1a;2、预分频器&#xff1a;3、计数模式&#xff1a;向上计数模式&#xff1a;向下计数模式&#xff1a;中央对齐模式&#xff1a; 4、捕获/比较通道 输入捕获模式 输出…

辽宁普通测径仪升级智能测径仪后都有哪些改进?

关键字: 普通测径仪, 智能测径仪, 测径仪升级, 测径仪特点, 智能测径仪优势, 目前多数厂家测径仪的数据处理方式是单片机计算出最终结果&#xff0c;然后传输到工控机后期处理。这样的电路系统对轧钢现场的高温、高粉尘和强电磁干扰的环境适应性很差&#xff0c;使得同一厂家、…

node 版本控制

官网下载 nvm 包 查看node和npm版本&#xff1a;https://github.com/coreybutler/nvm-windows/releases 2、查看nvm是否安装成功 nvm3、基本使用 1、查看当前node可用版本 nvm ls2、查看当前使用的node版本 nvm current3、安装指定node版本 nvm install 19.9.04、切换版…