首页 分享 SQL 语句中 where 条件后 写上 1=1 是什么意思!

SQL 语句中 where 条件后 写上 1=1 是什么意思!

来源:花匠小妙招 时间:2024-12-05 20:24

最新推荐文章于 2024-07-08 10:30:48 发布

DevolperFront 于 2021-03-25 23:59:54 发布

点击“开发者技术前线”,选择“星标????”

让一部分开发者看到未来

来源:架构师专栏

程序员在编程过程中,经常会在代码中使用到“where 1=1”,这是为什么呢?

这段代码应该是由程序(例如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中连接AND条件

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

where后面总要有语句,加上了1=1后就可以保证语法不会出错!

搜索后端架构师公众号回复“架构整洁”,送你一份惊喜礼包。

select * from table where 1=1

因为table中根本就没有名称为1的字段,所以该SQL等效于select * from table,

这个SQL语句很明显是全表扫描,需要大量的IO操作,数据量越大越慢,

建议查询时增加必输项,即where 1=1后面追加一些常用的必选条件,并且将这些必选条件建立适当的索引,效率会大大提高

拷贝表

create table  table_name   as   select   *   from   Source_table   where   1=1;

复制表结构

create table  table_name   as   select   *   from   Source_table   where   1 <> 1;

所以在查询时,where1=1的后面需要增加其它条件,并且给这些条件建立适当的索引,效率就会大大提高。

END

最后为大家准备了一份2020年最新最全的面试题及答案,这套电子书涵盖了诸多后端,客户端,前端技术栈的面试题和答案,相信可以帮助大家在最短的时间内复习的大多数面试题,从而拿到自己心仪的offer

大厂面试题领取方式:加下面我的微信一定要备注(大厂面试):

大厂面试题领取方式:

加下面助理的微信一定要备注(大厂面试):

研究/工作方向+地点+学校/公司+昵称

(如Java+上海+上交+可可)

根据格式备注,可更快被通过且邀请进群,领取一份专属学习礼包

相关知识

【转】SQL语言艺术
SQL语言艺术
《sql 语言艺术》 概要
【SQL】已解决:SQL错误(208):对象名‘STRING
=a在c语言中是什么意?c!=a在c语言中是什么意思 爱问知识人
后端SQL语句没错,但就是查不出数据
错误 1
C语言 z的意思,C语言中z= x是什么意思
SQL格式化工具
SQL 小技巧

网址: SQL 语句中 where 条件后 写上 1=1 是什么意思! https://www.huajiangbk.com/newsview898860.html

所属分类:花卉
上一篇: NumPy入门(5)
下一篇: 项目七

推荐分享