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

79 lines
3.1 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 Demo3_Insertable
{
public static void Init()
{
Console.WriteLine("");
Console.WriteLine("#### Insertable 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)));
}
}
});
2020-11-15 00:39:23 +08:00
var insertObj = new Order() { Id = 1, Name = "order1", Price = 0 };
var insertObjs = new List<Order> {
2019-06-04 21:03:27 +08:00
new Order() { Id = 11, Name = "order11", Price=0 },
new Order() { Id = 12, Name = "order12" , Price=0}
2019-05-21 12:57:51 +08:00
};
2019-06-04 21:03:27 +08:00
//Ignore CreateTime
db.Insertable(insertObj).IgnoreColumns(it => new { it.CreateTime }).ExecuteReturnIdentity();//get identity
db.Insertable(insertObj).IgnoreColumns("CreateTime").ExecuteReturnIdentity();
2019-05-21 12:57:51 +08:00
//Only insert Name and Price
db.Insertable(insertObj).InsertColumns(it => new { it.Name, it.Price }).ExecuteReturnIdentity();
2019-06-04 21:03:27 +08:00
db.Insertable(insertObj).InsertColumns("Name", "Price").ExecuteReturnIdentity();
2019-05-21 12:57:51 +08:00
//ignore null columns
2020-11-15 00:39:23 +08:00
db.Insertable(insertObjs).ExecuteCommand();//get change row count
2022-12-13 17:02:51 +08:00
db.Insertable(insertObjs).AS("ORDER").ExecuteCommand();//get change row count
db.Insertable(insertObjs.First()).AS("ORDER").ExecuteCommand();//get change row count
2019-05-21 12:57:51 +08:00
//Use Lock
db.Insertable(insertObj).With(SqlWith.UpdLock).ExecuteCommand();
2020-11-15 00:39:23 +08:00
insertObjs = new List<Order> {
new Order() { Id = 11, Name = "order11", Price=1 },
new Order() { Id = 12, Name = "order12" , Price=20, CreateTime=DateTime.Now, CustomId=1}
};
2021-09-05 03:01:57 +08:00
db.Insertable(insertObjs).UseSqlServer().ExecuteBulkCopy();
2020-11-15 00:39:23 +08:00
db.CodeFirst.InitTables<RootTable0, TwoItem, TwoItem2, TwoItem3>();
db.CodeFirst.InitTables<ThreeItem2>();
db.DbMaintenance.TruncateTable("RootTable0");
db.DbMaintenance.TruncateTable("TwoItem");
db.DbMaintenance.TruncateTable("TwoItem2");
db.DbMaintenance.TruncateTable("TwoItem3");
db.DbMaintenance.TruncateTable("ThreeItem2");
2022-12-26 11:24:21 +08:00
object getAll = db.Queryable<Order>().Take(2).ToList();
db.InsertableByObject(getAll).ExecuteCommand();
object o = db.Queryable<Order>().First();
db.InsertableByObject(o).ExecuteCommand();
2020-11-15 00:39:23 +08:00
2019-05-21 12:57:51 +08:00
Console.WriteLine("#### Insertable End ####");
2020-11-15 00:39:23 +08:00
}
2022-12-26 11:24:21 +08:00
2019-05-21 12:57:51 +08:00
}
}