腾讯一面问我SQL语句中where条件为什么写上1=1
来源:SegmentFault
时间:2023-01-24 14:11:19 224浏览 收藏
本篇文章主要是结合我之前面试的各种经历和实战开发中遇到的问题解决经验整理的,希望这篇《腾讯一面问我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运算符会得到意向不到的结果,结果会让你哆嗦。不信,往下看:
例如,当我们要删除博客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的永真条件,会导致整张表里的记录都被删除了。那你可就闯祸了。
不用where 1=1 在多条件查询的困扰
举个例子,如果你想查看当前博客中某条评论记录时,那么按照平时的查询语句的 动态构造,代码大体如下:
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语句为:
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 」第一时间阅读。每天分享优质文章、大厂经验、大厂面经,助力面试,是每个程序员值得关注的平台。
今天带大家了解了MySQL、面试、后端、校招的相关知识,希望对你有所帮助;关于数据库的技术知识我们会一点点深入介绍,欢迎大家关注golang学习网公众号,一起学习编程~
-
499 收藏
-
244 收藏
-
235 收藏
-
157 收藏
-
101 收藏
-
259 收藏
-
411 收藏
-
476 收藏
-
312 收藏
-
244 收藏
-
195 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 542次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 507次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 497次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 484次学习
-
- 精明的凉面
- 这篇文章真是及时雨啊,太全面了,很有用,已收藏,关注楼主了!希望楼主能多写数据库相关的文章。
- 2023-02-23 05:47:53
-
- 苹果发箍
- 太全面了,收藏了,感谢大佬的这篇技术贴,我会继续支持!
- 2023-02-18 16:54:56
-
- 痴情的未来
- 赞 👍👍,一直没懂这个问题,但其实工作中常常有遇到...不过今天到这,帮助很大,总算是懂了,感谢楼主分享文章!
- 2023-02-02 02:37:54
-
- 彩色的月饼
- 太全面了,已加入收藏夹了,感谢师傅的这篇博文,我会继续支持!
- 2023-02-01 04:48:20
-
- 花痴的香烟
- 这篇技术贴太及时了,细节满满,很有用,码起来,关注师傅了!希望师傅能多写数据库相关的文章。
- 2023-01-30 01:25:02
-
- 活力的手机
- 感谢大佬分享,一直没懂这个问题,但其实工作中常常有遇到...不过今天到这,看完之后很有帮助,总算是懂了,感谢up主分享技术贴!
- 2023-01-27 02:41:54
-
- 爱笑的大树
- 这篇博文太及时了,大佬加油!
- 2023-01-25 19:40:50
-
- 坚定的彩虹
- 这篇文章真及时,很详细,真优秀,已加入收藏夹了,关注作者大大了!希望作者大大能多写数据库相关的文章。
- 2023-01-25 01:40:27