SqlSugar/OrmTest/UnitTest/Query/JoinQuery.cs

61 lines
1.7 KiB
C#
Raw Normal View History

2017-02-26 23:56:28 +08:00
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
2017-02-27 01:03:56 +08:00
using SqlSugar;
using System.Linq.Expressions;
using OrmTest.Models;
2017-03-04 15:07:58 +08:00
namespace OrmTest.UnitTest
2017-02-26 23:56:28 +08:00
{
2017-03-04 15:07:58 +08:00
public class JoinQuery : ExpTestBase
2017-02-26 23:56:28 +08:00
{
2017-03-04 15:07:58 +08:00
private JoinQuery() { }
public JoinQuery(int eachCount)
2017-02-27 01:03:56 +08:00
{
this.Count = eachCount;
}
internal void Init()
{
base.Begin();
for (int i = 0; i < base.Count; i++)
{
2017-03-05 00:29:53 +08:00
Q1();
2017-02-27 01:03:56 +08:00
Q2();
}
base.End("Method Test");
}
2017-03-05 00:29:53 +08:00
public void Q1()
{
using (var db = GetInstance())
{
var list = db.Queryable<Student, School>((st, sc) => new object[] {
JoinType.Left,st.SchoolId==sc.Id
}).Where(st => st.Id > 0).Select<Student>("*").ToList();
}
}
2017-02-27 01:03:56 +08:00
public void Q2()
{
2017-03-04 00:54:19 +08:00
using (var db = GetInstance())
{
var list = db.Queryable<Student, School>((st, sc) => new object[] {
JoinType.Left,st.SchoolId==sc.Id
2017-03-05 00:29:53 +08:00
}).Where(st=>st.Id>0).Select<Student>("*").ToList();
2017-03-04 00:54:19 +08:00
}
}
2017-02-27 01:03:56 +08:00
2017-03-04 00:54:19 +08:00
public SqlSugarClient GetInstance()
{
SqlSugarClient db = new SqlSugarClient(new SystemTablesConfig() { ConnectionString = Config.ConnectionString, DbType = DbType.SqlServer });
2017-03-05 00:29:53 +08:00
db.Database.IsEnableLogEvent = true;
db.Database.LogEventStarting = (sql, pars) =>
{
Console.WriteLine(sql+" "+pars);
};
2017-03-04 00:54:19 +08:00
return db;
2017-02-27 01:03:56 +08:00
}
2017-02-26 23:56:28 +08:00
}
}