删除是一个非常危险的操作,FreeSql对删除支持并不强大,仅支持了单表有条件的删除方法。
不想过多的介绍拉长删除数据的系列文章,删除数据的介绍仅此一篇。
若Where条件为空的时候执行方法,FreeSql仅返回0或默认值,不执行真正的SQL删除操作。
为了增强系统的安全性,强烈建议在实体中增加 is_deledted 字段做软删除标识。
var connstr = "Data Source=127.0.0.1;Port=3306;User ID=root;Password=root;" + 
"Initial Catalog=cccddd;Charset=utf8;SslMode=none;Max pool size=10"; IFreeSql 
fsql = new FreeSql.FreeSqlBuilder() 
.UseConnectionString(FreeSql.DataType.MySql, connstr) 
.UseAutoSyncStructure(true) //自动同步实体结构到数据库 .Build(); [Table(Name = "tb_topic")] 
class Topic { [Column(IsIdentity = true, IsPrimary = true)] public int Id { 
get; set; } public int Clicks { get; set; } public string Title { get; set; } 
public DateTime CreateTime { get; set; } } 
动态条件
Delete<Topic>(object dywhere) 
dywhere 支持
 * 主键值 
 * new[] { 主键值1, 主键值2 } 
 * Topic对象 
 * new[] { Topic对象1, Topic对象2 } 
 * new { id = 1 } fsql.Delete<Topic>(new[] { 1, 2 }).ExecuteAffrows(); 
//DELETE FROM `tb_topic` WHERE (`Id` = 1 OR `Id` = 2) fsql.Delete<Topic>(new 
Topic { Id = 1, Title = "test" }).ExecuteAffrows(); //DELETE FROM `tb_topic` 
WHERE (`Id` = 1) fsql.Delete<Topic>(new[] { new Topic { Id = 1, Title = "test" 
}, new Topic { Id = 2, Title = "test" } }).ExecuteAffrows(); //DELETE FROM 
`tb_topic` WHERE (`Id` = 1 OR `Id` = 2) fsql.Delete<Topic>(new { id = 1 
}).ExecuteAffrows(); //DELETE FROM `tb_topic` WHERE (`Id` = 1) 
删除条件
出于安全考虑,没有条件不执行删除动作,避免误删除全表数据
 删除全表数据:fsql.Delete<T>().Where("1=1").ExecuteAffrows()
fsql.Delete<Topic>().Where(a => a.Id == 1).ExecuteAffrows(); //DELETE FROM 
`tb_topic` WHERE (`Id` = 1) fsql.Delete<Topic>().Where("id = ?id", new { id = 1 
}).ExecuteAffrows(); //DELETE FROM `tb_topic` WHERE (id = ?id) var item = new 
Topic { Id = 1, Title = "newtitle" }; 
fsql.Delete<Topic>().Where(item).ExecuteAffrows(); //DELETE FROM `tb_topic` 
WHERE (`Id` = 1) var items = new List<Topic>(); for (var a = 0; a < 10; a++) 
items.Add(new Topic { Id = a + 1, Title = $"newtitle{a}", Clicks = a * 100 }); 
fsql.Delete<Topic>().Where(items).ExecuteAffrows(); //DELETE FROM `tb_topic` 
WHERE (`Id` IN (1,2,3,4,5,6,7,8,9,10)) 
API
方法 返回值 参数 描述 
Where <this> Lambda 表达式条件,仅支持实体基础成员(不包含导航对象) 
Where <this> string, parms 原生sql语法条件,Where("id = ?id", new { id = 1 }) 
Where <this> T1 | IEnumerable 传入实体或集合,将其主键作为条件 
WhereExists <this> ISelect 子查询是否存在 
WithTransaction <this> DbTransaction 设置事务对象 
ToSql string 返回即将执行的SQL语句 
ExecuteAffrows long 执行SQL语句,返回影响的行数 
ExecuteDeleted List<T1> 执行SQL语句,返回被删除的记录 
系列文章导航
 * 
(一)入门 <https://www.cnblogs.com/FreeSql/p/11531300.html>
 * 
(二)自动迁移实体 <https://www.cnblogs.com/FreeSql/p/11531301.html>
 * 
(三)实体特性 <https://www.cnblogs.com/FreeSql/p/11531302.html>
 * 
(四)实体特性 Fluent Api <https://www.cnblogs.com/FreeSql/p/11531304.html>
 * 
(五)插入数据 <https://www.cnblogs.com/FreeSql/p/11531306.html>
 * 
(六)批量插入数据 <https://www.cnblogs.com/FreeSql/p/11531309.html>
 * 
(七)插入数据时忽略列 <https://www.cnblogs.com/FreeSql/p/11531316.html>
 * 
(八)插入数据时指定列 <https://www.cnblogs.com/FreeSql/p/11531318.html>
 * 
(九)删除数据
 * 
(十)更新数据 <https://www.cnblogs.com/FreeSql/p/11531321.html>
 * 
(十一)更新数据 Where <https://www.cnblogs.com/FreeSql/p/11531324.html>
 * 
(十二)更新数据时指定列 <https://www.cnblogs.com/FreeSql/p/11531327.html>
 * 
(十三)更新数据时忽略列 <https://www.cnblogs.com/FreeSql/p/11531334.html>
 * 
(十四)批量更新数据 <https://www.cnblogs.com/FreeSql/p/11531335.html>
 * 
(十五)查询数据 <https://www.cnblogs.com/FreeSql/p/11531339.html>
 * 
(十六)分页查询 <https://www.cnblogs.com/FreeSql/p/11531341.html>
 * 
(十七)联表查询 <https://www.cnblogs.com/FreeSql/p/11531346.html>
 * 
(十八)导航属性 <https://www.cnblogs.com/FreeSql/p/11531352.html>
 * 
(十九)多表查询 <https://www.cnblogs.com/FreeSql/p/11531362.html>
 * 
(二十)多表查询 WhereCascade <https://www.cnblogs.com/FreeSql/p/11531372.html>
 * 
(二十一)查询返回数据 <https://www.cnblogs.com/FreeSql/p/11531376.html>
 * 
(二十二)Dto 映射查询 <https://www.cnblogs.com/FreeSql/p/11531381.html>
 * 
(二十三)分组、聚合 <https://www.cnblogs.com/FreeSql/p/11531384.html>
 * 
(二十四)Linq To Sql 语法使用介绍 <https://www.cnblogs.com/FreeSql/p/11531392.html>
 * 
(二十五)延时加载 <https://www.cnblogs.com/FreeSql/p/11531395.html>
 * 
(二十六)贪婪加载 Include、IncludeMany、Dto、ToList 
<https://www.cnblogs.com/FreeSql/p/11531404.html>
 * 
(二十七)将已写好的 SQL 语句,与实体类映射进行二次查询 
<https://www.cnblogs.com/FreeSql/p/11531416.html>
 * 
(二十八)事务 <https://www.cnblogs.com/FreeSql/p/11531423.html>
 * 
(二十九)Lambda 表达式 <https://www.cnblogs.com/FreeSql/p/11531425.html>
 * 
(三十)读写分离 <https://www.cnblogs.com/FreeSql/p/11531430.html>
 * 
(三十一)分区分表 <https://www.cnblogs.com/FreeSql/p/11531435.html>
 * 
(三十二)Aop <https://www.cnblogs.com/FreeSql/p/11531471.html>
 * 
(三十三)CodeFirst 类型映射 <https://www.cnblogs.com/FreeSql/p/11531543.html>
 * 
(三十四)CodeFirst 迁移说明 <https://www.cnblogs.com/FreeSql/p/11531550.html>
 * 
(三十五)CodeFirst 自定义特性 <https://www.cnblogs.com/FreeSql/p/11531576.html>
热门工具 换一换
