mirror of
https://gitee.com/dotnetchina/SqlSugar.git
synced 2025-04-05 17:37:58 +08:00
Add unit test
This commit is contained in:
parent
8d67a9f28f
commit
bb76c60954
@ -31,6 +31,8 @@ namespace OrmTest
|
||||
}
|
||||
public static void Init()
|
||||
{
|
||||
UCustom015.Init();
|
||||
UCustom014.Init();
|
||||
UCustom012.Init();
|
||||
UCustom01.Init();
|
||||
UCustom02.Init();
|
||||
|
@ -45,12 +45,20 @@ namespace OrmTest
|
||||
db.Insertable(new TeacherA() { SchoolId = 2, Id = 4, Name = "清华老师02" }).ExecuteCommand();
|
||||
|
||||
|
||||
db.Insertable(new BookA() { BookId = 1, Name = "java", studenId = 1 }).ExecuteCommand();
|
||||
db.Insertable(new BookA() { BookId=1, Name="java" , studenId=1 }).ExecuteCommand();
|
||||
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();
|
||||
|
||||
|
||||
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();
|
||||
|
||||
//先用Mapper导航映射查出第二层
|
||||
var list = db.Queryable<StudentA>().Mapper(x => x.SchoolA, x => x.SchoolId).ToList();
|
||||
|
||||
@ -63,25 +71,27 @@ namespace OrmTest
|
||||
|
||||
sch.TeacherList = db.Queryable<TeacherA>().SetContext(teachera => teachera.SchoolId, () => sch.SchoolId, sch).ToList();
|
||||
});
|
||||
|
||||
|
||||
|
||||
var list2 = db.Queryable<StudentA>()
|
||||
.Includes(x => x.SchoolA, x => x.RoomList)//2个参数就是 then Include
|
||||
.Includes(x => x.Books)
|
||||
.ToList();
|
||||
|
||||
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();
|
||||
db.Insertable(new A1() { Id = 3, Name = "a3" }).ExecuteCommand();
|
||||
db.Insertable(new B1() { Id = 1, Name = "b1" }).ExecuteCommand();
|
||||
db.Insertable(new B1() { Id = 2, Name = "b2" }).ExecuteCommand();
|
||||
db.Insertable(new ABMapping1() { AId = 1, BId = 1 }).ExecuteCommand();
|
||||
db.Insertable(new ABMapping1() { AId = 2, BId = 1 }).ExecuteCommand();
|
||||
db.Insertable(new ABMapping1() { AId=1,BId=1 }).ExecuteCommand();
|
||||
db.Insertable(new ABMapping1() { AId =2, BId = 1 }).ExecuteCommand();
|
||||
db.Insertable(new ABMapping1() { AId = 2, BId = 2 }).ExecuteCommand();
|
||||
var list3 = db.Queryable<A1>().Includes(x => x.BList).ToList();
|
||||
var list31 = db.Queryable<A1>().Includes(x => x.BList, x => x.AList).ToList();
|
||||
|
||||
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();
|
||||
|
||||
db.CodeFirst.InitTables(typeof(Tree1));
|
||||
db.DbMaintenance.TruncateTable("Tree1");
|
||||
@ -89,44 +99,79 @@ namespace OrmTest
|
||||
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();
|
||||
db.Insertable(new Tree1() { Id = 5, Name = "0201", ParentId = 2 }).ExecuteCommand();
|
||||
db.Insertable(new Tree1() { Id = 5, Name = "0201", ParentId = 2 }).ExecuteCommand();
|
||||
db.Insertable(new Tree1() { Id = 6, Name = "020101", ParentId = 5 }).ExecuteCommand();
|
||||
var list4 = db.Queryable<Tree1>()
|
||||
.Includes(it => it.Child, it => it.Child, it => it.Child)
|
||||
.Includes(it => it.Parent, it => it.Parent, it => it.Parent, it => it.Parent)
|
||||
|
||||
|
||||
var list21111 = new List<Tree1>();
|
||||
var xxx= db.Queryable<Tree1>()
|
||||
.Includes(it => it.Child)
|
||||
.Includes(it => it.Parent)
|
||||
.Where(it=>it.Child.Any())
|
||||
.ToList();
|
||||
|
||||
db.ThenMapper(xxx, it =>
|
||||
{
|
||||
it.Child = it.Child.OrderBy(x => x.Id).ToList();
|
||||
});
|
||||
//var json = db.Utilities.SerializeObject(list4);
|
||||
|
||||
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();
|
||||
});
|
||||
}
|
||||
|
||||
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; }
|
||||
}
|
||||
public class Tree1
|
||||
{
|
||||
[SqlSugar.SugarColumn(IsPrimaryKey = true)]
|
||||
public int Id { get; set; }
|
||||
public string Name { get; set; }
|
||||
public int ParentId { get; set; }
|
||||
[Navigat(NavigatType.OneToOne, nameof(ParentId))]
|
||||
[Navigat(NavigatType.OneToOne,nameof(ParentId))]
|
||||
public Tree1 Parent { get; set; }
|
||||
[Navigat(NavigatType.OneToMany, nameof(Tree1.ParentId))]
|
||||
[Navigat(NavigatType.OneToMany,nameof(Tree1.ParentId))]
|
||||
public List<Tree1> Child { get; set; }
|
||||
}
|
||||
public class ABMapping1
|
||||
{
|
||||
[SugarColumn(IsPrimaryKey = true)]
|
||||
[SugarColumn(IsPrimaryKey = true )]
|
||||
public int AId { get; set; }
|
||||
[SugarColumn(IsPrimaryKey = true)]
|
||||
public int BId { get; set; }
|
||||
}
|
||||
public class A1
|
||||
{
|
||||
[SugarColumn(IsPrimaryKey = true)]
|
||||
[SugarColumn(IsPrimaryKey = true )]
|
||||
public int Id { get; set; }
|
||||
public string Name { get; set; }
|
||||
[Navigat(typeof(ABMapping1), nameof(ABMapping1.AId), nameof(ABMapping1.BId))]
|
||||
[Navigat(typeof(ABMapping1),nameof(ABMapping1.AId),nameof(ABMapping1.BId))]
|
||||
public List<B1> BList { get; set; }
|
||||
}
|
||||
public class B1
|
||||
{
|
||||
[SugarColumn(IsPrimaryKey = true)]
|
||||
[SugarColumn(IsPrimaryKey = true )]
|
||||
public int Id { get; set; }
|
||||
public string Name { get; set; }
|
||||
[Navigat(typeof(ABMapping1), nameof(ABMapping1.BId), nameof(ABMapping1.AId))]
|
||||
@ -150,7 +195,7 @@ namespace OrmTest
|
||||
[SugarColumn(IsPrimaryKey = true)]
|
||||
public int SchoolId { get; set; }
|
||||
public string SchoolName { get; set; }
|
||||
[Navigat(NavigatType.OneToMany, nameof(RoomA.SchoolId))]
|
||||
[Navigat(NavigatType.OneToMany,nameof(RoomA.SchoolId))]
|
||||
public List<RoomA> RoomList { get; set; }
|
||||
[SugarColumn(IsIgnore = true)]
|
||||
public List<TeacherA> TeacherList { get; set; }
|
||||
|
136
Src/Asp.NetCore2/SqlSeverTest/UnitTest/UCustom014.cs
Normal file
136
Src/Asp.NetCore2/SqlSeverTest/UnitTest/UCustom014.cs
Normal file
@ -0,0 +1,136 @@
|
||||
using SqlSugar;
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
using System.Linq;
|
||||
using System.Text;
|
||||
using System.Threading.Tasks;
|
||||
|
||||
namespace OrmTest
|
||||
{
|
||||
public class UCustom014
|
||||
{
|
||||
|
||||
public static void Init()
|
||||
{
|
||||
var db = new SqlSugarScope(new SqlSugar.ConnectionConfig()
|
||||
{
|
||||
ConnectionString = Config.ConnectionString,
|
||||
DbType = DbType.SqlServer,
|
||||
IsAutoCloseConnection = true
|
||||
});
|
||||
|
||||
db.CodeFirst.InitTables<Country111, Province111, City111>();
|
||||
db.DbMaintenance.TruncateTable("Country_111");
|
||||
db.DbMaintenance.TruncateTable("Province_111");
|
||||
db.DbMaintenance.TruncateTable("City_111");
|
||||
db.Insertable(new List<Country111>()
|
||||
{
|
||||
new Country111(){
|
||||
Id=1,
|
||||
Name="中国",
|
||||
Provinces=new List<Province111>(){
|
||||
new Province111{
|
||||
Id=1001,
|
||||
Name="江苏",
|
||||
citys=new List<City111>(){
|
||||
new City111(){ Id=1001001, Name="南通" },
|
||||
new City111(){ Id=1001002, Name="南京" }
|
||||
}
|
||||
},
|
||||
new Province111{
|
||||
Id=1002,
|
||||
Name="上海",
|
||||
citys=new List<City111>(){
|
||||
new City111(){ Id=1002001, Name="徐汇" },
|
||||
new City111(){ Id=1002002, Name="普陀" }
|
||||
}
|
||||
},
|
||||
new Province111{
|
||||
Id=1003,
|
||||
Name="北京",
|
||||
citys=new List<City111>(){
|
||||
new City111(){ Id=1003001, Name="北京A" },
|
||||
new City111(){ Id=1003002, Name="北京B" }
|
||||
}
|
||||
}
|
||||
}
|
||||
},
|
||||
new Country111(){
|
||||
Name="美国",
|
||||
Id=2,
|
||||
Provinces=new List<Province111>()
|
||||
{
|
||||
new Province111(){
|
||||
Name="美国小A",
|
||||
Id=20001
|
||||
},
|
||||
new Province111(){
|
||||
Name="美国小b",
|
||||
Id=20002
|
||||
}
|
||||
}
|
||||
},
|
||||
new Country111(){
|
||||
Name="英国",
|
||||
Id=3
|
||||
}
|
||||
})
|
||||
.AddSubList(it => new SubInsertTree()
|
||||
{
|
||||
Expression = it.Provinces.First().CountryId,
|
||||
ChildExpression = new List<SubInsertTree>() {
|
||||
new SubInsertTree(){
|
||||
Expression=it.Provinces.First().citys.First().ProvinceId
|
||||
}
|
||||
}
|
||||
}).ExecuteCommand();
|
||||
db.Aop.OnLogExecuted = (sq, p) =>
|
||||
{
|
||||
Console.WriteLine(sq);
|
||||
};
|
||||
var list=db.Queryable<Country111>()
|
||||
.Includes(x => x.Provinces.OrderByDescending(x111=>x111.Id).ToList())
|
||||
.ToList();
|
||||
|
||||
var list2 = db.Queryable<Country111>()
|
||||
.Includes(x => x.Provinces)
|
||||
.Where(x=>x.Provinces.Count()>2)
|
||||
.ToList();
|
||||
|
||||
var list3 = db.Queryable<Country111>()
|
||||
.Includes(x => x.Provinces,x=>x.citys)
|
||||
.ToList();
|
||||
}
|
||||
|
||||
[SugarTable("Country_111")]
|
||||
public class Country111
|
||||
{
|
||||
[SqlSugar.SugarColumn(IsPrimaryKey = true, IsIdentity = true, ColumnName = "cid")]
|
||||
public int Id { get; set; }
|
||||
public string Name { get; set; }
|
||||
|
||||
[Navigat(NavigatType.OneToMany,nameof(Province111.CountryId))]
|
||||
public List<Province111> Provinces { get; set; }
|
||||
}
|
||||
[SugarTable("Province_111")]
|
||||
public class Province111
|
||||
{
|
||||
[SqlSugar.SugarColumn(IsPrimaryKey = true, IsIdentity = true, ColumnName = "pid")]
|
||||
public int Id { get; set; }
|
||||
public string Name { get; set; }
|
||||
[SugarColumn(ColumnName = "coid")]
|
||||
public int CountryId { get; set; }
|
||||
[Navigat(NavigatType.OneToMany, nameof(City111.ProvinceId))]
|
||||
public List<City111> citys { get; set; }
|
||||
}
|
||||
[SugarTable("City_111")]
|
||||
public class City111
|
||||
{
|
||||
[SqlSugar.SugarColumn(IsPrimaryKey = true, IsIdentity = true, ColumnName = "cid")]
|
||||
public int Id { get; set; }
|
||||
[SugarColumn(ColumnName="ppid")]
|
||||
public int ProvinceId { get; set; }
|
||||
public string Name { get; set; }
|
||||
}
|
||||
}
|
||||
}
|
101
Src/Asp.NetCore2/SqlSeverTest/UnitTest/UCustom015.cs
Normal file
101
Src/Asp.NetCore2/SqlSeverTest/UnitTest/UCustom015.cs
Normal file
@ -0,0 +1,101 @@
|
||||
using SqlSugar;
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
using System.Linq;
|
||||
using System.Text;
|
||||
using System.Threading.Tasks;
|
||||
|
||||
namespace OrmTest
|
||||
{
|
||||
public class UCustom015
|
||||
{
|
||||
|
||||
public static void Init()
|
||||
{
|
||||
var db = new SqlSugarScope(new SqlSugar.ConnectionConfig()
|
||||
{
|
||||
ConnectionString = Config.ConnectionString,
|
||||
DbType = DbType.SqlServer,
|
||||
IsAutoCloseConnection = true
|
||||
});
|
||||
db.DbMaintenance.CreateDatabase();
|
||||
|
||||
db.CodeFirst.InitTables<Country1111>();
|
||||
db.CodeFirst.InitTables<Province1111>();
|
||||
db.CodeFirst.InitTables<Country111Info>();
|
||||
db.DbMaintenance.TruncateTable("Country_1111");
|
||||
db.DbMaintenance.TruncateTable("Province_1111");
|
||||
db.DbMaintenance.TruncateTable("Country111Info");
|
||||
var c = new Country1111()
|
||||
{
|
||||
Id=1,
|
||||
Name="中国",InfoId=1
|
||||
};
|
||||
var ps = new List<Province1111>(){
|
||||
new Province1111{
|
||||
Id=1001,
|
||||
Name="江苏", CountryId=1
|
||||
|
||||
},
|
||||
new Province1111{
|
||||
Id=1002,
|
||||
Name="上海", CountryId=1
|
||||
|
||||
},
|
||||
new Province1111{
|
||||
Id=1003,
|
||||
Name="北京", CountryId=1
|
||||
|
||||
}
|
||||
};
|
||||
|
||||
db.Insertable(c).ExecuteCommand();
|
||||
db.Insertable(ps).ExecuteCommand();
|
||||
db.Insertable(new Country111Info { Id=1, Name="infoa"}).ExecuteCommand();
|
||||
db.Aop.OnLogExecuted = (sq, p) =>
|
||||
{
|
||||
Console.WriteLine(sq);
|
||||
};
|
||||
|
||||
var list = db.Queryable<Country1111>()
|
||||
.Includes(x => x.Info)
|
||||
.ToList();
|
||||
var list2 = db.Queryable<Country1111>()
|
||||
.Includes(x => x.Provinces.OrderByDescending(x111 => x111.Id).ToList())
|
||||
.ToList();
|
||||
}
|
||||
|
||||
[SugarTable("Country_1111")]
|
||||
public class Country1111
|
||||
{
|
||||
[SqlSugar.SugarColumn(IsPrimaryKey =true, ColumnName = "cid")]
|
||||
public int Id { get; set; }
|
||||
public string Name { get; set; }
|
||||
public int InfoId { get; set; }
|
||||
|
||||
[Navigat(NavigatType.OneToOne, nameof(InfoId))]
|
||||
public Country111Info Info { get; set; }
|
||||
|
||||
[Navigat(NavigatType.OneToMany,nameof(Province1111.CountryId))]
|
||||
public List<Province1111> Provinces { get; set; }
|
||||
}
|
||||
|
||||
public class Country111Info
|
||||
{
|
||||
[SqlSugar.SugarColumn(IsPrimaryKey =true,ColumnName = "infoId")]
|
||||
public int Id { get; set; }
|
||||
public string Name { get; set; }
|
||||
}
|
||||
|
||||
[SugarTable("Province_1111")]
|
||||
public class Province1111
|
||||
{
|
||||
[SqlSugar.SugarColumn( ColumnName = "pid")]
|
||||
public int Id { get; set; }
|
||||
public string Name { get; set; }
|
||||
[SugarColumn(ColumnName = "coid")]
|
||||
public int CountryId { get; set; }
|
||||
}
|
||||
|
||||
}
|
||||
}
|
Loading…
Reference in New Issue
Block a user