SqlSugar有实体CURD应用-C#

  • 本文所述开发环境:.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.mfbz.cn/a/727442.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

IOS逆向分析—终极详细(三)

IOS逆向分析—终极详细&#xff08;三&#xff09; 前言一、逆向分析是什么&#xff1f;二、IDA分析1.下载并安装IDA2.安装插件3.加载二进制4.代码分析5.其它 总结 前言 本文是个人完成对IOS上APP分析的整个过程&#xff0c;当然对于不同的机型还会遇到不同的情况&#xff0c;谨…

NSSCTF-Web题目8

目录 [LitCTF 2023]Http pro max plus 1、题目 2、知识点 3、思路 [NSSCTF 2022 Spring Recruit]babyphp 1、题目 2、知识点 3、思路 [LitCTF 2023]Http pro max plus 1、题目 2、知识点 http数据包头部字段 3、思路 打开题目 第一想法就是加上X-forwarded-for字段 …

【BES2500x系列 -- RTX5操作系统】CMSIS-RTOS RTX -- 实时操作系统的核心,为嵌入式系统注入活力 --(一)

&#x1f48c; 所属专栏&#xff1a;【BES2500x系列】 &#x1f600; 作  者&#xff1a;我是夜阑的狗&#x1f436; &#x1f680; 个人简介&#xff1a;一个正在努力学技术的CV工程师&#xff0c;专注基础和实战分享 &#xff0c;欢迎咨询&#xff01; &#x1f49…

显卡nvidia的CUDA和cuDNN的安装

显卡版本&#xff0c;和nvidia下载的 CUDA版本和CUDNN的关系 1. 显卡版本 nvidia-smi 硬件环境&#xff1a;显卡版本 4090 NVIDIA-SMI-555.85 我的驱动是510.85.02&#xff0c;驱动附带cuda12.5 2. nvidia下载的cuda版本 nvcc -V 我下载的是cuda12.5 cuda在安装版本过程…

使用宝塔面板搭建Flask项目保姆级喂饭教程

目录 零.前言 一.准备工作 1.1创建requirements.txt文件 1.2将项目打包为压缩文件 1.3租一台服务器 1.4部署宝塔面板 二.宝塔面板(服务器)上的操作 2.1将本地Flask项目上传到服务器 2.2添加Python项目 2.3配置Python项目 2.4配置Nginx 2.5宝塔面板放行端口 2.6在服…

CoRR和arXiv

CoRR和arXiv到底是什么&#xff1f;_corr期刊-CSDN博客文章浏览阅读1.4w次&#xff0c;点赞8次&#xff0c;收藏10次。提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档CoRR和arXiv到底是什么文章目录一、arXiv二、CoRR前言 a…

性能测试-性能监控分析与调优(三)《实战》

性能监控 使用命令监控 cpu瓶颈分析 top命令 在进行性能测试时使用top命令&#xff0c;界面如下 上图可以看出 CPU 概况区&#xff1a; %Cpu(s): us&#xff08;用户进程占用CPU的百分比&#xff09;, 和 sy&#xff08;系统进程占用CPU的百分比&#xff09; 的数值很高…

【Unity设计模式】状态编程模式

前言 最近在学习Unity游戏设计模式&#xff0c;看到两本比较适合入门的书&#xff0c;一本是unity官方的 《Level up your programming with game programming patterns》 ,另一本是 《游戏编程模式》 这两本书介绍了大部分会使用到的设计模式&#xff0c;因此很值得学习 本…

通过git命令查询某个用户提交信息

要查询某个用户通过 Git 提交了多少行代码&#xff0c;可以使用以下步骤和命令来实现。这些命令将统计该用户的添加和删除的代码行数。 1、切换到你的 Git 仓库&#xff1a; cd /path/to/your/repositorygit命令结果&#xff1a; 2、查询所有用户&#xff1a; git log --pr…

原子性(juc编程)

原子性 概述&#xff1a;所谓的原子性是指在一次操作或者多次操作中&#xff0c;要么所有的操作全部都得到了执行并且不会受到任何因素的干扰而中断&#xff0c;要么所有的操作都不执行&#xff0c;多个操作是一个不可以分割的整体。 //比如说&#xff1a;你喂你女朋友吃冰淇…

SOFTS: Efficient Multivariate Time Series Forecasting with Series-Core Fusion

SOFTS: Efficient Multivariate Time Series Forecasting with Series-Core Fusion 文章目录 SOFTS: Efficient Multivariate Time Series Forecasting with Series-Core Fusion1. 论文背景1.1 通道独立-通道依赖的区别1.2 论文贡献 2. 模型架构2.1 SOFTS的主要架构2.2 STAR 模…

《QT实用小工具·七十一》基于Qt+Qml开发的文件传输工具

1、概述 源码放在文章末尾 该项目基于QTQML实现了文件传输的功能&#xff0c;可以在局域网环境下使用(热点)&#xff0c;扫描使用UDP&#xff0c;传输使用TCP&#xff0c;每一个文件传输使用独立的线程进行处理&#xff0c;高效便捷。 开发环境 使用Qt/Qml开发 QT版本&#x…

搭建开发模式下的以太坊私有链【Geth:1.14.5】

一、为什么用到私有链&#xff1f; 在以太坊的公有链上部署智能合约、发起交易需要花费以太币。而通过修改配置&#xff0c;可以在本机搭建一套以太坊私有链&#xff0c;因为与公有链没关系&#xff0c;既不用同步公有链庞大的数据&#xff0c;也不用花钱购买以太币&#xff0…

Mybatis中BaseEntity作用

新建各种对象的时候&#xff0c;一般来说&#xff0c;有几个属性是所有对象共有的&#xff0c;比如说id,is_del&#xff0c;is_enable这些&#xff0c;然后设置一个基础对象&#xff0c;以后新建所有对象的时候都继承它&#xff0c;就省的每次都要写这些共有的属性了

生育是家庭和个人的重要的选择

生育是个人和家庭的重要选择&#xff0c;而国家对于生育政策的制定应该综合考虑多种因素&#xff0c;包括人口结构、经济发展和社会稳定等。同时&#xff0c;我们也应该认识到&#xff0c;男女不应该成为决定一个人是否能够生育的因素。男女在生育中扮演着不同的角色&#xff0…

在Maven工程中手动配置并测试SpringBoot(巨详)

本篇博客承继自博客&#xff1a; 在IDEA 2024.1.3 (Community Edition)中创建Maven项目_idea2024.1.3如何创建maven项目-CSDN博客 配置POM文件 打开工程中的pom.xml文件&#xff0c;先向其中写入 <parent><groupId>org.springframework.boot</groupId><…

【总线】AXI4第三课时:握手机制

大家好,欢迎来到今天的总线学习时间!如果你对电子设计、特别是FPGA和SoC设计感兴趣&#xff0c;那你绝对不能错过我们今天的主角——AXI4总线。作为ARM公司AMBA总线家族中的佼佼者&#xff0c;AXI4以其高性能和高度可扩展性&#xff0c;成为了现代电子系统中不可或缺的通信桥梁…

Java面向对象的三大特性之一——继承

目录 一、继承概念 二、为什么要继承 三、继承语法&#xff08;关键字extends&#xff09; 四、父类成员访问 1、子类中访问父类的成员变量 &#xff08;1&#xff09;子类和父类不存在同名的成员变量 &#xff08;2&#xff09;子类和父类中存在同名的成员变量 2、子类中访…

Transformer学习理解

1.前言 本文介绍当下人工智能领域的基石与核心结构模型——Transformer&#xff0c;为什么说它是基石&#xff0c;因为以ChatGPT为代表的聊 天机器人以及各种有望通向AGI&#xff08;通用人工智能&#xff09;的道路上均在采用的Transformer。 Transformer也是当下NLP任…

基于PCL实现多边形框选点云并进行裁剪(附C++源码)

文章目录 一.算法效果二.算法原理PNPoly算法直线相交性判断三.代码实现一.算法效果 通过在PCL可视化界面上绘制2D封闭多边形来提取位于该封闭多边形内部或者外部的 的点,算法效果如下: 图1多边形裁剪点云效果图 二.算法原理 PNPoly算法 2D多边形框选裁剪点云,实际上可以简…