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
|
|
|
|
|
{
|
|
|
|
|
public class Query
|
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
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();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private static void Tran()
|
|
|
|
|
{
|
|
|
|
|
var db = GetInstance();
|
|
|
|
|
|
|
|
|
|
var result=db.UseTran(() =>
|
|
|
|
|
{
|
|
|
|
|
var count= db.Ado.ExecuteCommand("delete student");
|
|
|
|
|
throw new Exception("error haha");
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
var result2 = db.UseTran<List<Student>>(() =>
|
|
|
|
|
{
|
|
|
|
|
return db.Queryable<Student>().ToList();
|
|
|
|
|
});
|
2017-05-22 00:30:39 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private static void Group()
|
|
|
|
|
{
|
|
|
|
|
var db = GetInstance();
|
|
|
|
|
var list = db.Queryable<Student>()
|
|
|
|
|
.GroupBy(it => it.Name)
|
|
|
|
|
.GroupBy(it => it.Id).Having(it => NBORM.AggregateAvg(it.Id) > 0)
|
|
|
|
|
.Select(it => new { idAvg = NBORM.AggregateAvg(it.Id), name = it.Name }).ToList();
|
2017-05-22 00:35:07 +08:00
|
|
|
|
|
|
|
|
|
//SQL:
|
|
|
|
|
//SELECT AVG([Id]) AS[idAvg], [Name] AS[name] FROM[Student] GROUP BY[Name],[Id] HAVING(AVG([Id]) > 0 )
|
2017-05-27 01:00:41 +08:00
|
|
|
|
|
2017-05-22 00:30:39 +08:00
|
|
|
|
//NBORM.AggregateSum(object thisValue)
|
|
|
|
|
//NBORM.AggregateAvg<TResult>(TResult thisValue)
|
|
|
|
|
//NBORM.AggregateMin(object thisValue)
|
|
|
|
|
//NBORM.AggregateMax(object thisValue)
|
|
|
|
|
//NBORM.AggregateCount(object thisValue)
|
2017-05-22 00:12:23 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private static void Ado()
|
|
|
|
|
{
|
|
|
|
|
var db = GetInstance();
|
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-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-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);
|
|
|
|
|
var getByWhere = db.Queryable<Student>().Where(it => it.Id == 1 || it.Name == "a").ToList();
|
|
|
|
|
var getByFuns = db.Queryable<Student>().Where(it => NBORM.IsNullOrEmpty(it.Name)).ToList();
|
2017-05-27 01:00:41 +08:00
|
|
|
|
var sum = db.Queryable<Student>().Sum(it => it.Id);
|
|
|
|
|
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-05-25 12:39:51 +08:00
|
|
|
|
var getListByRename = db.Queryable<School>().AS("Student").ToList();
|
2017-05-26 02:25:26 +08:00
|
|
|
|
var group = db.Queryable<Student>().GroupBy(it => it.Id)
|
|
|
|
|
.Having(it => NBORM.AggregateCount(it.Id) > 10)
|
2017-05-27 01:00:41 +08:00
|
|
|
|
.Select(it => new { id = NBORM.AggregateCount(it.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-05-21 22:38:37 +08:00
|
|
|
|
var page = db.Queryable<Student>().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-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-05-27 01:00:41 +08:00
|
|
|
|
.Where((st, sc, st2) => st2.Id == 1 || sc.Id == 1 || st.Id == 1).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-05-21 22:33:21 +08:00
|
|
|
|
}
|
|
|
|
|
public static void Funs()
|
|
|
|
|
{
|
2017-05-22 00:30:39 +08:00
|
|
|
|
var db = GetInstance();
|
|
|
|
|
var t1 = db.Queryable<Student>().Where(it => NBORM.ToLower(it.Name) == NBORM.ToLower("JACK")).ToList();
|
|
|
|
|
//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***/
|
|
|
|
|
//NBORM.IsNullOrEmpty(object thisValue)
|
|
|
|
|
//NBORM.ToLower(object thisValue)
|
|
|
|
|
//NBORM.string ToUpper(object thisValue)
|
|
|
|
|
//NBORM.string Trim(object thisValue)
|
|
|
|
|
//NBORM.bool Contains(string thisValue, string parameterValue)
|
|
|
|
|
//NBORM.ContainsArray(object[] thisValue, string parameterValue)
|
|
|
|
|
//NBORM.StartsWith(object thisValue, string parameterValue)
|
|
|
|
|
//NBORM.EndsWith(object thisValue, string parameterValue)
|
|
|
|
|
//NBORM.Equals(object thisValue, object parameterValue)
|
|
|
|
|
//NBORM.DateIsSame(DateTime date1, DateTime date2)
|
|
|
|
|
//NBORM.DateIsSame(DateTime date1, DateTime date2, DateType dataType)
|
|
|
|
|
//NBORM.DateAdd(DateTime date, int addValue, DateType millisecond)
|
|
|
|
|
//NBORM.DateAdd(DateTime date, int addValue)
|
|
|
|
|
//NBORM.DateValue(DateTime date, DateType dataType)
|
|
|
|
|
//NBORM.Between(object value, object start, object end)
|
|
|
|
|
//NBORM.ToInt32(object value)
|
|
|
|
|
//NBORM.ToInt64(object value)
|
|
|
|
|
//NBORM.ToDate(object value)
|
|
|
|
|
//NBORM.ToString(object value)
|
|
|
|
|
//NBORM.ToDecimal(object value)
|
|
|
|
|
//NBORM.ToGuid(object value)
|
|
|
|
|
//NBORM.ToDouble(object value)
|
|
|
|
|
//NBORM.ToBool(object value)
|
|
|
|
|
//NBORM.Substring(object value, int index, int length)
|
|
|
|
|
//NBORM.Replace(object value, string oldChar, string newChar)
|
|
|
|
|
//NBORM.Length(object value) { throw new NotImplementedException(); }
|
|
|
|
|
//NBORM.AggregateSum(object thisValue)
|
|
|
|
|
//NBORM.AggregateAvg<TResult>(TResult thisValue)
|
|
|
|
|
//NBORM.AggregateMin(object thisValue)
|
|
|
|
|
//NBORM.AggregateMax(object thisValue)
|
|
|
|
|
//NBORM.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-05-22 00:30:39 +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-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();
|
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-05-21 22:33:21 +08:00
|
|
|
|
public static SqlSugarClient GetInstance()
|
|
|
|
|
{
|
2017-05-23 06:16:59 +08:00
|
|
|
|
SqlSugarClient db = new SqlSugarClient(new SystemTableConfig() { ConnectionString = Config.ConnectionString, DbType = DbType.SqlServer, IsAutoCloseConnection = true });
|
2017-05-21 22:33:21 +08:00
|
|
|
|
db.Ado.IsEnableLogEvent = true;
|
|
|
|
|
db.Ado.LogEventStarting = (sql, pars) =>
|
|
|
|
|
{
|
|
|
|
|
Console.WriteLine(sql + "\r\n" + db.RewritableMethods.SerializeObject(pars));
|
|
|
|
|
Console.WriteLine();
|
|
|
|
|
};
|
|
|
|
|
return db;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|