点击上方“Java基基”,选择“设为星标”

做积极的人,而不是积极废人!

源码精品专栏

大家好,我是基基。

今天,基基,跟大家分享一下,程序员在编程过程中,偶尔会在代码中使用到“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”而导致语法错误。

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;

欢迎加入我的知识星球,一起探讨架构,交流源码。加入方式,长按下方二维码噢:

已在知识星球更新源码解析如下:

最近更新《芋道 SpringBoot 2.X 入门》系列,已经 20 余篇,覆盖了MyBatis、Redis、MongoDB、ES、分库分表、读写分离、SpringMVC、Webflux、权限、WebSocket、Dubbo、RabbitMQ、RocketMQ、Kafka、性能测试等等内容。

提供近 3W 行代码的 SpringBoot 示例,以及超 4W 行代码的电商微服务项目。

发表回复

您的电子邮箱地址不会被公开。 必填项已用*标注