2022-04-10 02:34:26 +08:00 
										
									 
								 
							 
							
								
							 
							
								 
							
								
									
										 
							
							
								  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								using  SqlSugar ;  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								using  System ;  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								using  System.Collections.Generic ;  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								using  System.Linq ;  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								using  System.Text ;  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								using  System.Threading.Tasks ;  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								namespace  OrmTest  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								{  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								    public  class  UCustom012 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								    { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								        public  static  void  Init ( ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								        { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            var  db  =  NewUnitTest . Db ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-04-12 08:49:37 +08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
								
									
								 
							
							
								            db . CodeFirst . InitTables < StudentA ,  RoomA ,  SchoolA ,  TeacherA > ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            db . CodeFirst . InitTables < BookA > ( ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2022-04-10 02:34:26 +08:00 
										
									 
								 
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            db . DbMaintenance . TruncateTable < StudentA > ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            db . DbMaintenance . TruncateTable < RoomA > ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            db . DbMaintenance . TruncateTable < SchoolA > ( ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2022-04-12 08:49:37 +08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
								
									
								 
							
							
								            db . DbMaintenance . TruncateTable < TeacherA > ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            db . DbMaintenance . TruncateTable < BookA > ( ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2022-04-10 02:34:26 +08:00 
										
									 
								 
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            db . Insertable ( new  RoomA ( )  {  RoomId  =  1 ,  RoomName  =  "北大001室" ,  SchoolId  =  1  } ) . ExecuteCommand ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            db . Insertable ( new  RoomA ( )  {  RoomId  =  2 ,  RoomName  =  "北大002室" ,  SchoolId  =  1  } ) . ExecuteCommand ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            db . Insertable ( new  RoomA ( )  {  RoomId  =  3 ,  RoomName  =  "北大003室" ,  SchoolId  =  1  } ) . ExecuteCommand ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            db . Insertable ( new  RoomA ( )  {  RoomId  =  4 ,  RoomName  =  "清华001厅" ,  SchoolId  =  2  } ) . ExecuteCommand ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            db . Insertable ( new  RoomA ( )  {  RoomId  =  5 ,  RoomName  =  "清华002厅" ,  SchoolId  =  2  } ) . ExecuteCommand ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            db . Insertable ( new  RoomA ( )  {  RoomId  =  6 ,  RoomName  =  "清华003厅" ,  SchoolId  =  2  } ) . ExecuteCommand ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            db . Insertable ( new  SchoolA ( )  {  SchoolId  =  1 ,  SchoolName  =  "北大"  } ) . ExecuteCommand ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            db . Insertable ( new  SchoolA ( )  {  SchoolId  =  2 ,  SchoolName  =  "清华"  } ) . ExecuteCommand ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            db . Insertable ( new  StudentA ( )  {  StudentId  =  1 ,  SchoolId  =  1 ,  Name  =  "北大jack"  } ) . ExecuteCommand ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            db . Insertable ( new  StudentA ( )  {  StudentId  =  2 ,  SchoolId  =  1 ,  Name  =  "北大tom"  } ) . ExecuteCommand ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            db . Insertable ( new  StudentA ( )  {  StudentId  =  3 ,  SchoolId  =  2 ,  Name  =  "清华jack"  } ) . ExecuteCommand ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            db . Insertable ( new  StudentA ( )  {  StudentId  =  4 ,  SchoolId  =  2 ,  Name  =  "清华tom"  } ) . ExecuteCommand ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-04-12 08:49:37 +08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
								
									
								 
							
							
								            db . Insertable ( new  TeacherA ( )  {  SchoolId  =  1 ,  Id  =  1 ,  Name  =  "北大老师01"  } ) . ExecuteCommand ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            db . Insertable ( new  TeacherA ( )  {  SchoolId  =  1 ,  Id  =  2 ,  Name  =  "北大老师02"  } ) . ExecuteCommand ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            db . Insertable ( new  TeacherA ( )  {  SchoolId  =  2 ,  Id  =  3 ,  Name  =  "清华老师01"  } ) . ExecuteCommand ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            db . Insertable ( new  TeacherA ( )  {  SchoolId  =  2 ,  Id  =  4 ,  Name  =  "清华老师02"  } ) . ExecuteCommand ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-04-13 23:01:54 +08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
								
									
								 
							
							
								            db . Insertable ( new  BookA ( )  {  BookId = 1 ,  Name = "java"  ,  studenId = 1  } ) . ExecuteCommand ( ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2022-04-12 08:49:37 +08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
								
									
								 
							
							
								            db . Insertable ( new  BookA ( )  {  BookId  =  2 ,  Name  =  "c#2" ,  studenId  =  2  } ) . ExecuteCommand ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            db . Insertable ( new  BookA ( )  {  BookId  =  3 ,  Name  =  "c#1" ,  studenId  =  2  } ) . ExecuteCommand ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            db . Insertable ( new  BookA ( )  {  BookId  =  4 ,  Name  =  "php" ,  studenId  =  3  } ) . ExecuteCommand ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            db . Insertable ( new  BookA ( )  {  BookId  =  5 ,  Name  =  "js" ,  studenId  =  4  } ) . ExecuteCommand ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-04-13 23:01:54 +08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
								
									
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            var  list2  =  db . Queryable < StudentA > ( ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								           . Includes ( x  = >  x . SchoolA ,  x  = >  x . RoomList ) //2个参数就是 then Include  
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								           . Includes ( x  = >  x . Books ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								           . Where ( x = > x . Books . Any ( z = > z . BookId = = 1 ) ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								           . Where ( x  = >  x . SchoolA . SchoolName  = =  "北大" ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								           . ToList ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2023-08-30 15:55:46 +08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
								
									
								 
							
							
								            var  list2222 =  db . Queryable < StudentA > ( ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            . Includes ( x  = >  x . SchoolA ,  x  = >  x . RoomList ) //2个参数就是 then Include  
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            . Includes ( x  = >  x . Books )  
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            . Select ( it = > new  {  
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								               a1 = it . SchoolA , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								               a2 = it . Books 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            } ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            . ToList ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            if  ( list2222 . First ( ) . a1 ? . RoomList ? . Any ( )  ! =  true  | |  ! list2222 . First ( ) . a2 . Any ( ) )  
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								                throw  new  Exception ( "unit error" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            }  
							 
						 
					
						
							
								
									
										
										
										
											2022-11-25 13:42:32 +08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
								
									
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2023-08-09 21:11:07 +08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
								
									
								 
							
							
								            db . QueryFilter . AddTableFilter < BookA > ( x  = >  x . Name  = =  "a" ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2022-11-25 13:42:32 +08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
								
									
								 
							
							
								            var  list22  =  db . Queryable < StudentA > ( ) 
							 
						 
					
						
							
								
									
										
										
										
											2023-08-09 21:11:07 +08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
								
									
								 
							
							
								           . Includes ( x  = >  x . Books ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								           . Where ( x  = >  x . Books . Any ( z  = >  z . BookId  = =  1 )  | |  x . Books . Any ( z  = >  z . BookId  = =  1 ) ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								           . ToList ( ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2023-08-12 17:37:11 +08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
								
									
								 
							
							
								            db . QueryFilter . Clear ( ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2023-08-09 21:11:07 +08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
								
									
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            var  list222  =  db . Queryable < StudentA > ( ) 
							 
						 
					
						
							
								
									
										
										
										
											2022-11-25 13:42:32 +08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
								
									
								 
							
							
								            . Includes ( x  = >  x . SchoolA . ToList ( it = > new  SchoolA ( )  {   SchoolId = it . SchoolId } ) ,  x  = >  x . RoomList . ToList ( it = > new  RoomA ( )  {  RoomId = it . RoomId } ) )  
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            . ToList ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-04-10 02:34:26 +08:00 
										
									 
								 
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            //先用Mapper导航映射查出第二层 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            var  list  =  db . Queryable < StudentA > ( ) . Mapper ( x  = >  x . SchoolA ,  x  = >  x . SchoolId ) . ToList ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
										 
							
							
								            //参数1 :将第二层对象合并成一个集合  参数2:  
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
										 
							
							
								            //说明:  
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            db . ThenMapper ( list . Select ( it  = >  it . SchoolA ) ,  sch  = > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
										 
							
							
								                //参数1: room表关联字段  参数2: school表关联字段,  
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								                sch . RoomList  =  db . Queryable < RoomA > ( ) . SetContext ( room  = >  room . SchoolId ,  ( )  = >  sch . SchoolId ,  sch ) . ToList ( ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2022-04-12 08:49:37 +08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
								
									
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								                sch . TeacherList  =  db . Queryable < TeacherA > ( ) . SetContext ( teachera  = >  teachera . SchoolId ,  ( )  = >  sch . SchoolId ,  sch ) . ToList ( ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2022-04-10 02:34:26 +08:00 
										
									 
								 
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            } ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2022-04-13 23:01:54 +08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
								
									
								 
							
							
								     
							 
						 
					
						
							
								
									
										
										
										
											2022-04-10 02:34:26 +08:00 
										
									 
								 
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-04-13 23:01:54 +08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
								
									
								 
							
							
								       
							 
						 
					
						
							
								
									
										
										
										
											2022-04-12 08:49:37 +08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
								
									
								 
							
							
								            db . CodeFirst . InitTables < A1 ,  B1 ,  ABMapping1 > ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            db . DbMaintenance . TruncateTable < A1 > ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            db . DbMaintenance . TruncateTable < B1 > ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            db . DbMaintenance . TruncateTable < ABMapping1 > ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            db . Insertable ( new  A1 ( )  {  Id  =  1 ,  Name  =  "a1"  } ) . ExecuteCommand ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            db . Insertable ( new  A1 ( )  {  Id  =  2 ,  Name  =  "a2"  } ) . ExecuteCommand ( ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2022-04-13 23:01:54 +08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
								
									
								 
							
							
								            db . Insertable ( new  A1 ( )  {  Id  =  3 ,  Name  =  "a3"  } ) . ExecuteCommand ( ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2022-04-12 08:49:37 +08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
								
									
								 
							
							
								            db . Insertable ( new  B1 ( )  {  Id  =  1 ,  Name  =  "b1"  } ) . ExecuteCommand ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            db . Insertable ( new  B1 ( )  {  Id  =  2 ,  Name  =  "b2"  } ) . ExecuteCommand ( ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2022-04-13 23:01:54 +08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
								
									
								 
							
							
								            db . Insertable ( new  ABMapping1 ( )  {   AId = 1 , BId = 1  } ) . ExecuteCommand ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            db . Insertable ( new  ABMapping1 ( )  {  AId  = 2 ,  BId  =  1  } ) . ExecuteCommand ( ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2022-04-12 08:49:37 +08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
								
									
								 
							
							
								            db . Insertable ( new  ABMapping1 ( )  {  AId  =  2 ,  BId  =  2  } ) . ExecuteCommand ( ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2022-04-13 23:01:54 +08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
								
									
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            var  list3 =  db . Queryable < A1 > ( ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								                . Includes ( x  = >  x . BList . Where ( it = > it . Id = = 1 ) . ToList ( ) ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								                . Where ( x = > x . BList . Any ( ) ) . ToList ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            var  list31  =  db . Queryable < A1 > ( ) . Includes ( x  = >  x . BList , x = > x . AList ) . ToList ( ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2022-04-12 08:49:37 +08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
								
									
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            db . CodeFirst . InitTables ( typeof ( Tree1 ) ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            db . DbMaintenance . TruncateTable ( "Tree1" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            db . Insertable ( new  Tree1 ( )  {  Id  =  1 ,  Name  =  "01"  } ) . ExecuteCommand ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            db . Insertable ( new  Tree1 ( )  {  Id  =  2 ,  Name  =  "0101" ,  ParentId  =  1  } ) . ExecuteCommand ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            db . Insertable ( new  Tree1 ( )  {  Id  =  3 ,  Name  =  "0102" ,  ParentId  =  1  } ) . ExecuteCommand ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            db . Insertable ( new  Tree1 ( )  {  Id  =  4 ,  Name  =  "02"  } ) . ExecuteCommand ( ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2022-04-13 23:01:54 +08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
								
									
								 
							
							
								            db . Insertable ( new  Tree1 ( )  {  Id  =  5 ,  Name  =  "0201" ,  ParentId  =  2  } ) . ExecuteCommand ( ) ;  
							 
						 
					
						
							
								
									
										
										
										
											2022-04-12 08:49:37 +08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
								
									
								 
							
							
								            db . Insertable ( new  Tree1 ( )  {  Id  =  6 ,  Name  =  "020101" ,  ParentId  =  5  } ) . ExecuteCommand ( ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2023-10-13 20:08:27 +08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
								
									
								 
							
							
								            db . Insertable ( new  Tree1 ( )  {  Id  =  7 ,  Name  =  "02010101" ,  ParentId  =  6  } ) . ExecuteCommand ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            var  tree1 = db . Queryable < Tree1 > ( ) . Includes ( x  = >  x . Parent . Parent ) . ToList ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            if  ( tree1 . Last ( ) . Parent . Parent  = =  null )  
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								                throw  new  Exception ( "unit error" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            var  tree2  =  db . Queryable < Tree1 > ( ) . Includes ( x  = >  x . Parent . Parent . Parent ) . ToList ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            if  ( tree2 . Last ( ) . Parent . Parent . Parent  = =  null ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								                throw  new  Exception ( "unit error" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            var  tree3  =  db . Queryable < Tree1 > ( ) . Includes ( x  = >  x . Parent . Parent . Parent . Parent ) . ToList ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            if  ( tree3 . Last ( ) . Parent . Parent . Parent . Parent  = =  null ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								                throw  new  Exception ( "unit error" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            } 
							 
						 
					
						
							
								
									
										
										
										
											2022-04-13 23:01:54 +08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
								
									
								 
							
							
								            var  list21111  =  new  List < Tree1 > ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								           var  xxx =  db . Queryable < Tree1 > ( ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								                . Includes ( it  = >  it . Child ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								                . Includes ( it  = >  it . Parent ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								                . Where ( it = > it . Child . Any ( ) ) 
							 
						 
					
						
							
								
									
										
										
										
											2022-04-12 08:49:37 +08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
								
									
								 
							
							
								                . ToList ( ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2022-04-13 23:01:54 +08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
								
									
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            db . ThenMapper ( xxx ,  it  = > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								                it . Child  =  it . Child . OrderBy ( x  = >  x . Id ) . ToList ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            } ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2022-04-12 08:49:37 +08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
								
									
								 
							
							
								            //var json = db.Utilities.SerializeObject(list4); 
							 
						 
					
						
							
								
									
										
										
										
											2022-04-13 23:01:54 +08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
								
									
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            db . CodeFirst . InitTables < UnitA001 ,  UnitA002 > ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            db . DbMaintenance . TruncateTable < UnitA001 > ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            db . DbMaintenance . TruncateTable < UnitA002 > ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            db . Insertable ( new  UnitA001 ( )  {  id  =  1 ,  name1  =  "a" ,  orgid  =  "1"  } ) . ExecuteCommand ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            db . Insertable ( new  UnitA002 ( )  {  id  =  1 ,  name2 =  "a2" ,  orgid  =  "1"  } ) . ExecuteCommand ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            var  list5 = db . Queryable < UnitA001 > ( ) . ToList ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            db . ThenMapper ( list5 ,  it  = > 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								                it . UnitA002  =  db . Queryable < UnitA002 > ( ) . SetContext ( x  = >  x . orgid ,  ( )  = >  it . id ,  it ) . First ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            } ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2022-11-27 13:40:12 +08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
								
									
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								           var  list4 = db . Queryable < SchoolA > ( ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								                . LeftJoin < StudentA > ( ( x ,  y )  = >  ( x . SchoolId  = =  y . SchoolId ) ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								                . LeftJoin < BookA > ( ( x , y , z ) = > y . SchoolId = = y . SchoolId ) 
							 
						 
					
						
							
								
									
										
										
										
											2022-11-27 16:55:43 +08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
								
									
								 
							
							
								                . LeftJoin < BookA > ( ( x ,  y ,  z , z1 )  = >  y . SchoolId  = =  y . SchoolId ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								                . Select ( ( x , y , z , z1 )  = >  new   
							 
						 
					
						
							
								
									
										
										
										
											2022-11-27 13:40:12 +08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
								
									
								 
							
							
								                { 
							 
						 
					
						
							
								
									
										
										
										
											2022-11-27 16:55:43 +08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
								
									
								 
							
							
								                     SchoolName =  x . SchoolName , 
							 
						 
					
						
							
								
									
										
										
										
											2022-11-27 16:10:15 +08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
								
									
								 
							
							
								                      Id = "1" 
							 
						 
					
						
							
								
									
										
										
										
											2022-11-27 16:55:43 +08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
								
									
								 
							
							
								                } ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								                . MergeTable ( ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								                . Select ( it = > new  UnitView01 ( )  { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								                 Name = "a" 
							 
						 
					
						
							
								
									
										
										
										
											2022-11-27 13:40:12 +08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
								
									
								 
							
							
								                } , true ) . ToList ( ) ; 
							 
						 
					
						
							
								
									
										
										
										
											2022-11-27 16:55:43 +08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
								
									
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            db . Queryable < SchoolA > ( ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								             . LeftJoin < StudentA > ( ( x ,  y )  = >  ( x . SchoolId  = =  y . SchoolId ) ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								             . LeftJoin < BookA > ( ( x ,  y ,  z )  = >  y . SchoolId  = =  y . SchoolId ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								             . Select ( ( x , y , z )  = >  new  UnitView01 ( ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								             { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								                 Name  =  "a" 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								             } , true ) . ToList ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            var  list6  =  db . Queryable < SchoolA > ( ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								             . LeftJoin < StudentA > ( ( x ,  y )  = >  ( x . SchoolId  = =  y . SchoolId ) ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								             . LeftJoin < BookA > ( ( x ,  y ,  z )  = >  y . SchoolId  = =  y . SchoolId ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								             . Select ( ( x ,  y ,  z )  = >  new  UnitView01 ( ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								             { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								                 Name  =  "a" 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								             } ,  true ) . ToSql ( ) . Key ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2023-01-12 23:01:16 +08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
								
									
								 
							
							
								            if  ( list6  ! =  "SELECT @constant0 AS [Name] ,[x].[SchoolName] AS [SchoolName] ,[y].[StudentId] AS [StudentId] ,[z].[BookId] AS [BookId] FROM [SchoolA] [x] Left JOIN [StudentA] [y] ON ( [x].[SchoolId] = [y].[SchoolId] )  Left JOIN [BookA] [z] ON ( [y].[SchoolId] = [y].[SchoolId] )  " ) 
							 
						 
					
						
							
								
									
										
										
										
											2022-11-27 16:55:43 +08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
								
									
								 
							
							
								            { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								                throw  new  Exception ( "unit error" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            db . Queryable < SchoolA > ( ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            . Select ( x  = >  new  UnitView01 ( ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								                Name  =  "a" 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            } ,  true ) . ToList ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            var  list7  =  db . Queryable < SchoolA > ( ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								               . Select ( x  = >  new  UnitView01 ( ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								               { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								                   Name  =  "a" 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								               } ,  true ) . ToSql ( ) . Key ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            if  ( list7  ! =  "SELECT @constant0 AS [Name] ,[SchoolName] AS [SchoolName] FROM [SchoolA] " )  
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								                throw  new  Exception ( "unit error" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            db . Queryable < SchoolA > ( ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            . LeftJoin < StudentA > ( ( x ,  y )  = >  ( x . SchoolId  = =  y . SchoolId ) ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            . Select ( ( x ,  y )  = >  new  UnitView01 ( ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								                Name  =  "a" 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            } ,  true ) . ToList ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            var  list8  =  db . Queryable < SchoolA > ( ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								             . LeftJoin < StudentA > ( ( x ,  y )  = >  ( x . SchoolId  = =  y . SchoolId ) ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								             . Select ( ( x ,  y )  = >  new  UnitView01 ( ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								             { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								                 Name  =  "a" 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								             } ,  true ) . ToSql ( ) . Key ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2023-01-12 23:01:16 +08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
								
									
								 
							
							
								            if  ( list8  ! =  "SELECT @constant0 AS [Name] ,[x].[SchoolName] AS [SchoolName] ,[y].[StudentId] AS [StudentId] FROM [SchoolA] [x] Left JOIN [StudentA] [y] ON ( [x].[SchoolId] = [y].[SchoolId] )  " ) 
							 
						 
					
						
							
								
									
										
										
										
											2022-11-27 16:55:43 +08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
								
									
								 
							
							
								            { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								                throw  new  Exception ( "unit error" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            } 
							 
						 
					
						
							
								
									
										
										
										
											2023-06-30 19:18:00 +08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
								
									
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            var  listxxx  =  db . Queryable < SchoolA > ( ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								             . Includes ( it  = >  it . RoomList ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            //.LeftJoin<StudentA>((x, y) => (x.SchoolId == y.SchoolId)) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            //.LeftJoin<BookA>((x, y, z) => y.SchoolId == y.SchoolId) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            . Select ( x  = >  new  SchoolA ( ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								                SchoolId  =  x . SchoolId , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								                RoomList  =  x . RoomList 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            } ,  true ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            . MergeTable ( ) . Clone ( ) . ToList ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            if  ( ! listxxx . First ( ) . RoomList . Any ( ) )  
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								                throw  new  Exception ( "unit error" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            } 
							 
						 
					
						
							
								
									
										
										
										
											2023-07-08 15:02:16 +08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
								
									
								 
							
							
								            var  listxxxx  =  db . Queryable < SchoolA > ( ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								           . Includes ( it  = >  it . RoomList ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								           . LeftJoin < StudentA > ( ( x ,  y )  = >  ( x . SchoolId  = =  y . SchoolId ) ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								          //.LeftJoin<BookA>((x, y, z) => y.SchoolId == y.SchoolId) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								          . Select ( x  = >  new  SchoolA ( ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								          { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								              SchoolId  =  1 , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								              SchoolName = x . SchoolName , 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								              RoomList  =  x . RoomList 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								          } ) . ToList ( ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								          if  ( ! listxxxx . First ( ) . RoomList . Any ( ) ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								          { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								                throw  new  Exception ( "unit error" ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								          } 
							 
						 
					
						
							
								
									
										
										
										
											2023-07-08 20:02:04 +08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
								
									
								 
							
							
								            var  listxxxx2  =  db . Queryable < SchoolA > ( ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								        . Includes ( it  = >  it . RoomList ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								        . LeftJoin < StudentA > ( ( x ,  y )  = >  ( x . SchoolId  = =  y . SchoolId ) ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								       //.LeftJoin<BookA>((x, y, z) => y.SchoolId == y.SchoolId) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								       . Sum ( x = > x . SchoolId ) ; 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-11-27 13:40:12 +08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
								
									
								 
							
							
								        } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								        public  class  UnitView01  
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								        { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            public  string  Id  {  get ;  set ;  } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            public  string  SchoolName  {  get ;  set ;  } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            public  string  Name  {  get ;  set ;  } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            public  int  BookId  {  get ;  set ;  } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            public  int  StudentId  {  get ;  set ;  } 
							 
						 
					
						
							
								
									
										
										
										
											2022-04-12 08:49:37 +08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
								
									
								 
							
							
								        } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-04-13 23:01:54 +08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
								
									
								 
							
							
								        public  class  UnitA001 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								        { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            public  int  id  {  get ;  set ;  } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            public  string  name1  {  get ;  set ;  } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            public  string  orgid  {  get ;  set ;  } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            [SugarColumn(IsIgnore =true)]  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            public  UnitA002  UnitA002  {  get ;  set ;  } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								        } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								        public  class  UnitA002 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								        { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            public  int  id  {  get ;  set ;  } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            public  string  name2 {  get ;  set ;  } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            public  string  orgid  {  get ;  set ;  } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								        } 
							 
						 
					
						
							
								
									
										
										
										
											2022-04-12 08:49:37 +08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
								
									
								 
							
							
								        public  class  Tree1 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								        { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            [SqlSugar.SugarColumn(IsPrimaryKey = true)]  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            public  int  Id  {  get ;  set ;  } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            public  string  Name  {  get ;  set ;  } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            public  int  ParentId  {  get ;  set ;  } 
							 
						 
					
						
							
								
									
										
										
										
											2022-04-14 13:50:19 +08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
								
									
								 
							
							
								            [Navigate(NavigateType.OneToOne,nameof(ParentId))]  
						 
					
						
							
								
									
										
										
										
											2022-04-12 08:49:37 +08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
								
									
								 
							
							
								            public  Tree1  Parent  {  get ;  set ;  } 
							 
						 
					
						
							
								
									
										
										
										
											2022-04-14 13:50:19 +08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
								
									
								 
							
							
								            [Navigate(NavigateType.OneToMany,nameof(Tree1.ParentId))]  
						 
					
						
							
								
									
										
										
										
											2022-04-12 08:49:37 +08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
								
									
								 
							
							
								            public  List < Tree1 >  Child  {  get ;  set ;  } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								        } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								        public  class  ABMapping1 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								        { 
							 
						 
					
						
							
								
									
										
										
										
											2022-04-13 23:01:54 +08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
								
									
								 
							
							
								            [SugarColumn(IsPrimaryKey = true )]  
						 
					
						
							
								
									
										
										
										
											2022-04-12 08:49:37 +08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
								
									
								 
							
							
								            public  int  AId  {  get ;  set ;  } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            [SugarColumn(IsPrimaryKey = true)]  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            public  int  BId  {  get ;  set ;  } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								        } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								        public  class  A1 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								        { 
							 
						 
					
						
							
								
									
										
										
										
											2022-04-13 23:01:54 +08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
								
									
								 
							
							
								            [SugarColumn(IsPrimaryKey = true  )]  
						 
					
						
							
								
									
										
										
										
											2022-04-12 08:49:37 +08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
								
									
								 
							
							
								            public  int  Id  {  get ;  set ;  } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            public  string  Name  {  get ;  set ;  } 
							 
						 
					
						
							
								
									
										
										
										
											2022-04-14 13:50:19 +08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
								
									
								 
							
							
								            [Navigate(typeof(ABMapping1),nameof(ABMapping1.AId),nameof(ABMapping1.BId))]  
						 
					
						
							
								
									
										
										
										
											2022-04-12 08:49:37 +08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
								
									
								 
							
							
								            public  List < B1 >  BList  {  get ;  set ;  } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								        } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								        public  class  B1 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								        { 
							 
						 
					
						
							
								
									
										
										
										
											2022-04-13 23:01:54 +08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
								
									
								 
							
							
								            [SugarColumn(IsPrimaryKey = true )]  
						 
					
						
							
								
									
										
										
										
											2022-04-12 08:49:37 +08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
								
									
								 
							
							
								            public  int  Id  {  get ;  set ;  } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            public  string  Name  {  get ;  set ;  } 
							 
						 
					
						
							
								
									
										
										
										
											2022-04-14 13:50:19 +08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
								
									
								 
							
							
								            [Navigate(typeof(ABMapping1), nameof(ABMapping1.BId), nameof(ABMapping1.AId))]  
						 
					
						
							
								
									
										
										
										
											2022-04-12 08:49:37 +08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
								
									
								 
							
							
								            public  List < A1 >  AList  {  get ;  set ;  } 
							 
						 
					
						
							
								
									
										
										
										
											2022-04-10 02:34:26 +08:00 
										
									 
								 
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								        } 
							 
						 
					
						
							
								
									
										
										
										
											2022-04-12 08:49:37 +08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
								
									
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-04-10 02:34:26 +08:00 
										
									 
								 
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								        public  class  StudentA 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								        { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            [SugarColumn(IsPrimaryKey = true)]  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            public  int  StudentId  {  get ;  set ;  } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            public  string  Name  {  get ;  set ;  } 
							 
						 
					
						
							
								
									
										
										
										
											2022-04-21 18:19:02 +08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
								
									
								 
							
							
								            [SugarColumn(IsNullable =true)]  
						 
					
						
							
								
									
										
										
										
											2022-04-10 02:34:26 +08:00 
										
									 
								 
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            public  int  SchoolId  {  get ;  set ;  } 
							 
						 
					
						
							
								
									
										
										
										
											2022-04-14 13:50:19 +08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
								
									
								 
							
							
								            [Navigate(NavigateType.OneToOne, nameof(SchoolId))]  
						 
					
						
							
								
									
										
										
										
											2022-04-10 02:34:26 +08:00 
										
									 
								 
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            public  SchoolA  SchoolA  {  get ;  set ;  } 
							 
						 
					
						
							
								
									
										
										
										
											2022-04-14 13:50:19 +08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
								
									
								 
							
							
								            [Navigate(NavigateType.OneToMany, nameof(BookA.studenId))]  
						 
					
						
							
								
									
										
										
										
											2022-04-12 08:49:37 +08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
								
									
								 
							
							
								            public  List < BookA >  Books  {  get ;  set ;  } 
							 
						 
					
						
							
								
									
										
										
										
											2022-04-10 02:34:26 +08:00 
										
									 
								 
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2022-04-12 08:49:37 +08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
								
									
								 
							
							
								        } 
							 
						 
					
						
							
								
									
										
										
										
											2022-04-10 02:34:26 +08:00 
										
									 
								 
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								        public  class  SchoolA 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								        { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            [SugarColumn(IsPrimaryKey = true)]  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            public  int  SchoolId  {  get ;  set ;  } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            public  string  SchoolName  {  get ;  set ;  } 
							 
						 
					
						
							
								
									
										
										
										
											2022-04-14 13:50:19 +08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
								
									
								 
							
							
								            [Navigate(NavigateType.OneToMany,nameof(RoomA.SchoolId))]  
						 
					
						
							
								
									
										
										
										
											2022-04-10 02:34:26 +08:00 
										
									 
								 
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            public  List < RoomA >  RoomList  {  get ;  set ;  } 
							 
						 
					
						
							
								
									
										
										
										
											2022-04-12 08:49:37 +08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
								
									
								 
							
							
								            [SugarColumn(IsIgnore = true)]  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            public  List < TeacherA >  TeacherList  {  get ;  set ;  } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								        } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								        public  class  TeacherA 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								        { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            [SugarColumn(IsPrimaryKey = true)]  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            public  int  Id  {  get ;  set ;  } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            public  int  SchoolId  {  get ;  set ;  } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            public  string  Name  {  get ;  set ;  } 
							 
						 
					
						
							
								
									
										
										
										
											2022-04-10 02:34:26 +08:00 
										
									 
								 
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								        } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								        public  class  RoomA 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								        { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            [SugarColumn(IsPrimaryKey = true)]  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            public  int  RoomId  {  get ;  set ;  } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            public  string  RoomName  {  get ;  set ;  } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            public  int  SchoolId  {  get ;  set ;  } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								        } 
							 
						 
					
						
							
								
									
										
										
										
											2022-04-12 08:49:37 +08:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
								
									
								 
							
							
								        public  class  BookA 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								        { 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            [SugarColumn(IsPrimaryKey = true)]  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            public  int  BookId  {  get ;  set ;  } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            public  string  Name  {  get ;  set ;  } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								            public  int  studenId  {  get ;  set ;  } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								        } 
							 
						 
					
						
							
								
									
										
										
										
											2022-04-10 02:34:26 +08:00 
										
									 
								 
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								    } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
								
									
								 
							
							
								}