SqlSugar/Src/Asp.Net/SqlServerTest/Demos/1_Query.cs

503 lines
22 KiB
C#
Raw Normal View History

2017-05-21 22:33:21 +08:00
using OrmTest.Models;
using SqlSugar;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
namespace OrmTest.Demo
{
2017-06-13 01:29:01 +08:00
public class Query : DemoBase
2017-05-21 22:33:21 +08:00
{
public static void Init()
{
Easy();
Page();
Where();
Join();
Funs();
Select();
2017-05-22 00:12:23 +08:00
Ado();
2017-05-22 00:30:39 +08:00
Group();
2017-05-22 02:21:43 +08:00
Sqlable();
2017-05-27 01:00:41 +08:00
Tran();
2017-05-27 02:01:33 +08:00
StoredProcedure();
2017-06-04 19:22:05 +08:00
Enum();
2017-06-23 19:44:55 +08:00
Simple();
2017-09-05 11:12:46 +08:00
Async();
2017-09-16 21:27:31 +08:00
Subqueryable();
}
private static void Subqueryable()
{
var db = GetInstance();
2017-09-17 00:29:48 +08:00
var getAll7 = db.Queryable<Student>().Where(it => SqlFunc.Subqueryable<School>().Where(s => s.Id == it.Id).Any()).ToList();
2017-09-17 00:44:46 +08:00
var getAll8= db.Queryable<Student>().Where(it => SqlFunc.Subqueryable<School>().Where(s => s.Id == it.Id).Where(s=>s.Name==it.Name).NotAny()).ToList();
2017-09-17 00:29:48 +08:00
var getAll1 = db.Queryable<Student>().Where(it => it.Id == SqlFunc.Subqueryable<School>().Where(s => s.Id == it.Id).Select(s => s.Id)).ToList();
2017-09-16 21:27:31 +08:00
var getAll2 = db.Queryable<Student, School>((st, sc) => new object[] {
JoinType.Left,st.Id==sc.Id
})
.Where(st => st.Id == SqlFunc.Subqueryable<School>().Where(s => s.Id == st.Id).Select(s => s.Id))
.ToList();
var getAll3 = db.Queryable<Student, School>((st, sc) => new object[] {
JoinType.Left,st.Id==sc.Id
})
2017-09-17 00:29:48 +08:00
.Select(st =>
new
{
name = st.Name,
id = SqlFunc.Subqueryable<School>().Where(s => s.Id == st.Id).Select(s => s.Id)
2017-09-16 21:27:31 +08:00
})
.ToList();
2017-09-16 23:06:20 +08:00
var getAll4 = db.Queryable<Student>().Select(it =>
2017-09-17 00:29:48 +08:00
new
{
name = it.Name,
id = SqlFunc.Subqueryable<School>().Where(s => s.Id == it.Id).Select(s => s.Id)
}).ToList();
2017-09-16 23:09:46 +08:00
var getAll5 = db.Queryable<Student>().Select(it =>
2017-09-17 00:29:48 +08:00
new Student
{
2017-09-16 23:09:46 +08:00
Name = it.Name,
Id = SqlFunc.Subqueryable<School>().Where(s => s.Id == it.Id).Select(s => s.Id)
}).ToList();
2017-09-17 00:29:48 +08:00
2017-09-05 11:12:46 +08:00
}
private static void Async()
{
var db = GetInstance();
2017-09-16 21:27:31 +08:00
var list = db.Queryable<Student>().Where(it => it.Id == 1).SingleAsync();
2017-09-05 11:12:46 +08:00
list.Wait();
2017-09-05 11:31:34 +08:00
var list2 = db.Queryable<Student>().SingleAsync(it => it.Id == 1);
list2.Wait();
2017-09-16 21:27:31 +08:00
var list3 = db.Queryable<Student>().Where(it => it.Id == 1).ToListAsync();
2017-09-05 11:31:34 +08:00
list3.Wait();
2017-09-16 21:27:31 +08:00
var list4 = db.Queryable<Student>().Where(it => it.Id == 1).ToPageListAsync(1, 2);
2017-09-05 11:31:34 +08:00
list4.Wait();
2017-06-23 19:44:55 +08:00
}
private static void Simple()
{
//SqlSugarClient
var db = GetInstance();
var student1 = db.Queryable<Student>().InSingle(1);
//get SimpleClient
var sdb = db.SimpleClient;
var student2 = sdb.GetById<Student>(1);
sdb.DeleteById<Student>(1);
sdb.Insert(new Student() { Name = "xx" });
sdb.Update<Student>(it => new Student { Name = "newvalue" }, it => it.Id == 1);//only update name where id=1
2017-09-16 21:27:31 +08:00
sdb.Update(new Student() { Name = "newavalue", Id = 1 });//update all where id=1
2017-06-23 19:44:55 +08:00
//SimpleClient Get SqlSugarClient
2017-09-16 21:27:31 +08:00
var student3 = sdb.FullClient.Queryable<Student>().InSingle(1);
2017-06-23 19:44:55 +08:00
2017-05-27 01:00:41 +08:00
}
2017-05-27 02:01:33 +08:00
private static void StoredProcedure()
2017-05-27 01:00:41 +08:00
{
var db = GetInstance();
2017-05-27 01:05:22 +08:00
//1. no result
2017-05-28 11:10:11 +08:00
db.Ado.UseStoredProcedure(() =>
2017-05-27 02:01:33 +08:00
{
string spName = "sp_help";
var getSpReslut = db.Ado.SqlQueryDynamic(spName, new { objname = "student" });
});
//2. has result
2017-06-13 01:29:01 +08:00
var result = db.Ado.UseStoredProcedure<dynamic>(() =>
{
string spName = "sp_help";
return db.Ado.SqlQueryDynamic(spName, new { objname = "student" });
});
2017-05-28 11:10:11 +08:00
//2. has output
object outPutValue;
var outputResult = db.Ado.UseStoredProcedure<dynamic>(() =>
{
string spName = "sp_school";
var p1 = new SugarParameter("@p1", "1");
2017-06-13 01:29:01 +08:00
var p2 = new SugarParameter("@p2", null, true);//isOutput=true
var dbResult = db.Ado.SqlQueryDynamic(spName, new SugarParameter[] { p1, p2 });
2017-05-28 11:10:11 +08:00
outPutValue = p2.Value;
return dbResult;
});
2017-08-31 19:22:39 +08:00
//3
2017-09-16 21:27:31 +08:00
var dt = db.Ado.UseStoredProcedure().GetDataTable("sp_school", new { p1 = 1, p2 = 2 });
2017-08-31 19:22:39 +08:00
var p11 = new SugarParameter("@p1", "1");
var p22 = new SugarParameter("@p2", null, true);//isOutput=true
//4
2017-09-16 21:27:31 +08:00
var dt2 = db.Ado.UseStoredProcedure().SqlQuery<School>("sp_school", p11, p22);
2017-05-27 02:01:33 +08:00
}
private static void Tran()
{
var db = GetInstance();
2017-09-16 21:27:31 +08:00
var x = db.Insertable(new Student() { CreateTime = DateTime.Now, Name = "tran" }).ExecuteCommand();
2017-05-27 02:01:33 +08:00
//1. no result
2017-05-28 11:10:11 +08:00
var result = db.Ado.UseTran(() =>
2017-05-27 02:01:33 +08:00
{
2017-09-16 21:27:31 +08:00
var beginCount = db.Queryable<Student>().ToList();
2017-05-27 02:01:33 +08:00
db.Ado.ExecuteCommand("delete student");
var endCount = db.Queryable<Student>().Count();
throw new Exception("error haha");
});
2017-05-27 01:22:26 +08:00
var count = db.Queryable<Student>().Count();
2017-05-27 01:00:41 +08:00
2017-05-27 01:05:22 +08:00
//2 has result
2017-05-28 11:10:11 +08:00
var result2 = db.Ado.UseTran<List<Student>>(() =>
2017-05-27 01:00:41 +08:00
{
return db.Queryable<Student>().ToList();
});
2017-05-27 01:05:22 +08:00
//3 use try
try
{
db.Ado.BeginTran();
db.Ado.CommitTran();
}
catch (Exception)
{
db.Ado.RollbackTran();
throw;
}
2017-05-22 00:30:39 +08:00
}
private static void Group()
{
var db = GetInstance();
var list = db.Queryable<Student>()
.GroupBy(it => it.Name)
2017-05-31 15:42:21 +08:00
.GroupBy(it => it.Id).Having(it => SqlFunc.AggregateAvg(it.Id) > 0)
.Select(it => new { idAvg = SqlFunc.AggregateAvg(it.Id), name = it.Name }).ToList();
2017-05-22 00:35:07 +08:00
2017-06-13 01:29:01 +08:00
var list2 = db.Queryable<Student>()
.GroupBy(it => new { it.Id, it.Name }).Having(it => SqlFunc.AggregateAvg(it.Id) > 0)
.Select(it => new { idAvg = SqlFunc.AggregateAvg(it.Id), name = it.Name }).ToList();
2017-07-14 01:42:25 +08:00
//SQL:
//SELECT AVG([Id]) AS[idAvg], [Name] AS[name] FROM[Student] GROUP BY[Name],[Id] HAVING(AVG([Id]) > 0 )
2017-06-13 01:29:01 +08:00
2017-06-13 02:08:41 +08:00
// group id,name take first
var list3 = db.Queryable<Student>()
.PartitionBy(it => new { it.Id, it.Name }).Take(1).ToList();
2017-09-12 14:02:12 +08:00
var list31 = db.Queryable<Student>()
.PartitionBy(it => new { it.Id, it.Name }).Take(1).Count();
2017-06-13 02:08:41 +08:00
2017-07-14 01:42:25 +08:00
int count = 0;
2017-06-13 02:08:41 +08:00
2017-07-16 02:38:23 +08:00
var list4 = db.Queryable<Student, School>((st, sc) => st.SchoolId == sc.Id)
2017-09-16 21:27:31 +08:00
.PartitionBy(st => new { st.Name }).Take(2).OrderBy(st => st.Id, OrderByType.Desc).Select(st => st).ToPageList(1, 1000, ref count);
2017-05-27 01:00:41 +08:00
2017-05-31 15:42:21 +08:00
//SqlFunc.AggregateSum(object thisValue)
//SqlFunc.AggregateAvg<TResult>(TResult thisValue)
//SqlFunc.AggregateMin(object thisValue)
//SqlFunc.AggregateMax(object thisValue)
//SqlFunc.AggregateCount(object thisValue)
2017-05-22 00:12:23 +08:00
}
private static void Ado()
{
var db = GetInstance();
2017-06-13 16:23:08 +08:00
db.Ado.BeginTran();
2017-05-27 01:00:41 +08:00
var t1 = db.Ado.SqlQuery<string>("select 'a'");
2017-05-22 00:12:23 +08:00
var t2 = db.Ado.GetInt("select 1");
var t3 = db.Ado.GetDataTable("select 1 as id");
2017-06-13 16:23:08 +08:00
db.Ado.CommitTran();
2017-09-07 19:29:51 +08:00
var t11 = db.Ado.SqlQuery<Student>("select * from student");
2017-05-22 02:15:41 +08:00
//more
//db.Ado.GetXXX...
2017-05-21 22:33:21 +08:00
}
public static void Easy()
{
var db = GetInstance();
var getAll = db.Queryable<Student>().ToList();
2017-06-13 01:44:22 +08:00
var getAllOrder = db.Queryable<Student>().OrderBy(it => it.Id).OrderBy(it => it.Name, OrderByType.Desc).ToList();
2017-06-12 18:19:18 +08:00
var getId = db.Queryable<Student>().Select(it => it.Id).ToList();
2017-06-13 01:29:01 +08:00
var getNew = db.Queryable<Student>().Where(it => it.Id == 1).Select(it => new { id = SqlFunc.IIF(it.Id == 0, 1, it.Id), it.Name, it.SchoolId }).ToList();
2017-05-22 00:46:52 +08:00
var getAllNoLock = db.Queryable<Student>().With(SqlWith.NoLock).ToList();
2017-05-21 22:33:21 +08:00
var getByPrimaryKey = db.Queryable<Student>().InSingle(2);
2017-09-16 21:27:31 +08:00
var getSingleOrDefault = db.Queryable<Student>().Where(it => it.Id == 1).Single();
2017-06-11 09:43:38 +08:00
var getFirstOrDefault = db.Queryable<Student>().First();
2017-05-21 22:33:21 +08:00
var getByWhere = db.Queryable<Student>().Where(it => it.Id == 1 || it.Name == "a").ToList();
2017-05-31 15:42:21 +08:00
var getByFuns = db.Queryable<Student>().Where(it => SqlFunc.IsNullOrEmpty(it.Name)).ToList();
2017-07-20 08:18:16 +08:00
var sum = db.Queryable<Student>().Select(it => it.SchoolId).ToList();
2017-09-16 21:27:31 +08:00
var sum2 = db.Queryable<Student, School>((st, sc) => st.SchoolId == sc.Id).Sum((st, sc) => sc.Id);
2017-05-27 01:00:41 +08:00
var isAny = db.Queryable<Student>().Where(it => it.Id == -1).Any();
2017-05-23 18:03:18 +08:00
var isAny2 = db.Queryable<Student>().Any(it => it.Id == -1);
2017-09-16 21:27:31 +08:00
var count = db.Queryable<Student>().Count(it => it.Id > 0);
2017-09-07 17:44:22 +08:00
var date = db.Queryable<Student>().Where(it => it.CreateTime.Value.Date == DateTime.Now.Date).ToList();
2017-05-25 12:39:51 +08:00
var getListByRename = db.Queryable<School>().AS("Student").ToList();
2017-06-13 01:29:01 +08:00
var in1 = db.Queryable<Student>().In(it => it.Id, new int[] { 1, 2, 3 }).ToList();
2017-05-31 01:29:25 +08:00
var in2 = db.Queryable<Student>().In(new int[] { 1, 2, 3 }).ToList();
int[] array = new int[] { 1, 2 };
2017-06-13 01:29:01 +08:00
var in3 = db.Queryable<Student>().Where(it => SqlFunc.ContainsArray(array, it.Id)).ToList();
2017-05-26 02:25:26 +08:00
var group = db.Queryable<Student>().GroupBy(it => it.Id)
2017-05-31 15:42:21 +08:00
.Having(it => SqlFunc.AggregateCount(it.Id) > 10)
.Select(it => new { id = SqlFunc.AggregateCount(it.Id) }).ToList();
2017-05-30 02:07:58 +08:00
2017-05-31 15:42:21 +08:00
var between = db.Queryable<Student>().Where(it => SqlFunc.Between(it.Id, 1, 20)).ToList();
2017-05-30 02:07:58 +08:00
2017-05-31 15:42:21 +08:00
var getTodayList = db.Queryable<Student>().Where(it => SqlFunc.DateIsSame(it.CreateTime, DateTime.Now)).ToList();
2017-07-28 13:23:05 +08:00
var joinSql = db.Queryable("student", "s").OrderBy("id").Select("id,name").ToPageList(1, 2);
2017-08-13 01:19:15 +08:00
2017-09-16 21:27:31 +08:00
var getDay1List = db.Queryable<Student>().Where(it => it.CreateTime.Value.Hour == 1).ToList();
var getDateAdd = db.Queryable<Student>().Where(it => it.CreateTime.Value.AddDays(1) == DateTime.Now).ToList();
var getDateIsSame = db.Queryable<Student>().Where(it => SqlFunc.DateIsSame(DateTime.Now, DateTime.Now, DateType.Hour)).ToList();
2017-08-17 23:27:08 +08:00
var getSqlList = db.Queryable<Student>().AS("(select * from student) t").ToList();
2017-08-26 08:57:18 +08:00
var getUnionAllList = db.UnionAll(db.Queryable<Student>().Where(it => it.Id == 1), db.Queryable<Student>().Where(it => it.Id == 2)).ToList();
var getUnionAllList2 = db.UnionAll(db.Queryable<Student>(), db.Queryable<Student>()).ToList();
2017-09-16 21:27:31 +08:00
var test1 = db.Queryable<Student, School>((st, sc) => st.SchoolId == sc.Id).Select((st, sc) => SqlFunc.ToInt64(sc.Id)).ToList();
2017-05-21 22:33:21 +08:00
}
public static void Page()
{
2017-05-21 22:38:37 +08:00
var db = GetInstance();
var pageIndex = 1;
var pageSize = 2;
var totalCount = 0;
2017-05-23 08:01:06 +08:00
//page
2017-06-13 01:29:01 +08:00
var page = db.Queryable<Student>().OrderBy(it => it.Id).ToPageList(pageIndex, pageSize, ref totalCount);
2017-05-21 22:33:21 +08:00
2017-05-23 08:01:06 +08:00
//page join
2017-05-21 22:38:37 +08:00
var pageJoin = db.Queryable<Student, School>((st, sc) => new object[] {
JoinType.Left,st.SchoolId==sc.Id
}).ToPageList(pageIndex, pageSize, ref totalCount);
2017-05-21 22:40:10 +08:00
//top 5
var top5 = db.Queryable<Student>().Take(5).ToList();
//skip5
var skip5 = db.Queryable<Student>().Skip(5).ToList();
2017-05-21 22:33:21 +08:00
}
public static void Where()
{
var db = GetInstance();
//join
var list = db.Queryable<Student, School>((st, sc) => new object[] {
JoinType.Left,st.SchoolId==sc.Id
})
2017-05-27 01:00:41 +08:00
.Where((st, sc) => sc.Id == 1)
.Where((st, sc) => st.Id == 1)
2017-05-26 01:23:54 +08:00
.Where((st, sc) => st.Id == 1 && sc.Id == 2).ToList();
2017-05-21 22:33:21 +08:00
//SELECT [st].[Id],[st].[SchoolId],[st].[Name],[st].[CreateTime] FROM [Student] st
//Left JOIN School sc ON ( [st].[SchoolId] = [sc].[Id] )
//WHERE ( [sc].[Id] = @Id0 ) AND ( [st].[Id] = @Id1 ) AND (( [st].[Id] = @Id2 ) AND ( [sc].[Id] = @Id3 ))
2017-05-21 22:49:18 +08:00
//Where If
string name = null;
string name2 = "sunkaixuan";
var list2 = db.Queryable<Student>()
.WhereIF(!string.IsNullOrEmpty(name), it => it.Name == name)
.WhereIF(!string.IsNullOrEmpty(name2), it => it.Name == name2).ToList();
2017-06-28 12:37:47 +08:00
//join
var list3 = db.Queryable<Student, School>((st, sc) => new object[] {
JoinType.Left,st.SchoolId==sc.Id
})
2017-06-30 09:40:49 +08:00
.WhereIF(false, (st, sc) => sc.Id == 1)
.WhereIF(false, (st, sc) => st.Id == 1).ToList();
2017-08-05 11:20:46 +08:00
var list4 = db.Queryable<Student, School>((st, sc) => new object[] {
JoinType.Left,st.SchoolId==sc.Id
})
2017-09-16 21:27:31 +08:00
.Select((st, sc) => new { id = st.Id, school = sc }).ToList();
2017-08-05 11:20:46 +08:00
2017-09-11 12:38:58 +08:00
var list5 = db.Queryable<Student, School>((st, sc) => new object[] {
JoinType.Left,st.SchoolId==sc.Id
}).AS<Student>("STUDENT").AS<School>("SCHOOL")
.Select((st, sc) => new { id = st.Id, school = sc }).ToList();
var list6 = db.Queryable<Student, School>((st, sc) => new object[] {
JoinType.Left,st.SchoolId==sc.Id
}).With(SqlWith.NoLock).AS<Student>("STUDENT").AS<School>("SCHOOL")
.Select((st, sc) => new { id = st.Id, school = sc }).ToList();
2017-05-21 22:33:21 +08:00
}
public static void Join()
{
2017-05-21 22:43:58 +08:00
var db = GetInstance();
2017-05-22 00:56:31 +08:00
//join 2
2017-05-21 22:43:58 +08:00
var list = db.Queryable<Student, School>((st, sc) => new object[] {
JoinType.Left,st.SchoolId==sc.Id
2017-05-26 02:25:26 +08:00
})
2017-05-27 01:00:41 +08:00
.Where(st => st.Name == "jack").ToList();
2017-05-21 22:33:21 +08:00
2017-05-22 00:56:31 +08:00
//join 3
2017-05-27 01:00:41 +08:00
var list2 = db.Queryable<Student, School, Student>((st, sc, st2) => new object[] {
2017-05-22 00:56:31 +08:00
JoinType.Left,st.SchoolId==sc.Id,
JoinType.Left,st.SchoolId==st2.Id
2017-05-26 02:25:26 +08:00
})
2017-09-08 14:02:00 +08:00
.Where((st, sc, st2) => st2.Id == 1 || sc.Id == 1 || st.Id == 1).With(SqlWith.NoLock).ToList();
2017-05-22 00:56:31 +08:00
2017-05-23 07:28:40 +08:00
//join return List<ViewModelStudent>
2017-05-22 00:56:31 +08:00
var list3 = db.Queryable<Student, School>((st, sc) => new object[] {
2017-05-21 22:43:58 +08:00
JoinType.Left,st.SchoolId==sc.Id
2017-05-27 01:00:41 +08:00
}).Select((st, sc) => new ViewModelStudent { Name = st.Name, SchoolId = sc.Id }).ToList();
2017-05-23 07:28:40 +08:00
//join Order By (order by st.id desc,sc.id desc)
var list4 = db.Queryable<Student, School>((st, sc) => new object[] {
JoinType.Left,st.SchoolId==sc.Id
})
2017-05-27 01:00:41 +08:00
.OrderBy(st => st.Id, OrderByType.Desc)
.OrderBy((st, sc) => sc.Id, OrderByType.Desc)
2017-05-26 01:23:54 +08:00
.Select((st, sc) => new ViewModelStudent { Name = st.Name, SchoolId = sc.Id }).ToList();
2017-06-16 02:21:29 +08:00
//join 2
var list4_1 = db.Queryable<Student, School>((st, sc) => new object[] {
JoinType.Left,st.SchoolId==sc.Id&& st.Name == "jack"
}).ToList();
2017-06-16 02:21:29 +08:00
//The simple use of Join 2 table
2017-09-16 21:27:31 +08:00
var list5 = db.Queryable<Student, School>((st, sc) => st.SchoolId == sc.Id).Select((st, sc) => new { st.Name, st.Id, schoolName = sc.Name }).ToList();
2017-06-16 02:21:29 +08:00
//join 3 table
2017-09-16 21:27:31 +08:00
var list6 = db.Queryable<Student, School, School>((st, sc, sc2) => st.SchoolId == sc.Id && sc.Id == sc2.Id)
.Select((st, sc, sc2) => new { st.Name, st.Id, schoolName = sc.Name, schoolName2 = sc2.Name }).ToList();
2017-06-16 02:21:29 +08:00
//join 3 table page
2017-09-16 21:27:31 +08:00
var list7 = db.Queryable<Student, School, School>((st, sc, sc2) => st.SchoolId == sc.Id && sc.Id == sc2.Id)
.Select((st, sc, sc2) => new { st.Name, st.Id, schoolName = sc.Name, schoolName2 = sc2.Name }).ToPageList(1, 2);
2017-06-18 06:49:51 +08:00
//join 3 table page
var list8 = db.Queryable<Student, School, School>((st, sc, sc2) => st.SchoolId == sc.Id && sc.Id == sc2.Id)
2017-09-16 21:27:31 +08:00
.OrderBy(st => st.Id)
2017-06-18 06:49:51 +08:00
.Select((st, sc, sc2) => new { st.Name, st.Id, schoolName = sc.Name, schoolName2 = sc2.Name }).ToPageList(1, 2);
2017-08-25 15:15:13 +08:00
//In
var list9 = db.Queryable<Student>("it")
.OrderBy(it => it.Id)
2017-09-16 21:27:31 +08:00
.In(it => it.Id, db.Queryable<School>().Where("it.id=schoolId").Select(it => it.Id))
2017-08-25 15:15:13 +08:00
.ToList();
2017-08-25 15:22:09 +08:00
//SELECT [ID],[SchoolId],[Name],[CreateTime] FROM [STudent] it WHERE [ID]
//IN (SELECT [Id] FROM [School] WHERE it.id=schoolId ) ORDER BY [ID] ASC
2017-09-16 21:27:31 +08:00
var list10 = db.Queryable<Student, School>((st, sc) => st.SchoolId == sc.Id)
2017-08-25 15:22:09 +08:00
.In(st => st.Name, db.Queryable<School>("sc2").Where("id=st.schoolid").Select(it => it.Name))
.OrderBy(st => st.Id)
2017-09-16 21:27:31 +08:00
.Select(st => st)
2017-08-25 15:22:09 +08:00
.ToList();
//SELECT st.* FROM [STudent] st ,[School] sc WHERE ( [st].[SchoolId] = [sc].[Id] ) AND [st].[Name]
//IN (SELECT [Name] FROM [School] sc2 WHERE id=st.schoolid ) ORDER BY [st].[ID] ASC
2017-08-26 08:27:47 +08:00
var list11 = db.Queryable<Student, School>((st, sc) => st.SchoolId == sc.Id)
2017-09-16 21:27:31 +08:00
.In(st => st.Name, db.Queryable<School>("sc2").Where(it => it.Id == 1).Where("id=st.schoolid").Select(it => it.Name))
2017-08-26 08:27:47 +08:00
.OrderBy(st => st.Id)
.Select(st => st)
.ToList();
2017-05-21 22:33:21 +08:00
}
public static void Funs()
{
2017-05-22 00:30:39 +08:00
var db = GetInstance();
2017-05-31 15:42:21 +08:00
var t1 = db.Queryable<Student>().Where(it => SqlFunc.ToLower(it.Name) == SqlFunc.ToLower("JACK")).ToList();
2017-05-22 00:30:39 +08:00
//SELECT [Id],[SchoolId],[Name],[CreateTime] FROM [Student] WHERE ((LOWER([Name])) = (LOWER(@MethodConst0)) )
2017-05-21 22:33:21 +08:00
2017-05-22 00:30:39 +08:00
/***More Functions***/
2017-05-31 15:42:21 +08:00
//SqlFunc.IsNullOrEmpty(object thisValue)
//SqlFunc.ToLower(object thisValue)
//SqlFunc.string ToUpper(object thisValue)
//SqlFunc.string Trim(object thisValue)
//SqlFunc.bool Contains(string thisValue, string parameterValue)
//SqlFunc.ContainsArray(object[] thisValue, string parameterValue)
//SqlFunc.StartsWith(object thisValue, string parameterValue)
//SqlFunc.EndsWith(object thisValue, string parameterValue)
//SqlFunc.Equals(object thisValue, object parameterValue)
//SqlFunc.DateIsSame(DateTime date1, DateTime date2)
//SqlFunc.DateIsSame(DateTime date1, DateTime date2, DateType dataType)
//SqlFunc.DateAdd(DateTime date, int addValue, DateType millisecond)
//SqlFunc.DateAdd(DateTime date, int addValue)
//SqlFunc.DateValue(DateTime date, DateType dataType)
//SqlFunc.Between(object value, object start, object end)
//SqlFunc.ToInt32(object value)
//SqlFunc.ToInt64(object value)
//SqlFunc.ToDate(object value)
//SqlFunc.ToString(object value)
//SqlFunc.ToDecimal(object value)
//SqlFunc.ToGuid(object value)
//SqlFunc.ToDouble(object value)
//SqlFunc.ToBool(object value)
//SqlFunc.Substring(object value, int index, int length)
//SqlFunc.Replace(object value, string oldChar, string newChar)
//SqlFunc.Length(object value) { throw new NotImplementedException(); }
//SqlFunc.AggregateSum(object thisValue)
//SqlFunc.AggregateAvg<TResult>(TResult thisValue)
//SqlFunc.AggregateMin(object thisValue)
//SqlFunc.AggregateMax(object thisValue)
//SqlFunc.AggregateCount(object thisValue)
2017-05-27 01:00:41 +08:00
}
2017-05-21 22:33:21 +08:00
public static void Select()
{
2017-05-22 00:30:39 +08:00
var db = GetInstance();
2017-05-22 00:35:07 +08:00
db.IgnoreColumns.Add("TestId", "Student");
2017-09-16 21:27:31 +08:00
var s1 = db.Queryable<Student>().Where(it => it.Id == 136915).Single();
2017-05-22 00:30:39 +08:00
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-05-26 01:23:54 +08:00
var s6 = db.Queryable<Student, School>((st, sc) => new object[] {
JoinType.Left,st.SchoolId==sc.Id
})
.OrderBy(st => st.Id, OrderByType.Desc)
.OrderBy((st, sc) => sc.Id, OrderByType.Desc)
2017-05-27 01:00:41 +08:00
.Select((st, sc) => new { Name = st.Name, SchoolId = sc.Id }).ToList();
var s7 = db.Queryable<Student, School>((st, sc) => new object[] {
JoinType.Left,st.SchoolId==sc.Id
}).Select((st, sc) => sc).ToList();
2017-07-08 01:22:14 +08:00
var s8 = db.Queryable<Student, School>((st, sc) => new object[] {
JoinType.Left,st.SchoolId==sc.Id
})
.OrderBy((st, sc) => st.SchoolId)
.Select((st, sc) => sc)
.Take(1).ToList();
2017-05-21 22:33:21 +08:00
}
2017-05-22 02:21:43 +08:00
private static void Sqlable()
{
var db = GetInstance();
var join3 = db.Queryable("Student", "st")
.AddJoinInfo("School", "sh", "sh.id=st.schoolid")
.Where("st.id>@id")
.AddParameters(new { id = 1 })
.Select("st.*").ToList();
2017-05-27 01:00:41 +08:00
//SELECT st.* FROM [Student] st Left JOIN School sh ON sh.id=st.schoolid WHERE st.id>@id
2017-05-22 02:21:43 +08:00
}
2017-06-04 19:22:05 +08:00
private static void Enum()
{
var db = GetInstance();
2017-06-13 01:29:01 +08:00
var list = db.Queryable<StudentEnum>().AS("Student").Where(it => it.SchoolId == SchoolEnum.HarvardUniversity).ToList();
2017-06-04 19:22:05 +08:00
}
2017-05-21 22:33:21 +08:00
}
}