首页 > 业界动态 > > 正文

环球观察:自研ORM 完美支持 Exists查询 非常灵活

时间:2023-06-07 20:03:34 来源:博客园
示例代码

Case 1 Code

var data = db.Query()                    .Where(w => db.Query().WhereIF(!string.IsNullOrWhiteSpace("测试"), a => a.ProductId == 1).Select(s => 1).Any())                    .Select(s => new                    {                        s.ProductId,                        s.ProductCode                    }).ToList();

Case 1 Sql


(资料图片)

SELECT `p1`.`ProductId` AS `ProductId`,`p1`.`ProductCode` AS `ProductCode` FROM `Product` `p1`WHERE  EXISTS ( SELECT 1 FROM `Product` `p2`WHERE ( `p2`.`ProductId` = 1 ) )

Case 2 Code (如需主表作为条件 需使用Case1 写法)

var existsQuery = db.Query().WhereIF(!string.IsNullOrWhiteSpace("测试"), a => a.ProductId == 1).Select(s => 1);                var data = db.Query()                    .Where(w => existsQuery.Any())                    .Select(s => new                    {                        s.ProductId,                        s.ProductCode                    }).ToList();

Case 2 Sql

SELECT `p1`.`ProductId` AS `ProductId`,`p1`.`ProductCode` AS `ProductCode` FROM `Product` `p1`WHERE  EXISTS ( SELECT 1 FROM `Product` `p2`WHERE ( `p2`.`ProductId` = 1 ) )

Case 3 Code(真实项目写法的伪代码,可自由搭配,基本上可以媲美手写sql)

var queryBuilder = db.Query()                    .Where(a => SqlFunc.Operation(a.CreateTime.ToString("yyyy-MM-dd"), ">=", DateTime.Now.ToString("yyyy-MM-dd")))                    .Where(a => db.Query().Where(b => a.ProductName.Contains("主表") || b.Custom1.Contains("子表")).WhereIF(!string.IsNullOrWhiteSpace("测试"), a => a.ProductId == 1).Select(s => 1).Any())                    .Select(s => new                    {                        s.ProductId,                        s.ProductCode                    }).QueryBuilder;

Case 3 Print Result

SELECT `p1`.`ProductId` AS `ProductId`,`p1`.`ProductCode` AS `ProductCode` FROM `Product` `p1`WHERE DATE_FORMAT( `p1`.`CreateTime`,"%Y-%m-%d" ) >= DATE_FORMAT( @Now_1,"%Y-%m-%d" ) AND  EXISTS ( SELECT 1 FROM `Product` `p2`WHERE ( `p1`.`ProductName` LIKE CONCAT( "%","主表","%" ) OR `p2`.`Custom1` LIKE CONCAT( "%","子表","%" ) ) AND ( `p2`.`ProductId` = 1 ) )参数名称:Now_1 参数值:2023-06-07 18:35:14

3.亮点功能

1.别名自动编排和联表查询一样

2.支持Query 所有非返回结果集方法,结尾需调用Any方法以及重载方法,非常灵活 !!!

开源项目地址:https://github.com/China-Mr-zhong/Fast-Framework (唯一)

其它查询示例

Select查询 (Case When)

var data = db.Query().Select(s => new                {                    CaseTest1 = SqlFunc.Case(s.Custom1).When("1").Then("xx1").When("2").Then("xx2").Else("xx3").End(),                    CaseTest2 = SqlFunc.CaseWhen(s.Custom1 == "1").Then("xx1").When(s.Custom1 == "2").Then("xx2").Else("xx3").End()                }).ToList();

分组查询

var data = db.Query().GroupBy(s => new            {                s.ProductId,                s.ProductName            }).ToList();

分组聚合查询

var sql = db.Query().InnerJoin((a, b) => a.OrderId == b.OrderId).GroupBy((a, b) => new            {                a.OrderCode            }).Select((a, b) => new            {                a.OrderCode,                Sum_Qty = SqlFunc.Sum(b.Qty)//支持嵌套            }).ToList();

排序查询

var data = db.Query().OrderBy(s => new            {                s.CreateTime            }).ToList();            //这是多个字段排序使用方法 还有其它重载方法

Having查询

var data = db.Query().GroupBy(s => new            {                s.ProductId,                s.ProductName            }).Having(s => SqlFunc.Count(s.ProductId) > 1).ToList();            //必须先使用GroupBy方法 懂得都懂
关键词:
x 广告
知识领域 诺基亚强制开机怎么按

1、首先将手机正常关机;2、同时按住拨号键、星号键、数字三号键;3、再按住挂机键打开电源直到英文诺基亚字样出现,此过程不能松开任何一个

共同抗疫!郑州71岁党员志愿者每天爬6栋楼,提醒800多户居民做核酸

1月4日,郑州市新冠肺炎疫情防控指挥部办公室发布通告对部分区域实施管控措施。这是近半年来,新冠疫情第3次造访郑州。截止至1月10日24时,

安阳疫情最新消息|1月11日8时至12日8时安阳市新增本土确诊病例39例,累计123例

安阳疫情最新消息2022年1月11日8时至12日8时安阳市新型冠状病毒肺炎疫情最新情况1月11日8时至12日8时,全市新增本土确诊病例39例(汤阴县38

迅速高效!“河南抗疫互助通道”网上网下联动 获群众点赞

核酸检测24小时了还没查到结果,怎么办?现在高速下站口的管控政策到底是什么样子的?从洛阳老城区自驾走高速回郑州,收费站还劝返吗?苏八

信阳市疫情防控工作视频调度会召开 陈志伟出席会议

1月11日,市疫情防控工作视频调度会召开。代市长陈志伟出席会议并讲话。听取有关疫情防控重点工作和各县区(管理区、开发区)疫情防控工作

全国最新疫情消息:11日新增本土确诊病例166例 天津市今日启动第二轮全员核酸检测

11日0—24时,31个省(自治区、直辖市)和新疆生产建设兵团报告新增新冠肺炎本土确诊病例166例(河南118例,其中安阳市65例、许昌市41例、

x 广告

Copyright ©  2015-2022 亚洲评测网版权所有  备案号:京ICP备2021034106号-51   联系邮箱:5 516 538 @qq.com