SqlSugar删除数据
1、根据实体删除
1.1 强类型实体
需要配置主键 ,根据主键删除需要给实体配置主键,参考文档实体配置
//单个实体db.Deleteable<Student>(new Student() { Id = 1 }).ExecuteCommand();//List<实体> (可以不加Where)List<Student> list=new List<Student>(){ new Student() { Id = 1 }};db.Deleteable<Student>(list).ExecuteCommand(); //批量删除//批量删除+分页db.Deleteable<Order>(list).PageSize(500).ExecuteCommand(); |
| 函数 | 说明 |
| ExecuteCommand | 返回受影响行数 , update where 如果没找到那么就会返回 0 |
| ExecuteCommandHasChange | 返回bool ,等同于 bool isChange= ExecuteCommand()>0 |
2.2无主键实体删除
注意:请升级到5.1.4.60-preview02
List<T> list=new List<T>(){...};db.Deleteable<Order>().WhereColumns(list,it=>new { it.Id}).ExecuteCommand(); |
2.3 Object、接口、抽象类 删除
//2.Object对象插入 (5.1.3.45)//o必须是真实的类对象 (比如根据type反射出来的对象,或者转成了Object的实体) db.DeleteableByObject(o).ExecuteCommand(); //更多功能 :动态建类等https://www.donet5.com/Home/Doc?typeId=2562 |
2、根据主键
db.Deleteable<Student>().In(1).ExecuteCommand();//无主键用法db.Deleteable<Order>().In(it=>it.Id,1).ExecuteCommand(); |
3、根据主键数组
db.Deleteable<Student>().In(new int[] { 1, 2 }).ExecuteCommand();//无主键用法db.Deleteable<Student>().In(it=>it.Id,new int[] { 1, 2 }).ExecuteCommand();//Oracle用户注意:这种方式只能删除1000,用达式方式.Where(it=>ids.Contains(it.Id)支持1000以上 |
4、根据表达式
db.Deleteable<Student>().Where(it => it.Id == 1).ExecuteCommand(); |
5、联表删除
db.Deleteable<Student>() .Where(p => SqlFunc.Subqueryable<School>().Where(s => s.Id == p.SchoolId).Any()) .ExecuteCommand()//.Where(s => s.Id == p.SchoolId) s和p的关联条件不能少,不然就全删了 |
6、无实体删除
db.Deleteable<object>().AS("[Order]").Where("id=@id",new { id=1}).ExecuteCommand();db.Deleteable<object>().AS("[Order]").Where("id in (@id) ",new { id=new int[]{1,2,3}}).ExecuteCommand();//批量//根据字典集合删除 List<Dictionary<string,object>> list= new List<Dictionary<string,object>>;list.Add(字典);db.Deleteable<object>().AS("[Order]").WhereColumns(list).ExecuteCommand();//DataTable也可以转成字典集合List<Dictionary<string,object>> list= db.Utilities.DataTableToDictionaryList(dataTable);//转成字典 |
7、全局过滤器(5.0.4.1)
//配置表过滤器db.QueryFilter.Add(new TableFilterItem<Order>(it => it.Name.Contains("a")));//查询有效 db.Queryable<Order>().ToList();//SELECT [Id],[Name],[Price],[CreateTime],[CustomId] FROM [Order] WHERE ([Name] like '%'+@MethodConst0+'%') //删除也有效db.Deleteable<Order>().EnableQueryFilter().Where(it=>it.Id==1).ExecuteCommand();//DELETE FROM [Order] WHERE ([Name] like '%'+@MethodConst1000+'%') AND ( [Id] = @Id0 ) |
8、逻辑删除(5.0.4.3)
逻辑删除方式1:
优点:简单直接用,如果有数据过滤器建议用方式2
实体属性有isdelete或者isdeleted
db.Deleteable<LogicTest>().In(100).IsLogic().ExecuteCommand(); //假删除 软删除 |
指定属性
db.Deleteable<LogicTest>().In(100).IsLogic().ExecuteCommand("mydelete"); |
指定属性并且修改时间
db.Deleteable<LogicTest>().In(100).IsLogic().ExecuteCommand("mydelete",true,DateTime.Now,"UpdateTime"); |
指定属性并且修改时间+用户
db.Deleteable<LogicTest>().In(100) .IsLogic() .ExecuteCommand("mydelete",true, DateTime.Now, "UpdateTime","ModifierName",userId); |
说明:用法与删除一样唯一多了个.IsLogic()
逻辑删除方式2:
优点:可以结合更新过滤器一起生效
public void FalseDelete<T>(Expression<Func<T,bool>> exp) where T:class,IDeleted,new()//约束3个不能少 { db.Updateable<T>() .SetColumns(it => new T() { IsDeleted = true }, true)//true 支持更新数据过滤器赋值字段一起更新 .Where(exp).ExecuteCommand(); } //建一个接口,继承这个接口的类就能用FalseDelete public interface IDeleted { bool IsDeleted { get; set; } } |
9、初始化表
表中数据全部清空,清除,自增初始化
db.DbMaintenance.TruncateTable<T>() |
10、导航删除
db.DeleteNav<OperatorInfo>(x=>x.id==1) .Include(x => x.Roles) .ExecuteCommand(); |
具体用法:https://www.donet5.com/Home/Doc?typeId=24314
11、常用案例1:除最新N条清空
db.Deleteable<Order>().In(it => it.Id, db.Queryable<Order>() .Skip(10).OrderByDescending(it=>it.CreateTime) .Select(it => it.Id)).ExecuteCommand(); //注意Select不要ToList() , ToList就2次查询了 |
12、常用案例2:N到N条删除
db.Deleteable<Order>().In(it => it.Id, db.Queryable<Order>() .Skip(10).Take(10) .Select(it => it.Id)).ExecuteCommand(); //注意Select不要ToList() , ToList就2次查询了 |
13、常用案例3:大数据删除
db.Deleteable<Order>(list).PageSize(500).ExecuteCommand(); |
SqlSugar删除数据的更多相关文章
- CRL快速开发框架系列教程四(删除数据)
本系列目录 CRL快速开发框架系列教程一(Code First数据表不需再关心) CRL快速开发框架系列教程二(基于Lambda表达式查询) CRL快速开发框架系列教程三(更新数据) CRL快速开发框 ...
- 读书笔记--SQL必知必会16--更新和删除数据
16.1 更新数据 使用UPDATE语句更新或修改表中的数据.必须有足够的安全权限. 更新表中的特定行 更新表中的所有行 使用UPDATE时一定要细心,不要省略WHERE子句. SET命令用来将新值赋 ...
- Web jquery表格组件 JQGrid 的使用 - 7.查询数据、编辑数据、删除数据
系列索引 Web jquery表格组件 JQGrid 的使用 - 从入门到精通 开篇及索引 Web jquery表格组件 JQGrid 的使用 - 4.JQGrid参数.ColModel API.事件 ...
- MySQL数据库5 - 插入数据,修改数据,删除数据
一.插入数据 1. 所有列都插入值 INSERT [INTO] TABLE_NAME VALUES(V1,V2....Vn); 特点:列值同数,列值同序 eg: insert into users v ...
- X删除数据表的新用法
删除数据表,可以这样进行,以前傻不拉唧的用sql去手动删除. DAL dal = ... dal.Db.CreateMetaData().SetSche ...
- Kafka深入理解-3:Kafka如何删除数据(日志)文件
Kafka作为消息中间件,数据需要按照一定的规则删除,否则数据量太大会把集群存储空间占满. 参考:apache Kafka是如何实现删除数据文件(日志)的 Kafka删除数据有两种方式 按照时间,超过 ...
- MySQL(四) 数据表的插入、更新、删除数据
序言 数据表的插入.更新.删除非常简单,但是简单的也要学习,细节决定成败. ---WH 一.插入数据 格式:INSERT INTO 表名(字段名...)VALUES(值...); 创建环境 使用per ...
- ThinkPHP 修改,删除数据,全部显示
1,修改数据 //数据修改 function Update() { $model = D("info"); /* //1,数组方式 $attr = array( "Cod ...
- Oracle 恢复被删除的数据,解决误操作删除数据
在删除数据的时候不小心,把delete语句执行错了,把别的表给delete,而且还执行了commit!真汗.......数据是相当的重要........废话少说了!赶快找方法吧: 第一种: 1.打开F ...
- 【mongo】pymongo通过_id删除数据
来源:http://www.educity.cn/wenda/361741.html pymongo 根据 objectId _id 来删除数据想要删除数据,根据_id ,是最靠谱的,具体方法因为 _ ...
随机推荐
- Djagno 使用locals()
Django使用locals()函数 locals()函数会以字典类型返回当前位置的全部局部变量 在 views.py中添加 #展示 class Goods_list(View): def get(s ...
- js import的几种用法
最近昨天公司小朋友离职,临时接收其负责的vue前端项目.vue好久没做了,很多东西都忘记或以前也没接触,几天开始慢慢写点vue的小知识,算是历程或备忘吧. import在js.ts中用了不知多少次,但 ...
- Educational Round 95 (Div. 2) A - B题题解(A题数据连错3次,搞人心态中)
1418A. Buying Torches 这次A题,真心fo了(导致wa了我两次) 样例出错两次,数据出错一次. 讲一下我的思路吧. 首先先明确至少需要多少个棍.\(k\) 个火炬,至少需要$k ∗ ...
- Codeforces 1092C Prefixes and Suffixes【字符串+思维】
题目链接:点这里 题意:理解错了题意导致WA好几发,QAQ暴击 题意是判断给你的2*n-2个字符串是前缀还是后缀,不是判断这个字符串的内容...我真的欲哭无泪,理解能力太菜了 思路:将两个n-1长的字 ...
- 0x05 基本算法-排序
A题:Cinema 经典离散化例题,把电影的语言与字幕和观众懂的语言放进一个数组,然后离散化. 最后统计快乐人数. const int N = 200006; int n, m, a[N], x[N] ...
- 【收藏】制作艺术二维码,用 Stable Diffusion 就行!
[收藏]Stable Diffusion 制作光影文字效果 https://www.cnblogs.com/Serverless/p/17620406.html 基于函数计算FC 快捷部署 Stabl ...
- <vue 路由 4、嵌套路由>
一.效果 点击about后,新闻和体育属于about的子路由调用的页面 知识点说明 路由里使用children属性可以实现路由的嵌套 三.代码结构 注:主要是标红的几个文件 四.代码 重新编写这几个文 ...
- 【驱动】以太网扫盲(三)PHY的控制器驱动框架分析
1. 概述 PHY芯片为OSI的最底层-物理层(Physical Layer),通过MII/GMII/RMII/SGMII/XGMII等多种媒体独立接口(介质无关接口)与数据链路层的MAC芯片相连,并 ...
- C#设计模式18——迭代器模式的写法
是什么: 迭代器模式是一种行为型设计模式,它允许客户端通过一种统一的方式遍历集合对象中的元素,而无需暴露集合对象的内部结构. 为什么: 使用迭代器模式可以使得客户端程序与集合对象解耦,从而可以更加灵活 ...
- zznu 1632
表达式求值 递归求解~~ #include<cstdio> #include<cstring> #include<cstdlib> #include<cmat ...