博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
(原)强类型dataset(类型化dataset)中动态修改查询条件(不确定参数查询)...
阅读量:7172 次
发布时间:2019-06-29

本文共 620 字,大约阅读时间需要 2 分钟。

原创博客,转载请注明:

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

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即可!

 

你可能感兴趣的文章
Android NDK 项目依赖简单示例
查看>>
Vue中插槽的使用。
查看>>
Android 安装镜像
查看>>
项目管理深入理解05--范围管理
查看>>
poj 2459 Sumsets
查看>>
MAT分析android内存泄漏
查看>>
关于Struts2中提交出现乱码的问题
查看>>
Windows常用命令,想要看什么命令直接在全文“CTRL+F”检索(转)
查看>>
数值的整数次方
查看>>
C++整数转string
查看>>
201621123018《java程序设计》第11周作业总结
查看>>
socket阻塞与非阻塞,同步与异步、I/O模型
查看>>
mysql 开发进阶篇系列 36 工具篇mysqlshow(数据库对象查看工具)
查看>>
如何高效的使用PowerShell备份数据库
查看>>
默认的Sublime 3中没有Package Control
查看>>
Axure 7.0百度云盘下载
查看>>
Unity AngryBots愤怒的机器人demo研究
查看>>
Asp.net MVC验证哪些事(2)-- 验证规则总结以及使用
查看>>
js学习1 —— 类型,值,变量
查看>>
Select count(*)、Count(1)、Count(0)的区别和执行效率比较
查看>>