LINQ to SQL集成到应用程序中需考虑的一些问题

简介:
1、LINQ to SQL集成到应用程序中需考虑的一个问题, 到底应该返回IQueryable<T>还是IQueryable? 或许这个列表还应该继续扩展为T, List<T>, 对于Business Layer来说, 到底应该选择哪一种?
2、需要一个分页功能; 到这一步的时候我又有几个选择, 利用LINQ to SQL可以执行自定义存储过程的功能, 完全自己写, LINQ to SQL本身已经有API提供了分页功能了,不过只有排序或包含标识列的查询中支持Skip方法, 我有什么理由放弃, 除非性能真的到了非常Critical的时候, 看看下面的分页API, 多么简单:
return q.Skip<Order>((currentPage - 1) * pageSize).Take< Order >(pageSize)
生成的T-SQL语句:
SELECT   [ t2 ] . [ OrderID ] [ t2 ] . [ OrderNumber ] [ t2 ] . [ OrderName ] [ t2 ] . [ DateSubmitted ] [ t2 ] . [ SubmittedBy ] , ( [ t2 ] . [ LastName ]   +   @p2 +   [ t2 ] . [ FirstName ]   AS   [ SubmittedUserName ]
FROM  (
SELECT   TOP  ( 10 [ t0 ] . [ OrderID ] [ t0 ] . [ OrderNumber ] [ t0 ] . [ OrderName ] [ t0 ] . [ SubmittedBy ] [ t0 ] . [ DateSubmitted ] [ t1 ] . [ FirstName ] [ t1 ] . [ LastName ]
FROM   [ dbo ] . [ Order ]   AS   [ t0 ]
INNER   JOIN   [ dbo ] . [ Users ]   AS   [ t1 ]   ON   [ t1 ] . [ UserID ]   =   [ t0 ] . [ SubmittedBy ]
WHERE  ( [ t0 ] . [ NextProcessedBy ]   =   @p0 AND  ( [ t0 ] . [ CurrentState ]   =   @p1 )
AS   [ t2 ]
– 
@p0 : Input  NVarChar  (Size  =   3 ; Prec  =   0 ; Scale  =   0 [ jlv ]
– 
@p1 : Input  NVarChar  (Size  =   3 ; Prec  =   0 ; Scale  =   0 [ New ]
– 
@p2 : Input  NVarChar  (Size  =   2 ; Prec  =   0 ; Scale  =   0 [ ]

DLINQ生成的SQL语句是利用TOP和嵌套子查询, 这种方法已经被证明是比较高效的做法(相比于临时表的做法), 所以完全有理由可以一试.到这里, List, IQueryable, IQueryable都没有任何问题.

3、需要一个动态排序功能, 这里List的局限性出来了, 传统的做法可能需要用一个dynamic参数来传递需要排序的列然后到SP当中来执行, 但我们已经不打算使用SP了, 也没有动态sql语句, 所有的东西都是强类型的, 然后有LINQ to SQL在运行时来帮我们转换为T-SQL语句。首先List的话, 我们不知道到底哪个字段要排序, 如果使用字符串作为参数的话, 例如放一个string sortBy作为方法的参数, 那么在方法体内就需要做if…else或者switch的判断, 而且还要考虑倒序还是正序的排序要求, 而且你还要hard code,很明显麻烦来了.然而如果使用IQueryable却可以很好的解决所有的这些问题.  但是IQueryable不能跨assembly, 一旦跨了assembly的话, 你无法使用var来引用匿名类里面的property, 绑定到control是没有问题的, 但是客户端的动态查询却成了问题, 因为你根本不知道匿名类是什么. 那么选择IQueryable<T>, 我们选择返回IQueryable<T>给客户端, 分页/排序都没有任何问题. 



本文来自云栖社区合作伙伴“doNET跨平台”,了解相关信息可以关注“opendotnet”微信公众号

目录
相关文章
|
6月前
|
SQL Java 流计算
Flink CDC在代码里面集成cdc的时候,是不是也要用上面这个胖包flink-sql-connector-mysql-cdc,不要去用瘦包flink-connector-mysql-cdc? com.ververica flink-sql-connector-mysql-cdc 2.4.0
Flink CDC在代码里面集成cdc的时候,是不是也要用上面这个胖包flink-sql-connector-mysql-cdc,不要去用瘦包flink-connector-mysql-cdc? com.ververica flink-sql-connector-mysql-cdc 2.4.0
95 1
|
4月前
|
SQL DataWorks 关系型数据库
DataWorks产品使用合集之数据集成时源头提供数据库自定义函数调用返回数据,数据源端是否可以写自定义SQL实现
DataWorks作为一站式的数据开发与治理平台,提供了从数据采集、清洗、开发、调度、服务化、质量监控到安全管理的全套解决方案,帮助企业构建高效、规范、安全的大数据处理体系。以下是对DataWorks产品使用合集的概述,涵盖数据处理的各个环节。
|
6月前
|
SQL Java 数据库连接
实时计算 Flink版产品使用合集之怎么将MyBatis-Plus集成到SQL语法中
实时计算Flink版作为一种强大的流处理和批处理统一的计算框架,广泛应用于各种需要实时数据处理和分析的场景。实时计算Flink版通常结合SQL接口、DataStreamAPI、以及与上下游数据源和存储系统的丰富连接器,提供了一套全面的解决方案,以应对各种实时计算需求。其低延迟、高吞吐、容错性强的特点,使其成为众多企业和组织实时数据处理首选的技术平台。以下是实时计算Flink版的一些典型使用合集。
|
6月前
|
监控 druid Java
Druid【SpringBoot集成】监控数据库报错 Failed to bind properties under ‘‘ to javax.sql.DataSource 解决(含配置源码)
Druid【SpringBoot集成】监控数据库报错 Failed to bind properties under ‘‘ to javax.sql.DataSource 解决(含配置源码)
536 0
|
6月前
|
Oracle Java 关系型数据库
Generator【SpringBoot集成】代码生成+knife4j接口文档(2种模板设置、逻辑删除、字段填充 含代码粘贴可用)保姆级教程(注意事项+建表SQL+代码生成类封装+测试类)
Generator【SpringBoot集成】代码生成+knife4j接口文档(2种模板设置、逻辑删除、字段填充 含代码粘贴可用)保姆级教程(注意事项+建表SQL+代码生成类封装+测试类)
113 0
|
SQL 消息中间件 存储
|
SQL 缓存 Java
Mybatis是如何操作动态sql的,又如何与spring集成(下)
Mybatis是如何操作动态sql的,又如何与spring集成
|
SQL XML 缓存
Mybatis是如何操作动态sql的,又如何与spring集成(上)
Mybatis是如何操作动态sql的,又如何与spring集成
|
SQL Java 数据库连接
springboot集成mybatis拦截器sql打印输出
springboot集成mybatis拦截器sql打印输出