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
|
|
|
|
}
|
|
|
|
|
}
|