Linq to SQL Dynamic 动态查询

在开发中我们常需要使用动态的条件来组合查询,scotte博客里提到了MS提供的一个动态查询类库Basic Dynamic LINQ C# Sample,这个可以给我们提供不少方便,但是给的示例实在太简单,实际当中我们很多不能像他这样用。

image

首先引入DynamicLibrary.cs,下面是我使用过程中的一些运行正确的用法(里面使用返回DataSet是因为对旧程序升级),我觉得写法很怪异,但是的确这样是正确的。

image

调用

image

最终生成的SQL语句

 

SELECT   COUNT ( * AS   [ value ]
FROM   [ dbo ] . [ News ]   AS   [ t0 ]
WHERE  ( [ t0 ] . [ NewsIsDeleted ]   IS   NULL AND  ( [ t0 ] . [ NewsIsDisplay ]   =   1 )
AND
 ( [ t0 ] . [ Newslanguages ]   =   @p0 AND  ( [ t0 ] . [ NewsIsHome ]   =   1 AND  ( [ t0 ] . [ NewsIsTop ]   =   1 )
--  @p0: Input NVarChar (Size = 8; Prec = 0; Scale = 0) [engbtest]
--
 Context: SqlProvider(Sql2005) Model: AttributedMetaModel Build: 3.5.21022.8 

 

另外分享一个query to datareader的方法,有了datareader可以生成datatable,dataset等:

image

注:不知各位有没有更好的办法?

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值