Files
SqlSugar/OrmTest/UnitTest/Query/SelectQuery.cs

84 lines
3.3 KiB
C#
Raw Normal View History

2017-03-04 01:22:06 +08:00
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using SqlSugar;
using System.Linq.Expressions;
using OrmTest.Models;
2017-03-04 15:07:58 +08:00
namespace OrmTest.UnitTest
2017-03-04 01:22:06 +08:00
{
2017-03-05 00:29:53 +08:00
public class SelectQuery : ExpTestBase
2017-03-04 01:22:06 +08:00
{
2017-03-05 00:29:53 +08:00
private SelectQuery() { }
public SelectQuery(int eachCount)
2017-03-04 01:22:06 +08:00
{
this.Count = eachCount;
}
internal void Init()
{
base.Begin();
for (int i = 0; i < base.Count; i++)
{
Q2();
}
base.End("Method Test");
}
public void Q2()
{
using (var db = GetInstance())
{
2017-04-09 17:03:07 +08:00
//db.Database.IsEnableLogEvent = true;
2017-03-16 10:42:31 +08:00
db.Database.LogEventStarting = (sql, pars) =>
2017-03-11 09:51:58 +08:00
{
2017-03-16 10:42:31 +08:00
Console.WriteLine(sql + " " + pars);
2017-03-11 09:51:58 +08:00
};
2017-03-16 10:42:31 +08:00
2017-04-09 14:39:08 +08:00
#region dr ot entity
db.IgnoreComumns.Add("TestId", "Student");
2017-04-29 21:25:31 +08:00
var s1 = db.Queryable<Student>().Select(it => new ViewModelStudent2 { Name=it.Name,Student=it}).ToList();
var s2 = db.Queryable<Student>().Select(it => new { id=it.Id,w=new { x=it } }).ToList();
var s3 = db.Queryable<Student>().Select(it => new { newid = it.Id }).ToList();
var s4 = db.Queryable<Student>().Select(it => new { newid = it.Id, obj = it }).ToList();
var s5 = db.Queryable<Student>().Select(it => new ViewModelStudent2 { Student = it, Name =it.Name }).ToList();
2017-04-09 14:39:08 +08:00
#endregion
#region sql and parameters validate
2017-04-29 21:25:31 +08:00
var ss1 = db.Queryable<School, School>((st, st2) => new object[] {
2017-03-26 15:18:17 +08:00
JoinType.Left,st.Id==st2.Id
})
2017-04-09 14:39:08 +08:00
.Where(st => st.Id > 0)
.Select<School, School, dynamic>((st, st2) => new { stid = st.Id, scId = st2.Id, xx = st }).ToSql();
2017-04-09 07:30:15 +08:00
2017-04-29 21:25:31 +08:00
base.Check("SELECT [st].[Id] AS [stid] , [st2].[Id] AS [scId] , [st].[Id] AS [School.Id] , [st].[Name] AS [School.Name] FROM [School] st Left JOIN School st2 ON ( [st].[Id] = [st2].[Id] ) WHERE ( [st].[Id] > @Id0 ) "
2017-04-09 07:30:15 +08:00
, new List<SugarParameter>() {
new SugarParameter("@Id0",0)
2017-04-29 21:25:31 +08:00
}, ss1.Key, ss1.Value, "ss1错误");
2017-03-08 14:01:41 +08:00
2017-03-08 16:46:34 +08:00
2017-04-29 21:33:38 +08:00
var ss2 = db.Queryable<Student, School, School>((st, sc, sc2) => new object[] {
2017-03-08 16:46:34 +08:00
JoinType.Left,st.SchoolId==sc.Id,
JoinType.Left,sc2.Id==sc.Id
2017-03-11 10:16:05 +08:00
}).Where(st => st.Id > 0)
2017-04-29 21:33:38 +08:00
.Select<School>((st) => new School() { Id = st.Id }).ToSql();
base.Check("SELECT [st].[Id] AS [Id] FROM [Student] st Left JOIN School sc ON ( [st].[SchoolId] = [sc].[Id] ) Left JOIN School sc2 ON ( [sc2].[Id] = [sc].[Id] ) WHERE ( [st].[Id] > @Id0 ) ",
new List<SugarParameter>() {
new SugarParameter("@Id0",0)
}, ss2.Key, ss2.Value, "ss2错误");
2017-04-09 14:39:08 +08:00
#endregion
2017-04-09 17:03:07 +08:00
2017-03-04 01:22:06 +08:00
}
}
public SqlSugarClient GetInstance()
{
SqlSugarClient db = new SqlSugarClient(new SystemTablesConfig() { ConnectionString = Config.ConnectionString, DbType = DbType.SqlServer });
return db;
}
}
}