mirror of
				https://gitee.com/dotnetchina/SqlSugar.git
				synced 2025-10-25 10:19:17 +08:00 
			
		
		
		
	
		
			
	
	
		
			118 lines
		
	
	
		
			2.9 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
		
		
			
		
	
	
			118 lines
		
	
	
		
			2.9 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
|   | using SqlSugar; | |||
|  | using System; | |||
|  | using System.Collections.Generic; | |||
|  | using System.Linq; | |||
|  | using System.Text; | |||
|  | using System.Threading.Tasks; | |||
|  | 
 | |||
|  | namespace OrmTest | |||
|  | { | |||
|  |     public class UnitCustom01 | |||
|  |     { | |||
|  |         public static void Init() | |||
|  |         { | |||
|  |             var ssc = new SqlSugarClient(new ConnectionConfig() | |||
|  | 
 | |||
|  |             { | |||
|  |   | |||
|  |                 ConnectionString = OrmTest.Config.ConnectionString, | |||
|  | 
 | |||
|  |                 DbType = SqlSugar.DbType.MySqlConnector, //必填 | |||
|  | 
 | |||
|  |                 IsAutoCloseConnection = true | |||
|  | 
 | |||
|  |             }); | |||
|  |             ssc.CodeFirst.InitTables<Student>(); | |||
|  |             var expMethods = new List<SqlFuncExternal>(); | |||
|  | 
 | |||
|  |             expMethods.Add(new SqlFuncExternal() | |||
|  | 
 | |||
|  |             { | |||
|  | 
 | |||
|  |                 UniqueMethodName = "SumSugar", | |||
|  | 
 | |||
|  |                 MethodValue = (expInfo, dbType, expContext) => | |||
|  | 
 | |||
|  |                 { | |||
|  | 
 | |||
|  |                     if (dbType == DbType.SqlServer) | |||
|  | 
 | |||
|  |                         return string.Format("SUM({0})", expInfo.Args[0].MemberName); | |||
|  | 
 | |||
|  |                     else if (dbType == DbType.MySqlConnector) | |||
|  | 
 | |||
|  |                         return string.Format("SUM({0})", expInfo.Args[0].MemberName); | |||
|  | 
 | |||
|  |                     else | |||
|  | 
 | |||
|  |                         throw new Exception("未实现"); | |||
|  | 
 | |||
|  |                 } | |||
|  | 
 | |||
|  |             }); | |||
|  | 
 | |||
|  |             ssc.CurrentConnectionConfig.ConfigureExternalServices = new ConfigureExternalServices() | |||
|  | 
 | |||
|  |             { | |||
|  | 
 | |||
|  |                 SqlFuncServices = expMethods //set ext method | |||
|  | 
 | |||
|  |             }; | |||
|  | 
 | |||
|  |             try | |||
|  | 
 | |||
|  |             { | |||
|  |                 ssc.Insertable(new Student() { Age = 1, Createtime = DateTime.Now, Grade = 1, Id = 1, Name = "a", Schoolid = 1 }).ExecuteCommand(); | |||
|  |                 ssc.Insertable(new Student() { Age = 1, Createtime = DateTime.Now, Grade = 1, Id = 1, Name = "a", Schoolid = 1 }).ExecuteCommand(); | |||
|  |                 var sss12 = ssc.Queryable<Student>().GroupBy(o => o.Name).Select(o => new { Age = SqlFunc.AggregateSum(o.Age)  }).ToList(); | |||
|  | 
 | |||
|  |             } | |||
|  | 
 | |||
|  |             catch (Exception e) | |||
|  | 
 | |||
|  |             { | |||
|  | 
 | |||
|  | 
 | |||
|  | 
 | |||
|  |             } | |||
|  |         } | |||
|  |     } | |||
|  | 
 | |||
|  |     [SugarTable("unitstudent1111")] | |||
|  |     public class Student | |||
|  |     { | |||
|  |         /// <summary> | |||
|  |         ///   | |||
|  |         ///</summary> | |||
|  |         [SugarColumn(ColumnName = "id", IsPrimaryKey = true, IsIdentity = true)] | |||
|  |         public int Id { get; set; } | |||
|  |         /// <summary> | |||
|  |         ///   | |||
|  |         ///</summary> | |||
|  |         [SugarColumn(ColumnName = "schoolid")] | |||
|  |         public int? Schoolid { get; set; } | |||
|  |         /// <summary> | |||
|  |         ///   | |||
|  |         ///</summary> | |||
|  |         [SugarColumn(ColumnName = "name")] | |||
|  |         public string Name { get; set; } | |||
|  |         /// <summary> | |||
|  |         ///   | |||
|  |         ///</summary> | |||
|  |         [SugarColumn(ColumnName = "createtime")] | |||
|  |         public DateTime? Createtime { get; set; } | |||
|  |         /// <summary> | |||
|  |         ///   | |||
|  |         ///</summary> | |||
|  |         [SugarColumn(ColumnName = "age")] | |||
|  |         public int? Age { get; set; } | |||
|  |         /// <summary> | |||
|  |         ///   | |||
|  |         ///</summary> | |||
|  |         [SugarColumn(ColumnName = "grade")] | |||
|  |         public int? Grade { get; set; } | |||
|  |     } | |||
|  | 
 | |||
|  | 
 | |||
|  | } |