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

183 lines
7.5 KiB
C#
Raw Normal View History

2019-05-20 17:20:36 +08:00
using SqlSugar;
using System;
using System.Collections.Generic;
2023-01-04 15:35:14 +08:00
using System.ComponentModel.DataAnnotations;
2019-05-20 17:20:36 +08:00
using System.Linq;
using System.Text;
using System.Threading.Tasks;
namespace OrmTest
{
public class Demo2_Updateable
{
public static void Init()
{
2019-05-20 17:32:13 +08:00
Console.WriteLine("");
Console.WriteLine("#### Updateable Start ####");
2019-05-20 17:20:36 +08:00
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)));
}
}
});
/*** 1.entity or List ***/
var updateObj = new Order() { Id = 1, Name = "order1" };
var updateObjs = new List<Order> {
new Order() { Id = 11, Name = "order11" },
new Order() { Id = 12, Name = "order12" }
};
//update all columns by primary key
var result = db.Updateable(updateObj).ExecuteCommand();//update single
var result2 = db.Updateable(updateObjs).ExecuteCommand();//update List<Class>
//Ignore Name and Price
var result3 = db.Updateable(updateObj).IgnoreColumns(it => new { it.CreateTime, it.Price }).ExecuteCommand();
//only update Name and CreateTime
var result4 = db.Updateable(updateObj).UpdateColumns(it => new { it.Name, it.CreateTime }).ExecuteCommand();
//If there is no primary key
var result5 = db.Updateable(updateObj).WhereColumns(it => new { it.Id }).ExecuteCommand();//update single by id
var result6 = db.Updateable(updateObjs).WhereColumns(it => new { it.Id }).ExecuteCommand();//update List<Class> by id
2021-12-18 20:51:39 +08:00
//Re set value
var result66 = db.Updateable(new List<Order> { updateObj }).ReSetValue(it => it.Id = 112).IgnoreColumns(it => new { it.CreateTime, it.Price }).ExecuteCommand();
2019-05-20 17:20:36 +08:00
2023-05-07 18:20:08 +08:00
var result67 =
db.Updateable(updateObjs)
.PublicSetColumns(it => it.Price, it => it.Price + 1)
.ExecuteCommand();
2019-05-20 17:20:36 +08:00
2023-05-07 18:39:37 +08:00
var result68 =
db.Updateable(updateObjs.First())
.PublicSetColumns(it => it.Price, it => it.Price + 1)
.ExecuteCommand();
2023-05-21 17:43:23 +08:00
var list = db.Queryable<Order>().OrderBy(it=>it.Id).Take(2).ToList();
if (list.Count >= 2)
{
list[0].Price = 10;
list[1].Price = 2;
var result69 =
db.Updateable(list)
.PublicSetColumns(it => it.Price, "+")
.ExecuteCommand();
}
2023-05-07 18:39:37 +08:00
2022-08-02 09:56:59 +08:00
//Update by track
2022-08-16 21:24:39 +08:00
Console.WriteLine(" Tracking 1:");
2022-08-02 09:56:59 +08:00
db.Tracking(updateObj);
2022-08-16 21:24:39 +08:00
//Update set name
2022-08-02 09:56:59 +08:00
updateObj.Name = "a1" + Guid.NewGuid();
db.Updateable(updateObj).ExecuteCommand();
2022-08-02 12:48:05 +08:00
db.TempItems = null;
2022-08-02 09:56:59 +08:00
2022-08-16 21:24:39 +08:00
Console.WriteLine(" Tracking 2:");
db.Tracking(updateObj);
//No Update
db.Updateable(updateObj).ExecuteCommand();
db.TempItems = null;
2019-05-20 17:20:36 +08:00
/*** 2.by expression ***/
//update name,createtime
var result7 = db.Updateable<Order>(it => new Order() { Name = "a", CreateTime = DateTime.Now }).Where(it => it.Id == 11).ExecuteCommand();
var result71 = db.Updateable<Order>().SetColumns(it => new Order() { Name = "a", CreateTime = DateTime.Now }).Where(it => it.Id == 11).ExecuteCommand();
//only update name
2019-06-02 11:12:04 +08:00
var result8 = db.Updateable<Order>(it => it.Name == "Name" + "1").Where(it => it.Id == 1).ExecuteCommand();
var result81 = db.Updateable<Order>().SetColumns(it => it.Name == "Name" + "1").Where(it => it.Id == 1).ExecuteCommand();
2023-01-04 15:35:14 +08:00
var array = new string[] { "1" };
var result82 = db.Updateable<Order>().SetColumns(it => it.Name == array[0]).Where(it => it.Id == 1).ExecuteCommand();
2023-04-24 17:44:19 +08:00
var result61 = db.Updateable<Order>()
.InnerJoin<Custom>((x, y) => x.CustomId == y.Id)
.SetColumns((x, y) => new Order() { Name = y.Name, Price = y.Id })
.Where((x, y) => x.Id == 1)
.ExecuteCommand();
2019-05-20 17:20:36 +08:00
/*** 3.by Dictionary ***/
var dt = new Dictionary<string, object>();
dt.Add("id", 1);
2019-06-02 11:13:30 +08:00
dt.Add("name", "abc");
2019-05-20 17:20:36 +08:00
dt.Add("createTime", DateTime.Now);
var dtList = new List<Dictionary<string, object>>();
dtList.Add(dt);
2019-06-02 09:51:09 +08:00
var t66 = db.Updateable(dt).AS("[Order]").WhereColumns("id").ExecuteCommand();
var t666 = db.Updateable(dtList).AS("[Order]").WhereColumns("id").ExecuteCommand();
2019-05-20 17:20:36 +08:00
/*** 4.Other instructions ***/
var caseValue = "1";
//Do not update NULL columns
db.Updateable(updateObj).IgnoreColumns(ignoreAllNullColumns: true).ExecuteCommand();
//if 1 update name else if 2 update name,createtime
db.Updateable(updateObj)
.UpdateColumnsIF(caseValue == "1", it => new { it.Name })
.UpdateColumnsIF(caseValue == "2", it => new { it.Name, it.CreateTime })
.ExecuteCommand();
//Use Lock
db.Updateable(updateObj).With(SqlWith.UpdLock).ExecuteCommand();
//Where Sql
2021-02-04 14:24:04 +08:00
//db.Updateable(updateObj).Where("id=@x", new { x = "1" }).ExecuteCommand();
2019-05-20 17:32:13 +08:00
2020-12-29 22:29:20 +08:00
var levelCode = "123213123131321";
db.Updateable<Order>(a => a.Name == "a")
.Where(a => SqlFunc.StartsWith(a.Name, levelCode))
.AddQueue();
db.SaveQueues();
2021-11-21 14:29:32 +08:00
2022-01-05 12:17:01 +08:00
var dataTable = db.Queryable<Order>().Select("id,name,1 as price").Take(2).ToDataTable();
db.Fastest<Order>().BulkUpdate("Order", dataTable,new string[] {"id" },new string[] {"name" });
2023-04-20 12:22:36 +08:00
2023-01-04 12:55:28 +08:00
db.Updateable<object>()
2022-06-29 15:17:39 +08:00
.AS("[Order]")
.SetColumns("name", 1)
.Where("id=1").ExecuteCommand();
2023-04-20 12:22:36 +08:00
2023-01-04 12:55:28 +08:00
db.Updateable<object>()
2022-06-29 15:17:39 +08:00
.AS("[Order]")
.SetColumns("name", 1)
2023-04-20 12:22:36 +08:00
.SetColumns("price", 1)
2022-06-29 15:17:39 +08:00
.Where("id=1").ExecuteCommand();
2022-12-26 15:29:20 +08:00
2023-04-20 12:22:36 +08:00
db.Updateable<object>()
.AS("[Order]")
.SetColumns(it => SqlFunc.MappingColumn<string>("name"), it => SqlFunc.MappingColumn<string>("(case when id>0 then name else '' end) "))
.SetColumns("price", 1)
.Where("id=1").ExecuteCommand();
db.Updateable<object>()
.AS("[Order]")
.SetColumns(it => SqlFunc.MappingColumn<string>("name"), it => SqlFunc.MappingColumn<string>("(case when id>0 then name else '' end) "))
//.SetColumns("price", 1)
.Where("id=1").ExecuteCommand();
2022-12-26 15:29:20 +08:00
object o = db.Queryable<Order>().First();
db.UpdateableByObject(o).ExecuteCommandAsync().GetAwaiter().GetResult();
2022-12-26 15:29:20 +08:00
object os = db.Queryable<Order>().Take(2).ToList();
db.UpdateableByObject(os).ExecuteCommand();
2019-05-20 17:32:13 +08:00
Console.WriteLine("#### Updateable End ####");
2019-05-20 17:20:36 +08:00
}
}
}