1、导航查询特点

作用:主要处理主对象里面有子对象这种层级关系查询

1.1 无外键开箱就用

其它ORM导航查询 需要 各种配置或者外键,而SqlSugar则开箱就用,无外键,只需配置特性和主键就能使用

1.2 高性能优

查询 性能非常强悍

支持大数据分页导航查询

3.3 语法超级爽

注意:多级查询时VS有时候没提示直接写就行了

 var list=db.Queryable<Test>()
.Includes(x => x.Provinces,x=>x.Citys ,x=>x.Street)//多级查询 有时候VS没提示手写
.Includes(x => x.ClassInfo)// 一级查询
.ToList(); var list=db.Queryable<Test>()
//多级查询 加排序过滤
.Includes(x =>x.Provinces.Where(z=>z.Id>0).OrderBy(z=>z.Id).ToList(),x=>x.Citys,x=>x.Street)
// 一级查询
.Includes(x =>x.ClassInfo)
.ToList();

  

2、新导航查询

适合有主键的常规操作, 请升级到5.0.6.8

2.1 一对一

//实体
public class StudentA
{
[SugarColumn(IsPrimaryKey = true)]
public int StudentId { get; set; }
public string Name { get; set; }
public int SchoolId { get; set; }
[Navigat(NavigatType.OneToOne, nameof(SchoolId))]//一对一
public SchoolA SchoolA { get; set; } }
public class SchoolA
{
[SugarColumn(IsPrimaryKey = true)]
public int SchoolId { get; set; }
public string SchoolName { get; set; }
}
//代码
var list2 = db.Queryable<StudentA>()
.Includes(x => x.SchoolA)
.Where(x => x.SchoolA.SchoolName == "北大")//可以对一级导航进行过滤
.ToList();

2.2 一对多

    public class StudentA
{
[SugarColumn(IsPrimaryKey = true)]
public int StudentId { get; set; }
public string Name { get; set; }
public int SchoolId { get; set; }
[Navigat(NavigatType.OneToMany, nameof(BookA.studenId))]
public List<BookA> Books { get; set; } }
public class BookA
{
[SugarColumn(IsPrimaryKey = true)]
public int BookId { get; set; }
public string Name { get; set; }
public int studenId { get; set; }
} //例1: 简单用法
var list = db.Queryable<StudentA>()
.Includes(x => x.Books)
.ToList(); //例2:支持Any和Count 对主表进行过滤
var list = db.Queryable<StudentA>()
.Includes(x => x.Books)
.Where(x=>x.Books.Any(z=>z.BookId==1))
.ToList(); //例3:对子对象进行排序和过滤
var list = db.Queryable<StudentA>()
.Includes(x => x.Books.Where(y=>y.BookId >0).OrderBy(y=>y.BookId ).ToList())
.ToList();

  

2.3 多对多

   //多对多
public class ABMapping1
{
[SugarColumn(IsPrimaryKey = true )]
public int AId { get; set; }
[SugarColumn(IsPrimaryKey = true)]
public int BId { get; set; }
}
public class A1
{
[SugarColumn(IsPrimaryKey = true )]
public int Id { get; set; }
public string Name { get; set; }
[Navigat(typeof(ABMapping1),nameof(ABMapping1.AId),nameof(ABMapping1.BId))]
public List<B1> BList { get; set; }
}
public class B1
{
[SugarColumn(IsPrimaryKey = true )]
public int Id { get; set; }
public string Name { get; set; }
[Navigat(typeof(ABMapping1), nameof(ABMapping1.BId), nameof(ABMapping1.AId))]
public List<A1> AList { get; set; }
}
//例1:简单用法
var list3= db.Queryable<A1>().Includes(x => x.BList).ToList(); //例2:支持子对象排序和过滤
var list3= db.Queryable<A1>().Includes(x => x.BList.Where(z=>z.Id>0).ToList()).ToList(); //例3:支持主表过滤 Any和Count
var list3= db.Queryable<A1>().Includes(x => x.BList)
.Where(x=>x.BList .Any(z=>z.Id ==1)).ToList();

2.4 多级查询

配置好实体类,我们可以多级查询

 var list=db.Queryable<Test>()
.Includes(x => x.Provinces,x=>x.Citys ,x=>x.Street)//有时候没提示 直接写
.Includes(x => x.ClassInfo)// 一级查询
.ToList();

  

2.5 大数据分页导航

适合一次性查询1000条以上的导航

  var list = new List<Tree1>();

    db.Queryable<Tree1>()
.Includes(it => it.Child)
.ForEach(it => list.Add(it), 300); //每次查询300条 

更多用法:https://www.donet5.com/Home/Doc?typeId=2414

3、手动映射(高性能)

手动映射适合没有主键或者复杂的一些操作

3.1 手动实现二层

结构:  Student->SchoolA

var list = db.Queryable<StudentA>().ToList();
db.ThenMapper(list, stu =>
{
//如果加Where不能带有stu参数,stu参数写到 SetContext
stu.SchoolA=db.Queryable<SchoolA>().SetContext(scl=>scl.SchoolId,()=>stu.SchoolId,stu).FirstOrDefault();
});
// SetContext不会生成循环操作,高性能 和直接Where性能是不一样的

如果没有SetContext那么这个查询将会循环

3.2 实现无限层注意:

了解原理后我们用ThenMapper想映射哪层就映射哪层

var treeRoot=db.Queryable<Tree>().Where(it => it.Id == 1).ToList();
//第一层
db.ThenMapper(treeRoot, item =>
{
item.Child = db.Queryable<Tree>().SetContext(x => x.ParentId, () => item.Id, item).ToList();
});
//第二层
db.ThenMapper(treeRoot.SelectMany(it=>it.Child), it =>
{
it.Child = db.Queryable<Tree>().SetContext(x => x.ParentId, () => it.Id, it).ToList();
});
//第三层
db.ThenMapper(treeRoot.SelectMany(it => it.Child).SelectMany(it=>it.Child), it =>
{
it.Child = db.Queryable<Tree>().SetContext(x => x.ParentId, () => it.Id, it).ToList();
});
//这儿只是用树型结构来证明可以实现无限级别导航查询 ,实际开发中树型结构用ToTree实现
public class Tree
{
[SqlSugar.SugarColumn(IsPrimaryKey =true)]
public int Id { get; set; }
public string Name { get; set; }
public int ParentId { get; set; }
[SqlSugar.SugarColumn(IsIgnore = true)]
public Tree Parent { get; set; }
[SqlSugar.SugarColumn(IsIgnore = true)]
public List<Tree> Child { get; set; }
}
// SetContext不会生成循环操作,高性能 和直接Where性能是不一样的

4 、未来计划

Json to sql  正在开发中 ,未来将打造一套直接由前端操作数据库的API

 {
"Queryable":"order",
Select:[ [{SqlFunc_AggregateMin:["id"]},"id"], [{SqlFunc_GetDate:[]},"Date"] ]
}

将支持 权限过滤 ,验证,多表查询,层级导航查询 等  

GitHUB 源码:

https://github.com/donet5/SqlSugar

喜欢的可以点个星星、点个关注

  

最新文章

  1. web移动端开发技巧与注意事项汇总
  2. Ajax的使用
  3. 发布windows phone应用经历实谈
  4. mysql 如何修改字符串为 utf8
  5. vmware设置centos虚拟机nat联网(转)
  6. cocos2dx - v2.3.3编辑器骨骼动画
  7. 《JavaScript高级程序设计》笔记:函数表达式(七)
  8. [Swift]LeetCode455. 分发饼干 | Assign Cookies
  9. 1、react-native中expo的真机测试字体不加载的坑
  10. navicat连接不上Linux服务器上的MySQL
  11. .Net Core 在 Linux-Centos上的部署实战教程(二)
  12. 1244. Minimum Genetic Mutation
  13. 关于MySQL数据库——增删改查语句集锦
  14. 渲染函数render和函数式组件
  15. Go 标准库 —— sync.Mutex 互斥锁
  16. JNDI是什么?
  17. Petapoco 查询 语法
  18. Linux优化远程SSH连接
  19. [think\exception\ErrorException] glob() has been disabled for security reasons
  20. 升级Xcode10报错问题修复

热门文章

  1. Nginx 陷阱和常见错误
  2. ubuntu忘记密码,用root修改Ubuntu密码
  3. Ubuntu16.04安装、卸载宝塔软件
  4. SSM(Spring+SpringMVC+MyBatis)框架整合开发流程
  5. 一致性检验评价方法kappa
  6. 数据结构 - 单链表 C++ 实现
  7. 可以直接调用 Thread 类的 run ()方法么?
  8. Java 中的同步集合与并发集合有什么区别?
  9. spring JDBC API 中存在哪些类?
  10. spring-boot-learning-事务处理