SqlSugar/Src/Asp.Net/SqlServerTest/Demo/DemoB_Aop.cs

81 lines
3.1 KiB
C#
Raw Normal View History

2019-06-02 16:38:16 +08:00
using SqlSugar;
using System;
2017-04-30 17:26:45 +08:00
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
2019-06-02 19:37:47 +08:00
2019-06-02 15:31:27 +08:00
namespace OrmTest
2017-04-30 17:26:45 +08:00
{
2019-06-02 15:31:27 +08:00
public class DemoB_Aop
2017-04-30 17:26:45 +08:00
{
2019-06-02 15:31:27 +08:00
public static void Init()
{
2019-06-02 16:38:16 +08:00
Console.WriteLine("");
Console.WriteLine("#### Aop Start ####");
2019-06-02 15:31:27 +08:00
2019-06-02 16:38:16 +08:00
SqlSugarClient db = new SqlSugarClient(new ConnectionConfig()
{
DbType = DbType.SqlServer,
ConnectionString = Config.ConnectionString,
InitKeyType = InitKeyType.Attribute,
2019-06-02 19:28:09 +08:00
IsAutoCloseConnection = true
2019-06-02 16:38:16 +08:00
});
2019-06-02 19:28:09 +08:00
db.Aop.OnLogExecuted = (sql, pars) => //SQL executed event
{
Console.WriteLine("OnLogExecuted"+sql);
};
db.Aop.OnLogExecuting = (sql, pars) => //SQL executing event (pre-execution)
{
Console.WriteLine("OnLogExecuting" + sql);
};
db.Aop.OnError = (exp) =>//SQL execution error event
{
//exp.sql
};
db.Aop.OnExecutingChangeSql = (sql, pars) => //SQL executing event (pre-execution,SQL script can be modified)
{
return new KeyValuePair<string, SugarParameter[]>(sql, pars);
};
2019-06-02 19:35:59 +08:00
db.Aop.OnDiffLogEvent = it =>//Get data changes
{
var editBeforeData = it.BeforeData;
var editAfterData = it.AfterData;
var sql = it.Sql;
var parameter = it.Parameters;
var businessData = it.BusinessData;
var time = it.Time;
var diffType = it.DiffType;//enum insert 、update and delete
2019-06-02 19:36:49 +08:00
Console.WriteLine(businessData);
2019-06-02 19:35:59 +08:00
//Write logic
};
2019-06-02 19:28:09 +08:00
2019-06-02 19:35:59 +08:00
2021-11-11 20:38:38 +08:00
var list= db.Queryable<Order>().ToList();
2019-06-02 19:28:09 +08:00
db.Queryable<OrderItem>().ToList();
2019-06-02 16:38:16 +08:00
2019-06-02 19:35:59 +08:00
//OnDiffLogEvent
var data = db.Queryable<Order>().First();
2021-11-11 20:38:38 +08:00
db.Insertable(list.Take(5).ToList()).EnableDiffLogEvent().ExecuteCommand();
2022-05-03 15:36:55 +08:00
db.CodeFirst.InitTables<DiffLong>();
db.Insertable(new List<DiffLong>() { new DiffLong() { Id=SnowFlakeSingle.Instance.NextId(), Name="2" },new DiffLong() { Id = SnowFlakeSingle.Instance.NextId(), Name = "2" } }).EnableDiffLogEvent().ExecuteCommand();
2021-11-11 20:38:38 +08:00
db.Insertable(new Order() { CreateTime=DateTime.Now, CustomId=1, Name="a" ,Price=1 }).EnableDiffLogEvent().ExecuteCommand();
2019-06-02 19:35:59 +08:00
data.Name = "changeName";
2019-06-02 19:36:49 +08:00
db.Updateable(data).EnableDiffLogEvent("--update Order--").ExecuteCommand();
2019-06-02 19:35:59 +08:00
2021-11-11 20:38:38 +08:00
db.Updateable(list.Take(5).ToList()).EnableDiffLogEvent("--update Order--").ExecuteCommand();
2021-11-11 20:51:05 +08:00
db.Updateable<Order>().SetColumns(it=>it.Name=="asdfa").Where(it=>it.Id==1).EnableDiffLogEvent("--update Order--").ExecuteCommand();
2022-01-15 19:03:57 +08:00
db.Updateable<Order>().SetColumns(it => it.Name == "asdfa")
.Where(it =>SqlFunc.Subqueryable<Order>().Where(x=>x.Id==it.Id).Any()).EnableDiffLogEvent("--update Order--").ExecuteCommand();
2019-06-02 16:38:16 +08:00
Console.WriteLine("#### Aop End ####");
2019-06-02 15:31:27 +08:00
}
2017-04-30 17:26:45 +08:00
}
}