SQL语句关于where判断问题

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了SQL语句关于where判断问题相关的知识,希望对你有一定的参考价值。

strSQL.Format("INSERT INTO 开关机时间记录结果(关机记录) SELECT(关机记录) FROM 关机时间表 WHERE [关机时间表].序号 = [开关机时间记录结果].序号");
加上WHERE判断语句后会报错,报错内容为:至少有一个参数未定义,请问应该怎么写,判断内容为 两张表的序号字段一致则插入

参考技术A

INSERT INTO 开关机时间记录结果(关机记录) SELECT(关机记录) FROM 关机时间表,开关机时间记录结果 WHERE [关机时间表].序号 = [开关机时间记录结果].序号

参考技术B 可以这么写:
strSQL.Format("INSERT INTO 开关机时间记录结果(关机记录) SELECT(关机记录) FROM 关机时间表 INNER JOIN 开关机时间记录结果 ON [关机时间表].序号 = [开关机时间记录结果].序号");本回答被提问者采纳
参考技术C 2表的关联条件没写追问

你可以说的具体些吗?应该怎么改?

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条件下怎么加判断语句?

sql 语句中where多个数值条件的判断使用,或者其他可以实现的方式,高手来

关于 select的条件语句where 后能否内嵌另一个 select语句??

oracle SQL查询中,如何在where中用条件语句,判断不同情况,追加不同的And条件?

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

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