mirror of
				https://gitee.com/dotnetchina/SqlSugar.git
				synced 2025-10-27 03:09:34 +08:00 
			
		
		
		
	
		
			
				
	
	
		
			136 lines
		
	
	
		
			5.3 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
			
		
		
	
	
			136 lines
		
	
	
		
			5.3 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
| 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()
 | |
|             {
 | |
|                 DbType = DbType.PostgreSQL,
 | |
|                 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
 | |
| 
 | |
|             var result67 =
 | |
|             db.Updateable(updateObjs)
 | |
|            .PublicSetColumns(it => it.Price, it => it.Price + 1)
 | |
|            .ExecuteCommand();
 | |
| 
 | |
|             var result68 =
 | |
|              db.Updateable(updateObjs.First())
 | |
|              .PublicSetColumns(it => it.Price, it => it.Price + 1)
 | |
|              .ExecuteCommand();
 | |
| 
 | |
|             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();
 | |
|             }
 | |
|             /*** 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
 | |
|             var result8 = db.Updateable<Order>(it => it.Name == "Name").Where(it => it.Id == 1).ExecuteCommand();
 | |
|             var result81 = db.Updateable<Order>()
 | |
|                 .SetColumns(it => it.Name == "Name" )
 | |
|                   .SetColumns(it => it.CreateTime == DateTime.Now)
 | |
|                 .Where(it => it.Id == 1).ExecuteCommand();
 | |
|             //
 | |
|             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();
 | |
|              
 | |
| 
 | |
|             /*** 3.by Dictionary ***/
 | |
|             var dt = new Dictionary<string, object>();
 | |
|             dt.Add("id", 1);
 | |
|             dt.Add("name", "abc");
 | |
|             dt.Add("CustomId", null);
 | |
|             dt.Add("createTime", DateTime.Now);
 | |
|             var dtList = new List<Dictionary<string, object>>();
 | |
|             dtList.Add(dt);
 | |
| 
 | |
|             var t66 = db.Updateable(dt).AS("order").WhereColumns("id").ExecuteCommand();
 | |
|             var t666 = db.Updateable(dtList).AS("order").WhereColumns("id").ExecuteCommand();
 | |
| 
 | |
| 
 | |
| 
 | |
|             /*** 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();
 | |
| 
 | |
|             db.Updateable<object>()
 | |
|                  .AS("Order")
 | |
|                  .SetColumns("name", 1)
 | |
|                  .Where("id=1").ExecuteCommand();
 | |
| 
 | |
|             //Where Sql
 | |
|             //db.Updateable(updateObj).Where("id=@x", new { x = 1 }).ExecuteCommand();
 | |
| 
 | |
|             Console.WriteLine("#### Updateable End ####");
 | |
|         }
 | |
| 
 | |
|     }
 | |
| } | 
