SqlSugar/Src/Asp.NetCore2/SqlSeverTest/Demo/Demo4_Deleteable.cs

62 lines
2.0 KiB
C#
Raw Normal View History

2019-05-21 12:57:51 +08:00
using SqlSugar;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
namespace OrmTest
{
public class Demo4_Deleteable
{
public static void Init()
{
Console.WriteLine("");
Console.WriteLine("#### Deleteable Start ####");
SqlSugarClient db = new SqlSugarClient(new ConnectionConfig()
{
DbType = DbType.SqlServer,
ConnectionString = Config.ConnectionString,
InitKeyType = InitKeyType.Attribute,
IsAutoCloseConnection = true,
AopEvents = new AopEvents
{
OnLogExecuting = (sql, p) =>
{
Console.WriteLine(sql);
Console.WriteLine(string.Join(",", p?.Select(it => it.ParameterName + ":" + it.Value)));
}
}
});
//by entity
2019-06-04 21:03:27 +08:00
db.Deleteable<Order>().Where(new Order() { Id = 1111 }).ExecuteCommand();
2019-05-21 12:57:51 +08:00
//by primary key
2019-06-04 21:03:27 +08:00
db.Deleteable<Order>().In(1111).ExecuteCommand();
2019-05-21 12:57:51 +08:00
//by primary key array
2019-06-04 21:03:27 +08:00
db.Deleteable<Order>().In(new int[] { 1111, 2222 }).ExecuteCommand();
2019-05-21 12:57:51 +08:00
//by expression
2019-06-04 21:03:27 +08:00
db.Deleteable<Order>().Where(it => it.Id == 11111).ExecuteCommand();
2019-05-21 12:57:51 +08:00
2021-11-21 12:10:44 +08:00
//logic delete
db.CodeFirst.InitTables<LogicDeleteTezt>();
db.Deleteable<LogicDeleteTezt>().Where(it=>it.Name=="a").IsLogic().ExecuteCommand();
2023-06-21 19:37:42 +08:00
db.Deleteable<Order>().WhereColumns(db.Queryable<Order>().Take(2).ToList(), it => new { it.Id, it.Name }).ExecuteCommand();
2019-05-21 12:57:51 +08:00
Console.WriteLine("#### Deleteable End ####");
}
2021-11-21 12:10:44 +08:00
public class LogicDeleteTezt
{
public string Name { get; set; }
[SugarColumn(IsPrimaryKey =true)]
public int Id { get; set; }
public bool IsDeleted { get; set; }
}
2019-05-21 12:57:51 +08:00
}
}