• FreeSql学习笔记——11.LinqToSql


    前言

      Linq的强大大家有目共睹,可以以简便的方式对数据集进行复杂操作,LinqToSql经常使用在数据库的联表、分组等查询操作中;FreeSql对LinqToSql的支持通过扩展包FreeSql.Extensions.Linq;
     
     

    Init

    dotnet add package FreeSql.Extensions.Linq
     

    说明

    • 请尽量不要在 ISelect 模式下的使用 Linq 方法:GroupJoin、Select、SelectMany、Join、DefaultIfEmpty;
    • 如果一定要在 ISelect 中使用 .Select() 方法,请务必在 .ToList() 之前调用它;
    • IQueryable 的实现目前不支持 GroupBy,可以考虑使用 RestoreSelect 方法转回 ISelect 进行查询
     

    ISelect与Queryable的转换

    var query = _freeSql.Select<Student>().AsQueryable();
    query.RestoreToSelect();
     
     

    示例

    (from s in _freeSql.Select<Student>()
         select s).ToList();
    SELECT a.[Id], a.[Name], a.[Age], a.[Status], a.[AddTime], a.[Remark], a.[Version], a.[ClassId]
    FROM [Student] a
    
    
    (from s in _freeSql.Select<Student>()
     join c in _freeSql.Select<Class>() on s.ClassId equals c.Id into temp
     from sc in temp.DefaultIfEmpty()
     where s.Status == StatusEnum.Normal
     select new
     {
         SName = s.Name,
         CName = sc.Name
     })
    .Page(2, 10)
    .ToList();
    
    SELECT a.[Name] as1, sc.[Name] as2
    FROM [Student] a
    LEFT JOIN [Class] sc ON a.[ClassId] = sc.[Id]
    WHERE (a.[Status] = 1)
    ORDER BY a.[Id]
    OFFSET 10 ROW
    FETCH NEXT 10 ROW ONLY
     
    Linq查询,联表使用较好,分组查询还是得使用ISelect,运用ISelect、IQueryable转换可以实现复杂查询
  • 相关阅读:
    终端字符颜色、样式控制
    popen——php多进程利器
    游戏技能效果与buff设定
    Linux 记录服务器负载、内存、cpu状态的PHP脚本
    简单的,省份和城市选择,非ajax版
    一道js题目
    左右结构,右边上固定、下iframe,iframe自动改变大小
    mysql 忘记root密码
    socket 学习(转载)
    子页面关闭后,更新父页面
  • 原文地址:https://www.cnblogs.com/zousc/p/16350989.html
Copyright © 2020-2023  润新知