mirror of
				https://gitee.com/dotnetchina/SqlSugar.git
				synced 2025-10-26 18:59:17 +08:00 
			
		
		
		
	
		
			
				
	
	
		
			70 lines
		
	
	
		
			2.9 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
			
		
		
	
	
			70 lines
		
	
	
		
			2.9 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
| using OrmTest.Models;
 | |
| using SqlSugar;
 | |
| using System;
 | |
| using System.Collections.Generic;
 | |
| using System.Linq;
 | |
| using System.Text;
 | |
| using System.Threading.Tasks;
 | |
| 
 | |
| namespace OrmTest.UnitTest
 | |
| {
 | |
|     public class Mapping : UnitTestBase
 | |
|     {
 | |
|         private Mapping() { }
 | |
|         public Mapping(int eachCount)
 | |
|         {
 | |
|             this.Count = eachCount;
 | |
|         }
 | |
| 
 | |
|         public void Init()
 | |
|         {
 | |
| 
 | |
|             var db = GetInstance();
 | |
|             var t1 = db.Queryable<Student>().Where(it => it.Id == 1).ToSql();
 | |
|             base.Check("SELECT [ID],[SchoolId],[Name],[CreateTime] FROM [STudent]  WHERE ( [ID] = @Id0 ) ", null, t1.Key, null, "Mapping t1 error");
 | |
| 
 | |
|             db.MappingColumns.Add("Id", "id", "School");
 | |
|             var t2 = db.Queryable<Student, School>((st, sc) => new object[] {
 | |
|                 JoinType.Left,st.SchoolId==sc.Id
 | |
|             })
 | |
|             .Where(st => st.Id == 1)
 | |
|             .Where((st, sc) => sc.Id == 1)
 | |
|             .Where((st, sc) => sc.Id == st.Id)
 | |
|             .GroupBy(st => st.Id)
 | |
|             .GroupBy((st, sc) => sc.Id).OrderBy(st => st.Id, OrderByType.Asc)
 | |
|             .Select((st, sc) => new { stid = st.Id, scid = sc.Id }).ToSql();
 | |
|             base.Check(@"SELECT  [st].[ID] AS [stid] , [sc].[id] AS [scid]  FROM [STudent] st Left JOIN [School] sc ON ( [st].[SchoolId] = [sc].[id] )   WHERE ( [st].[ID] = @Id0 )  AND ( [sc].[id] = @Id1 )  AND ( [sc].[id] = [st].[ID] )GROUP BY [st].[ID],[sc].[id] ORDER BY [st].[ID] ASC ",
 | |
|                 null, t2.Key, null, " Mapping t2 error");
 | |
|             var x2 = GetInstance();
 | |
| 
 | |
|             var q = x2.Queryable<Student>().AS("t");
 | |
|             var t3 = q.ToSql();
 | |
|             var t4 = q.ToSql();
 | |
|             base.Check("SELECT [ID],[SchoolId],[Name],[CreateTime] FROM [t] ", null, t3.Key, null, "Mapping t3 error");
 | |
|             base.Check("SELECT [ID],[SchoolId],[Name],[CreateTime] FROM [t] ", null, t4.Key, null, "Mapping t3 error");
 | |
| 
 | |
|             var x3 = GetInstance2();
 | |
|             x3.MappingTables.Add("Student", "studenT");
 | |
|             int count = 0;
 | |
|             var t5 = x3.Queryable<Student>().ToPageList(1,2,ref count);
 | |
|         }
 | |
| 
 | |
|         public new SqlSugarClient GetInstance()
 | |
|         {
 | |
|             SqlSugarClient db = new SqlSugarClient(new ConnectionConfig() { InitKeyType = InitKeyType.Attribute, ConnectionString = Config.ConnectionString, DbType = DbType.SqlServer, IsAutoCloseConnection = true });
 | |
|             return db;
 | |
|         }
 | |
|         public  SqlSugarClient GetInstance2()
 | |
|         {
 | |
|             SqlSugarClient db = new SqlSugarClient(new ConnectionConfig() { InitKeyType = InitKeyType.Attribute, ConnectionString = Config.ConnectionString, DbType = DbType.SqlServer, IsAutoCloseConnection = true });
 | |
|             db.Ado.IsEnableLogEvent = true;
 | |
|             db.Ado.LogEventStarting = (sql, pars) =>
 | |
|             {
 | |
|                 Console.WriteLine(sql + "\r\n" + db.Utilities.SerializeObject(pars));
 | |
|                 Console.WriteLine();
 | |
|             };
 | |
|             return db;
 | |
|         }
 | |
|     }
 | |
| }
 | 
