SqlSugar/OrmTest/UnitTest/ExpressionTest/Where.cs

147 lines
6.2 KiB
C#
Raw Normal View History

2017-01-28 14:32:06 +08:00
using OrmTest.Models;
using SqlSugar;
using System;
2017-01-14 20:53:04 +08:00
using System.Collections.Generic;
using System.Linq;
2017-01-28 14:32:06 +08:00
using System.Linq.Expressions;
2017-01-14 20:53:04 +08:00
using System.Text;
using System.Threading.Tasks;
2017-03-04 15:07:58 +08:00
namespace OrmTest.UnitTest
2017-01-14 20:53:04 +08:00
{
2017-01-28 14:32:06 +08:00
public class Where : ExpTestBase
2017-01-14 20:53:04 +08:00
{
2017-01-28 14:32:06 +08:00
private Where() { }
public Where(int eachCount)
{
this.Count = eachCount;
}
internal void Init()
{
base.Begin();
for (int i = 0; i < base.Count; i++)
{
whereSingle1();
whereSingle2();
whereSingle3();
whereSingle4();
2017-01-28 20:43:34 +08:00
whereSingle5();
2017-01-28 20:58:16 +08:00
whereSingle6();
2017-01-28 21:19:48 +08:00
WhereMultiple1();
2017-01-28 21:52:05 +08:00
WhereMultiple2();
2017-01-28 14:32:06 +08:00
}
base.End("Where Test");
}
2017-01-28 21:19:48 +08:00
private void WhereMultiple1()
{
Expression<Func<Student, bool>> exp = it => it.Id > 1;
2017-02-26 23:56:28 +08:00
ExpressionContext expContext = new ExpressionContext();
expContext.Resolve(exp, ResolveExpressType.WhereMultiple);
2017-01-28 21:19:48 +08:00
var value = expContext.Result.GetString();
var pars = expContext.Parameters;
base.Check(value, pars, "( it.Id > @Id0 )", new List<SugarParameter>() {
new SugarParameter("@Id0",1)
}, "WhereMultiple1");
}
2017-01-28 21:52:05 +08:00
private void WhereMultiple2()
{
string name = "a";
WhereConst.name = "a1";
Expression<Func<Student, bool>> exp = it => (it.Id > 1 && it.Name != name || it.Id == 1) || it.Name == WhereConst.name;
2017-02-26 23:56:28 +08:00
ExpressionContext expContext = new ExpressionContext();
expContext.Resolve(exp, ResolveExpressType.WhereMultiple);
2017-01-28 21:52:05 +08:00
var value = expContext.Result.GetString();
var pars = expContext.Parameters;
base.Check(value, pars, " (((( it.Id > @Id0 ) AND ( it.Name <> @Name1 )) OR ( it.Id = @Id2 )) OR ( it.Name = @Name3 ))", new List<SugarParameter>() {
new SugarParameter("@Id0",1),
new SugarParameter("@Name1","a"),
new SugarParameter("@Id2",1),
new SugarParameter("@Name3","a1")
}, "WhereMultiple2");
}
2017-01-28 14:32:06 +08:00
private void whereSingle1()
{
Expression<Func<Student, bool>> exp = it => it.Id > 1;
2017-02-26 23:56:28 +08:00
ExpressionContext expContext = new ExpressionContext();
expContext.Resolve(exp, ResolveExpressType.WhereSingle);
2017-01-28 14:32:06 +08:00
var value = expContext.Result.GetString();
var pars = expContext.Parameters;
2017-01-28 20:13:29 +08:00
base.Check(value, pars, "( Id > @Id0 )", new List<SugarParameter>() {
new SugarParameter("@Id0",1)
2017-01-28 14:32:06 +08:00
}, "whereSingle1");
}
private void whereSingle2()
{
2017-01-28 20:13:29 +08:00
Expression<Func<Student, bool>> exp = it => 1 > it.Id;
2017-02-26 23:56:28 +08:00
ExpressionContext expContext = new ExpressionContext();
expContext.Resolve(exp, ResolveExpressType.WhereSingle);
2017-01-28 14:32:06 +08:00
var value = expContext.Result.GetString();
var pars = expContext.Parameters;
2017-01-28 20:13:29 +08:00
base.Check(value, pars, "( @Id0 > Id )", new List<SugarParameter>() {
new SugarParameter("@Id0",1)
2017-01-28 14:32:06 +08:00
}, "whereSingle2");
}
private void whereSingle3()
{
Expression<Func<Student, bool>> exp = it => it.Id > 1 || it.Name == "a";
2017-02-26 23:56:28 +08:00
ExpressionContext expContext = new ExpressionContext();
expContext.Resolve(exp, ResolveExpressType.WhereSingle);
2017-01-28 14:32:06 +08:00
var value = expContext.Result.GetString();
var pars = expContext.Parameters;
2017-01-28 20:13:29 +08:00
base.Check(value, pars, " (( Id > @Id0 ) OR ( Name = @Name1 ))", new List<SugarParameter>() {
new SugarParameter("@Id0",1),
new SugarParameter("@Name1","a")
}, "whereSingle3");
2017-01-28 14:32:06 +08:00
}
private void whereSingle4()
{
2017-01-28 20:13:29 +08:00
Expression<Func<Student, bool>> exp = it => (it.Id > 1 && it.Name != "a") || it.Name == "a1";
2017-02-26 23:56:28 +08:00
ExpressionContext expContext = new ExpressionContext();
expContext.Resolve(exp, ResolveExpressType.WhereSingle);
2017-01-28 14:32:06 +08:00
var value = expContext.Result.GetString();
var pars = expContext.Parameters;
2017-01-28 20:13:29 +08:00
base.Check(value, pars, " ((( Id > @Id0 ) AND ( Name <> @Name1 )) OR ( Name = @Name2 )) ", new List<SugarParameter>() {
new SugarParameter("@Id0",1),
new SugarParameter("@Name1","a"),
new SugarParameter("@Name2","a1")
2017-01-28 14:32:06 +08:00
}, "whereSingle4");
}
2017-01-28 20:43:34 +08:00
private void whereSingle5()
{
string name = "a";
WhereConst.name = "a1";
Expression<Func<Student, bool>> exp = it => (it.Id > 1 && it.Name != name) || it.Name == WhereConst.name;
2017-02-26 23:56:28 +08:00
ExpressionContext expContext = new ExpressionContext();
expContext.Resolve(exp, ResolveExpressType.WhereSingle);
2017-01-28 20:43:34 +08:00
var value = expContext.Result.GetString();
var pars = expContext.Parameters;
base.Check(value, pars, " ((( Id > @Id0 ) AND ( Name <> @Name1 )) OR ( Name = @Name2 )) ", new List<SugarParameter>() {
new SugarParameter("@Id0",1),
new SugarParameter("@Name1","a"),
new SugarParameter("@Name2","a1")
2017-01-28 20:58:16 +08:00
}, "whereSingle5");
}
private void whereSingle6()
{
string name = "a";
WhereConst.name = "a1";
Expression<Func<Student, bool>> exp = it => (it.Id > 1 && it.Name != name||it.Id==1) || it.Name == WhereConst.name;
2017-02-26 23:56:28 +08:00
ExpressionContext expContext = new ExpressionContext();
expContext.Resolve(exp, ResolveExpressType.WhereSingle);
2017-01-28 20:58:16 +08:00
var value = expContext.Result.GetString();
var pars = expContext.Parameters;
base.Check(value, pars, " (((( Id > @Id0 ) AND ( Name <> @Name1 )) OR ( Id = @Id2 )) OR ( Name = @Name3 ))", new List<SugarParameter>() {
new SugarParameter("@Id0",1),
new SugarParameter("@Name1","a"),
new SugarParameter("@Id2",1),
new SugarParameter("@Name3","a1")
}, "whereSingle6");
2017-01-28 20:43:34 +08:00
}
}
public class WhereConst
{
public static string name { get; set; }
2017-01-14 20:53:04 +08:00
}
}