腾讯一面问我SQL语句中where条件为何写上1=1

在项目编写中,常常会在代码中使用到“where 1=1”,这是为何呢?

目录

  • where后面加"1=1"仍是不加
  • 不用where 1=1 在多条件查询的困惑
  • 使用where 1=1 的好处
  • 使用where 1=1 的坏处

where后面加"1=1"仍是不加

好比如今有一个场景,DB数据库中有一张博客表(blog),想把blog表中的全部记录查询出来,那么能够有两种方式操做。一种写法是where关键词什么也不加,另外一种写法是where关键词后面加"1=1",写法以下:程序员

  • where关键词什么也不加
select * from blog;
  • where关键词后面加 "1=1"
select * from blog where 1 = 1;

这两种SQL语句查询所获得的结果彻底没有区别。那为何要在where关键字后面添加"1=1"呢?面试

咱们知道1=1表示true,即永真。若是使用不恰当会造T0级错误。例如在编写SQL语句时进行where条件查询时配合or运算符会获得意向不到的结果,结果会让你哆嗦。不信,往下看:sql

例如,当咱们要删除博客ID称为“202102111501”的记录,咱们能够这样写:数据库

delete from blog where blogId = "202102111501"

若是这个时候若是在where语句后面加上 or 1=1会是什么后果?微信

delete from blog where blogId = "202102111501" or 1 = 1

原本只要博客ID称为“202102111501”的记录,结果由于添加了or 1=1的永真条件,会致使整张表里的记录都被删除了。那你可就闯祸了。code

不用where 1=1 在多条件查询的困扰

举个例子,若是你想查看当前博客中某条评论记录时,那么按照平时的查询语句的 动态构造,代码大致以下:blog

String sql="select * from blog where";
if ( condition 1) {
  sql = sql + " blogID = 202102111501";
}
if (condition 2) {
  sql = sql + " and commentID = 150101";
}

若是上述的两个if判断语句均为true时,那么最终的动态SQL语句为:索引

select * from table_name where blogID = 202102111501 and commentID = 150101;

能够看出来这是一条完整的正确的SQL查询语句,可以正确执行。博客

若是上述的两个if判断语句均为false时,那么最终的动态SQL语句为:it

select * from table_name where;

此时咱们看看这条生成的SQL语句,因为where关键字后面须要使用条件,可是这条语句根本不存在,因此该语句就是一条错误语句,不能被执行,不只报错,同时还查不到任何数据。

使用where 1=1 的好处

若是咱们在where条件后加上1=1,看看它的真面目:

String sql="select * from blog where 1=1";
if ( condition 1) {
  sql = sql + " and blogID = 202102111501";
}
if (condition 2) {
  sql = sql + " and commentID = 150101";
}

当condition 1和condition 2都为真时,上面被执行的SQL代码为:

select * from blog where 1=1 and blogID = "202102111501" and commentID = 150101;

能够看出来这是一条完整的正确的SQL查询语句,可以正确执行。

若是上述的两个if判断语句均为false时,那么最终的动态SQL语句为:

select * from table_name where 1=1;

如今,咱们来看这条语句,因为where 1=1 是为True的语句,所以,该条语句语法正确,可以被正确执行,它的做用至关于:sql="select * from table",即返回表中全部数据。

当在where关键字后面添加1=1时,若是此时查询时不选择任何字段时,那么必将返回表中的全部数据。若是是按照某个字段进行单条查询时,那么就会此时的条件进行查询。

说到这里,不知道您是否已明白,其实,where 1=1的应用,不是什么高级的应用,也不是所谓的智能化的构造,仅仅只是为了知足多条件查询页面中不肯定的各类因素而采用的一种构造一条正确能运行的动态SQL语句的一种方法。

使用where 1=1 的坏处

咱们在写SQL时,加上了1=1后虽然能够保证语法不会出错!

select * from table_name where 1=1;

可是由于table中根本就没有名称为1的字段,该SQL其实等效于select * from table,这个SQL语句很明显是全表扫描,须要大量的IO操做,数据量越大越慢。

因此在查询时,where1=1的后面须要增长其它条件,而且给这些条件创建适当的索引,效率就会大大提升。

文章也会持续更新,能够微信搜索「 迈莫coding 」第一时间阅读。天天分享优质文章、大厂经验、大厂面经,助力面试,是每一个程序员值得关注的平台。
相关文章
相关标签/搜索