(原)强类型dataset(类型化dataset)中动态修改查询条件(不确定参数查询)
2013-10-10 18:31
465 查看
原创博客,转载请注明:/article/5109977.html
查询时有多个参数,参数个数由客户输入决定,不能确定有多少个参数,按一般的方法每种参数组合都得写个方法,很麻烦,解决方法如下:
这样的话当有不需要的条件时,就往函数对应参数传入null即可。
另外,由于查询函数是VS自动生成,那么有的参数类型会使string,而不是System.Nullable<>类型,那么穿null进去就会出错,手动修改又可能丢失,例如如下条件:
@结束日期参数就会是string类型,传null进去就会出错,我现在暂时找到的不太好的方法是,加个 or 日期=@结束日期,如下所示:
这样VS自动生成的方法就会是System.Nullable<>类型。如果您有更好的方法,欢迎指教留言。
最新尝试到使参数类型为System.Nullable<>类型的方法:
找到你的方法,打开它对应的属性面板,如下图:
点击参数属性(红色圈中),如下图:
选择为true即可!
查询时有多个参数,参数个数由客户输入决定,不能确定有多少个参数,按一般的方法每种参数组合都得写个方法,很麻烦,解决方法如下:
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即可!
相关文章推荐
- Mybatis 不确定条件查询(动态语句where和if)借助实体类封装参数
- MyBatis中的动态SQL,实现不确定条件的CRUD-----使用Map来传递查询的参数
- 动态SQL中 实现条件参数 varchar类型的参数名称 以及模糊查询实现
- mybatis动态条件查询修改小例子
- 使用ADF-BC 实现查询功能之四:通过代码动态设置Where条件参数
- 如何动态修改ObjectDataSource数据源的查询参数
- 泛型约束where条件的使用(通过类型参数动态反射创建实例)
- 一个数据库查询方法(可以动态设置查询参数,设置查询条件),很巧妙的组合sql语句
- 泛型约束where条件的使用(可以通过类型参数动态反射创建实例)
- 使用ADF-BC 实现查询功能之八:通过代码动态设置Criteria条件参数
- linq里lambda写的join查询,并附加动态拼接的条件,条件为enum类型的查询
- 多条件查询--使用dapper命令参数动态拼接出最安全的sql语句
- sql 动态修改查询条件
- 动态指定任意类型的ObjectDataSource对象的查询参数
- 动态SQL文中where条件是IN,而导入的参数个数不确定的情况(亲自实践)
- ASP.NET 多条件动态参数查询方法
- easyui datagrid 动态修改查询参数
- 动态指定任意类型的ObjectDataSource对象的查询参数
- (笔记)VB中修改字体大小、日期加减,oracle数据库中查询条件为日期类型