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.rhkb.cn/news/349381.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

linux的UDP广播测试:C语言代码

测试代码 #include <stdio.h> #include <stdlib.h> #include <string.h> #include <unistd.h> #include <sys/types.h> #include <sys/socket.h> #include <netinet/in.h> #include <arpa/inet.h> #include <netdb.h>#…

MyEclipse新手使用介绍

目录 1.MyEclipse诞生背景 2.作用 3.版本历史 4.优缺点 5.应用场景 6.如何使用 6.1.下载与安装 6.2.MyEclipse 菜单及其菜单项 7.创建和发布一个 Java 程序 7.1.创建 Java 程序 7.2.发布 Java 程序 8.示例 8.1. Hello World 示例 8.2. 简单Spring Boot 应用 8.3…

kettle从入门到精通 第六十九课 ETL之kettle kettle cdc mysql,轻松实现增量同步

1、之前kettle cdc mysql的时候使用的方案是canalkafkakettle&#xff0c;今天我们一起学习下使用kettle的插件Debezium直接cdc mysql。 注&#xff1a;CDC (Change Data Capture) 是一种技术&#xff0c;用于捕获和同步数据库中的更改。 1&#xff09;Debezium步骤解析mysql b…

鸿蒙轻内核Kconfig使用笔记

鸿蒙轻内核使用Kconfig进行图形化配置&#xff0c;本文专门讲解下鸿蒙轻内核LiteOS-M和LiteOS-A的图形化配置方法。本文中所涉及的源码&#xff0c;均可以在开源站点 https://gitee.com/openharmony/kernel_liteos_a 、 https://gitee.com/openharmony/kernel_liteos_m 获取。本…

Spring AI 接入OpenAI实现文字生成图片功能

Spring AI 框架集成的图片大模型 2022年出现的三款文生图的现象级产品&#xff0c;DALL-E、Stable Diffusion、Midjourney。 OpenAI dall-e-3dall-e-2 Auzre OpenAI dall-e-3dall-e-2 Stability stable-diffusion-v1-6 ZhiPuAI cogview-3 OpenAI 与 Auzer OpenAI 使用的图片…

【FreeRTOS】创建任务-声光色影

参考《FreeRTOS入门与工程实践(基于DshanMCU-103).pdf》 目录 1 基本概念2 任务创建与删除2.1 什么是任务2.2 创建分配内存2.2.1 动态任务2.2.1 静态分配内存 2.3 示例1: 创建任务2.3.1 声2.3.1.1 music.c2.3.1.2 music.h2.3.1.4 硬件接线 2.3.2 光2.3.3 色2.3.4 影 在本章中&a…

DC12V升压24V/5A电流 布控球产品应用 升压恒压SL4010耐压40V芯片

随着科技的不断发展&#xff0c;布控球作为一种高效、精准的安全监控设备&#xff0c;被广泛应用于公安、消防、交通等多个领域。然而&#xff0c;布控球在工作过程中需要稳定的电源供应&#xff0c;以保证其正常运行和长期稳定性。因此&#xff0c;一款性能优良的升压恒压芯片…

WindTerm使用SSH密钥连接阿里云实例,服务器设置SSH密钥登录

安装Windterm 地址https://github.com/kingToolbox/WindTerm/releases 下载完放到文件夹就可以打开 阿里云开启密钥对 打开阿里云ecs控制台 https://ecs.console.aliyun.com/keyPair/region/cn-wulanchabu 网络与安全->密钥对&#xff0c;创建密钥对&#xff0c;创建成…

《现代通信原理与技术》--数字信号的最佳接收实验报告

《现代通信原理与技术》 数字信号的最佳接收实验报告 实 验&#xff1a;数字信号的最佳接收实验报告 目录 摘要......................................................................................................3 引言........................................…

R语言绘制三变量分区地图

参考资料&#xff1a; https://mp.weixin.qq.com/s/5c7gpO2mJ2BqJevePJz3CQ tricolore包教程&#xff1a;https://github.com/jschoeley/tricolore 学习笔记&#xff1a;Ternary choropleth maps 1、测试实例 代码&#xff1a; library(ggplot2) library(rnaturalearthdata) …

探索AI视频生成技术的原理

探索AI视频生成技术的原理 随着人工智能技术的迅猛发展&#xff0c;AI在视频生成领域的应用已经引起了广泛关注。从娱乐、广告到教育和科学研究&#xff0c;AI视频生成技术正在彻底改变我们制作和消费视频内容的方式。本文将深入探讨AI视频生成技术的原理&#xff0c;解析其背…

【Kadane】Leetcode 918. 环形子数组的最大和【中等】

环形子数组的最大和 给定一个长度为 n 的环形整数数组 nums &#xff0c;返回 nums 的非空 子数组 的最大可能和 。 环形数组 意味着数组的末端将会与开头相连呈环状。形式上&#xff0c; nums[i] 的下一个元素是 nums[(i 1) % n] &#xff0c;nums[i] 的前一个元素是 nums…

安鸾学院靶场——安全基础

文章目录 1、Burp抓包2、指纹识别3、压缩包解密4、Nginx整数溢出漏洞5、PHP代码基础6、linux基础命令7、Mysql数据库基础8、目录扫描9、端口扫描10、docker容器基础11、文件类型 1、Burp抓包 抓取http://47.100.220.113:8007/的返回包&#xff0c;可以拿到包含flag的txt文件。…

【车载音视频电脑】嵌入式AI分析车载DVR,支持8路1080P

产品特点 采用H.265 & H.264编解码&#xff0c;节约存储空间、传输流量&#xff1b; 高分辨率&#xff1a;支持8路1080P*15FPS/4路1080P*30FPS、720P、D1等编解码&#xff1b; 支持1张SATA硬盘&#xff0c;取用方便&#xff0c;满足大容量存储要求&#xff1b; 支持1个…

Stable-Diffusion-WebUI 常用提示词插件

SixGod提示词插件 SixGod提示词插件可以帮助用户快速生成逼真、有创意的图像。其中包含,清空正向提示词”和“清空负向提示词、提示词起手式包含人物、服饰、人物发型等各个维度的提示词、一键清除正面提示词与负面提示词、随机灵感关键词、提示词分类组合随机、动态随机语法…

【CTF Web】CTFShow 数据库恶意下载 Writeup(目录扫描+mdb文件泄露+Access脱库)

数据库恶意下载 10 mdb文件是早期aspaccess构架的数据库文件&#xff0c;文件泄露相当于数据库被脱裤了。 解法 用 dirsearch 扫描。 dirsearch -u 4b9b415f-4062-4bba-a6f5-3b107804043f.challenge.ctf.show找到一个 db 目录。 扫描 db 目录。 dirsearch -u 4b9b415f-4062-…

商标撤三申请成功,为商标申请扫除障碍!

最近去年帮一个主体做的商标连续三年使用撤销申请下来了&#xff0c;成功撤销掉目标商标&#xff0c;普推商标老杨看到对方在规定时间内没有提供使用证据进行答辩&#xff0c;这样基本上就会被撤销掉。 现在有效商标注册量很高&#xff0c;许多想到的商标名称基本上都有相同或高…

opencv_特征检测和描述

理解特征 寻找独特的特定模式或特定特征&#xff0c;可以轻松跟踪和比较。 拼图&#xff1a;在图像中搜索这些特征&#xff0c;找到它们&#xff0c;在其他图像中查找相同的特征并对齐它们。而已。 基本上&#xff0c;角被认为是图像中的好特征。 在本单元中&#xff0c;我…

【全开源】ChatGPT 机器人公众号小程序h5源码开源交付支持二开

AI机器人系统对接OPENAI&#xff1a;智能互联的无限可能 &#x1f310; 一、引言&#xff1a;AI机器人系统与OPENAI的碰撞 在科技日新月异的今天&#xff0c;AI机器人系统正逐渐渗透到我们生活的各个角落。而当这一智能系统与全球领先的OPENAI技术相结合&#xff0c;又将擦出…

Guitar Pro 8中文版安装包下载及安装教程

Guitar Pro是一款倍受吉他手喜爱的吉他和弦、六线谱、BASS四线谱绘制、打印、查看、试听软件&#xff0c;它也是一款优秀的MIDI音序器&#xff0c;MIDI制作辅助工具&#xff0c;可以输出标准格式的MIDI。 GP的过人之处就在于它可以直接用鼠标和键盘按标准的六线谱、四线谱进行…