在sql的where条件下怎么加判断语句?

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了在sql的where条件下怎么加判断语句?相关的知识,希望对你有一定的参考价值。

比如说:有一个参数 A , 如果A等于null的话,where后面就加上 num is null 否则就加上 null = A 语句是select * from dual where 后面怎么写??? 请教各位大侠了

一句sql恐怕难写,要写存储过程或是function 参考技术A case where datediff(dd,getdate(),baoziqi)<20 then '停止销售' else '继续销售' end 参考技术B 之前在搜索这个问题,我是用这样类似的逻辑:

select * from table where (case when A is null then (case when num is NULL then 1 else 0 end) else (case when num=A then 1 else 0 end) end)=1
参考技术C select * from dual where (num = A and A = 'XX') or (A <> 'XX' and num is null) 参考技术D 你自己不都写出来了?我想知道的是你的A是外界传入的还是什么?还有就是你用的数据库是oracle吧。

sql语句中“where1=1”是啥意思?

where 1=1是sql语句条件逻辑判断表达式,由于1=1成立,恒为真,该表达式1=1将始终返回"真"。

这段代码应该是由程序(例如Java)中生成的,where条件中 1=1 之后的条件是通过 if 块动态变化的。

语句将返回t1中所有的记录行

where 1=1 是为了避免where 关键字后面的第一个词直接就是 “and”而导致语法错误。

SQL语句

中是SQL语句必须定义的部分,[]中是SQL语句可选择的部分,可以省略的。

所要定义的基本表的名称,一个表可以由一个或若干个属性(列)组成,但至少有一个属性,不允许一个属性都没有的表,这样不是空表的含义。多个属性定义由圆括号指示其边界,通过逗号把各个属性定义分隔开,各个属性名称互不相同,可以采用任意顺序排列,一般按照实体或联系定义属性的顺序排列,关键字属性组在最前面,这样容易区分,也防止遗漏定义的属性。

以上内容参考:百度百科-结构化查询语言

参考技术A

where 1=1是sql语句条件逻辑判断表达式,由于1=1成立,恒为真,该表达式1=1将始终返回"真"。这种写法实际目的是为了获取逻辑值"True",其实诸如2=2, 1+2=3,'中'='中'等之类的写法都可以返回逻辑值"True",只不过1=1的运算开销更小,故被应用的最普遍。

下面例子将有助于理解有关概念:

1) select * from t1 where 1=1;
-- 实际等效于select * from t1 where true;
-- 语句将返回t1中所有的记录行

2) select * from t1 where 1<>1;
-- 实际等效于 select * from t1 where false;
-- 语句将返回空记录集

说明,例1)实际上等同于不加任何筛选条件,有些画蛇添足,where 1=1的实际意义不如where 1<>1来得有用,当我们只需要获取表的字段(结构)信息,而不需要理会实际保存的记录时,例2)的写法将是非常可去取的,因为系统仅会读取结构信息,而不会将具体的表记录读入内存中,这无疑节省了系统开销。

参考技术B 这段代码应该是由程序(例如Java)中生成的,where条件中 1=1 之后的条件是通过 if 块动态变化的。例如:
String sql="select * from table_name where 1=1";
if( conditon 1)
sql=sql+" and var2=value2";

if(conditon 2)
sql=sql+" and var3=value3";

where 1=1 是为了避免where 关键字后面的第一个词直接就是 “and”而导致语法错误。

以上是关于在sql的where条件下怎么加判断语句?的主要内容,如果未能解决你的问题,请参考以下文章

sql中where 之后怎么加if条件判断

SQL语句中where条件的写法

SQL 中 where 条件中 in 后面 加 CASE WHEN 语句 报错

SQL 中 where 条件中 in 后面 加 CASE WHEN 语句 报错

sql怎么用两个条件判断,让其中另一个值等于别的

sql条件判断语句