(原)强类型dataset(类型化dataset)中动态修改查询条件(不确定参数查询)...

原创博客,转载请注明:http://www.cnblogs.com/albert1017/p/3361932.html

查询时有多个参数,参数个数由客户输入决定,不能确定有多少个参数,按一般的方法每种参数组合都得写个方法,很麻烦,解决方法如下:

select * from table where (addDate = @addDate or @addDate is null) and (name = @name or @name = '')

这样的话当有不需要的条件时,就往函数对应参数传入null即可。

另外,由于查询函数是VS自动生成,那么有的参数类型会使string,而不是System.Nullable<>类型,那么穿null进去就会出错,手动修改又可能丢失,例如如下条件:

where DATEDIFF(day, 日期, @结束日期) >= 0 or @结束日期 is null

@结束日期参数就会是string类型,传null进去就会出错,我现在暂时找到的不太好的方法是,加个 or 日期=@结束日期,如下所示:

where DATEDIFF(day, 日期, @结束日期) >= 0 or @结束日期 is null or 日期=@结束日期

这样VS自动生成的方法就会是System.Nullable<>类型。如果您有更好的方法,欢迎指教留言。

 

最新尝试到使参数类型为System.Nullable<>类型的方法:

找到你的方法,打开它对应的属性面板,如下图:

点击参数属性(红色圈中),如下图:

 

 选择为true即可!

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值