SqlSugar/Src/Asp.Net/MySqlTest/UserTestCases/Cases/Demo2_Updateable.cs

129 lines
5.2 KiB
C#
Raw Normal View History

2019-05-22 20:42:46 +08:00
using SqlSugar;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
namespace OrmTest
{
public class Demo2_Updateable
{
public static void Init()
{
Console.WriteLine("");
Console.WriteLine("#### Updateable Start ####");
SqlSugarClient db = new SqlSugarClient(new ConnectionConfig()
{
2019-06-04 13:29:07 +08:00
DbType = DbType.MySql,
2019-05-22 20:42:46 +08:00
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
2023-05-07 18:38:36 +08:00
var result66 =
db.Updateable(updateObjs.First())
.PublicSetColumns(it => it.Price, it => it.Price + 1)
.ExecuteCommand();
2019-05-22 20:42:46 +08:00
2023-05-07 18:38:36 +08:00
var result67 =
db.Updateable(updateObjs)
.PublicSetColumns(it => it.Price, it => it.Price + 1)
.ExecuteCommand();
2019-05-22 20:42:46 +08:00
2023-05-21 18:04:43 +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();
}
2019-05-22 20:42:46 +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-04 12:36:18 +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();
2019-05-22 20:42:46 +08:00
//
2023-04-24 17:44:57 +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-22 20:42:46 +08:00
/*** 3.by Dictionary ***/
var dt = new Dictionary<string, object>();
dt.Add("id", 1);
2019-06-04 12:36:18 +08:00
dt.Add("name", "abc");
2019-05-22 20:42:46 +08:00
dt.Add("createTime", DateTime.Now);
var dtList = new List<Dictionary<string, object>>();
dtList.Add(dt);
2022-12-11 16:33:51 +08:00
var t66 = db.Updateable(dt).AS("`Order`").WhereColumns("id").ExecuteCommand();
var t666 = db.Updateable(dtList).AS("`Order`").WhereColumns("id").ExecuteCommand();
2019-05-22 20:42:46 +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 16:32:10 +08:00
//db.Updateable(updateObj).Where("id=@x", new { x = "1" }).ExecuteCommand();
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" });
2019-05-22 20:42:46 +08:00
Console.WriteLine("#### Updateable End ####");
}
}
}