首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >传递% using IN SQL

传递% using IN SQL
EN

Stack Overflow用户
提问于 2011-06-22 13:52:13
回答 6查看 103关注 0票数 0

我有一个问题

代码语言:javascript
复制
select dim.name as division,dm.name as department, cuser.contractor_name, cuser.contractor_surname,d.status as status,
d.date_submission,cm.name as code,scm.name as subCode,cuser.company_name as company, gt.grade_name as grade, gm.grade_value as gradeValue
from document d, selected_grade_map sgm, selected_grade_details sgd, code_master cm,code_master scm,
contractor_user_master_ipms cuser, department_master dm, division_master dim, grade_master gm, grade_type gt
where 
convert(datetime, convert(varchar(10), d.date_submission, 101)) <= convert(datetime, '2011-06-22') AND 
convert(datetime, convert(varchar(10), d.date_submission, 101)) >= convert(datetime, '2010-12-22') AND
d.application_status = 'NEW' 
and d.status != 'Forked'
and d.id = sgm.doc_id 
and sgm.selected_grade_id = sgd.selected_grade_id
and sgd.code_id = cm.code_id 
and sgd.sub_code_id = scm.code_id 
and d.contractor_user = cuser.id 
and d.department_id = dm.id 
and d.division_id = dim.id 
and sgd.grade_id = gm.grade_id
and gm.grade_type_id = gt.grade_type_id
and d.department_id IN ('%')
and dim.id IN (1,2)
and cm.code_id like '%' 
and scm.code_id like '%' 
and gt.grade_type_id like '%'
and d.status like '%'
and cuser.reservation_category like '%'
and cuser.company_name like '%' 

情况就是..。用户可以选择多个条件作为筛选器,但如果用户没有选择任何筛选器,那么我需要传递所有。因此,我尝试在SQL中使用%。但是这里的列是整型的。它不会允许这样做的。

查询是静态的,并且是用iReport编写的

如何在SQL中使用全部传递,如下所示

代码语言:javascript
复制
d.department_id IN ('%')
EN

回答 6

Stack Overflow用户

回答已采纳

发布于 2011-06-22 13:55:17

IN查询不允许传递字符串,并且该字符串不会与任何整数匹配,因为它不在LIKE中。看看您的iReport如何动态更改查询的这一部分。

票数 2
EN

Stack Overflow用户

发布于 2011-06-22 14:03:01

在输入为none的情况下,你能给出一个像-1这样的虚拟值吗?

然后转换查询,如下所示

代码语言:javascript
复制
(  
  d.department_id IN (@Userparam) 
    OR
  (-1) IN (@Userparam) -- If you pass -1 then it returns all user departments
)
票数 3
EN

Stack Overflow用户

发布于 2011-06-22 13:59:19

Like '%'的黑客攻击即使在它工作的地方也是可怕的。您必须研究如何动态更改查询。

如果真的只有一个整型列需要过滤或不过滤,那么可以选择两个静态查询(一个有条件,另一个没有条件)。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/6435493

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档