SqlSugar/Src/Asp.NetCore2/QuestDbTest/Demo/Demo3_Insertable.cs

64 lines
2.3 KiB
C#
Raw Normal View History

2022-07-29 22:44:21 +08:00
using SqlSugar;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
namespace OrmTest
{
public class Demo3_Insertable
{
public static void Init()
{
Console.WriteLine("");
Console.WriteLine("#### Insertable Start ####");
SqlSugarClient db = new SqlSugarClient(new ConnectionConfig()
{
DbType = DbType.QuestDB,
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)));
}
}
});
var insertObj = new Order() { Id = 1, Name = "order1",Price=0 ,Value = 10.133};
2022-07-29 22:44:21 +08:00
var updateObjs = new List<Order> {
new Order() { Id = SnowFlakeSingle.Instance.NextId(), Name = "order11", Price=0 ,Value = 0.242},
new Order() { Id = SnowFlakeSingle.Instance.NextId(), Name = "order12" , Price=0,Value = 3.343}
2022-07-29 22:44:21 +08:00
};
var x = db.Insertable(updateObjs).RemoveDataCache().IgnoreColumns(it => it.CreateTime).UseParameter().ExecuteCommand();
//Ignore CreateTime
2022-07-31 23:51:07 +08:00
db.Insertable(insertObj).IgnoreColumns(it => new { it.CreateTime }).ExecuteReturnSnowflakeId();//get identity
db.Insertable(insertObj).IgnoreColumns("CreateTime").ExecuteReturnSnowflakeId();
2022-07-29 22:44:21 +08:00
//Only insert Name and Price
2022-07-31 23:51:07 +08:00
db.Insertable(insertObj).InsertColumns(it => new { it.Name, it.Price }).ExecuteReturnSnowflakeId();
db.Insertable(insertObj).InsertColumns("Name", "Price").ExecuteReturnSnowflakeId();
2022-07-29 22:44:21 +08:00
2022-07-31 23:51:07 +08:00
foreach (var item in updateObjs)
{
item.Id = 0;
}
2022-07-29 22:44:21 +08:00
//ignore null columns
2022-07-31 23:51:07 +08:00
db.Insertable(updateObjs).ExecuteReturnSnowflakeId();//get change row count
2022-07-29 22:44:21 +08:00
//Use Lock
2022-07-31 23:51:07 +08:00
db.Insertable(insertObj).With(SqlWith.UpdLock).ExecuteReturnSnowflakeId();
2022-07-29 22:44:21 +08:00
2022-07-31 23:51:07 +08:00
2022-07-29 22:44:21 +08:00
Console.WriteLine("#### Insertable End ####");
}
}
}