当前位置:首页 > 文章列表 > 数据库 > MySQL > MySQL中where 1=1方法的使用及改进

MySQL中where 1=1方法的使用及改进

来源:脚本之家 2023-01-01 17:27:59 0浏览 收藏

对于一个数据库开发者来说,牢固扎实的基础是十分重要的,golang学习网就来带大家一点点的掌握基础知识点。今天本篇文章带大家了解《MySQL中where 1=1方法的使用及改进》,主要介绍了MySQLwhere、1=1,希望对大家的知识积累有所帮助,快点收藏起来吧,否则需要时就找不到了!

背景

刚入行的同学,看到在SQL语句中出现where 1 = 1这样的条件可能会有所困惑,而长时间这样使用的朋友可能又习以为常。那么,你是否还记得当初为什么要这样写?是否有性能问题?有没有更好的写法?

今天这篇文章,带大家从头到尾梳理一下where 1 = 1的使用及改进,或许你能从中得到更多意想不到的收获。

where 1=1的作用

如果要问在SQL语句的where条件中多加1=1目的是什么,很简单:使得where条件语句永远为真。本质上就是虽然加了where条件,但实际上永远为真,也就相当于没有加任何约束条件。

使用该语句的场景主要是:动态构建SQL语句

String sql  =  "select * from t_user  where 1=1 "; 
if(!b.equals("")){
  sql += "and  b='"+b+"'";
}   

在上述语句拼写时,使用where 1=1,当b不等于空时,可以直接拼接“and”语句,而不会导致语法错误。如果没有where 1=1,原来的SQL语句就变成(假设b传入了"abc"):

"select * from t_user  where and  b= 'abc' "; 

很明显,上述SQL语句会有语法错误。所以,之所以添加1=1,就是为了方便SQL拼接。

从另外一个角度来讲,不仅仅1=1可以这样使用,像:122>1'a'='a'等表达式,只要结果为true,都可以如此使用。

where 11

上面讲了where 1=1的来历及使用,那么你是否使用过where 11的形式呢?

你还别说,where 11也是有使用场景的,比如:只获取表结构而不取数据。

create table t_temp as select * from t_user  where 11

上述语句,创建了一个与t_user表结构一样但没有任何数据的新表t_temp。

当然,除了表结构,其他的结构也可以如此使用。

where 1=1的性能问题

有人说,使用where 1=1可能会有性能问题,咱们直接来实验一下。

mysql 8.0.18,t_user表,id_no字段有索引:

explain select * from t_user where id_no = 'Tom25';
explain select * from t_user where 1=1 and id_no = 'Tom25';

执行上述两行SQL语句,explain结果都是如下:

也就是说,1=1这样条件,并不影响索引和性能,从explain结果上可以看出两者并无本质区别。

之所以不同的SQL语句,呈现了相同的结果,这是因为被Mysql优化了。Mysql在处理指令时,会对1=1这类无效的条件进行优化处理。这个与Java的编译器有些像,很多无效的判断或语句,在编译成字节码时,编译器会进行优化处理。

where 1=1的改进

虽然说1=1会被优化器优化掉,但优化操作本身还是会消耗MySQL的性能的,如果能够从根本上避免这种情况的出现,那不就更好了。

以Mybatis为例,在使用where 1=1时,通常会是如下写法:

<select id="queryUser" parametertype="com.choupangxia.entity.User" resulttype="java.lang.Integer">
  select count(id) from t_user u where 1=1
<if test="username !=null and username !='' ">
  AND u.username = #{username} 
</if><if test="userNo !=null and userNo !='' ">
  AND u.user_no = #{userNo}
</if></select>

这里where 1=1的作用同上。但如果你更进一步去了解Mybatis的语法及标签,可以使用标签来代替where 1=1

<select id="queryUser" parametertype="com.choupangxia.entity.User" resulttype="java.lang.Integer">
  select count(id) from t_user u
<where><if test="username !=null and username !='' ">
 u.username = #{username} 
</if><if test="userNo !=null and userNo !='' ">
 AND u.user_no = #{userNo}
</if></where></select>

这样,在查询数据比较大的情况下,可减少MySQL为了优化1=1这样的条件而损失的性能。

小结

本文我们从习以为常的where 1=1使用聊起,聊了它的使用场景、MySQL对其优化、以及延伸出来的where 11的使用,同时基于常见的Mybatis框架,如何进一步改进。

其实,写这篇文章想传达的一个思想就是:再小,再习以为常的事物,如果你去思考、研究都会学到很多相关的知识点,也都可以对其进一步优化。

终于介绍完啦!小伙伴们,这篇关于《MySQL中where 1=1方法的使用及改进》的介绍应该让你收获多多了吧!欢迎大家收藏或分享给更多需要学习的朋友吧~golang学习网公众号也会发布数据库相关知识,快来关注吧!

版本声明
本文转载于:脚本之家 如有侵犯,请联系study_golang@163.com删除
MySQL中空值Null和空字符‘‘的具体使用MySQL中空值Null和空字符‘‘的具体使用
上一篇
MySQL中空值Null和空字符‘‘的具体使用
深入理解MySQL中MVCC与BufferPool缓存机制
下一篇
深入理解MySQL中MVCC与BufferPool缓存机制
查看更多
最新文章
查看更多
课程推荐
  • 前端进阶之JavaScript设计模式
    前端进阶之JavaScript设计模式
    设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
    542次学习
  • GO语言核心编程课程
    GO语言核心编程课程
    本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
    511次学习
  • 简单聊聊mysql8与网络通信
    简单聊聊mysql8与网络通信
    如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
    498次学习
  • JavaScript正则表达式基础与实战
    JavaScript正则表达式基础与实战
    在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
    487次学习
  • 从零制作响应式网站—Grid布局
    从零制作响应式网站—Grid布局
    本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
    484次学习
查看更多
AI推荐
  • 千音漫语:智能声音创作助手,AI配音、音视频翻译一站搞定!
    千音漫语
    千音漫语,北京熠声科技倾力打造的智能声音创作助手,提供AI配音、音视频翻译、语音识别、声音克隆等强大功能,助力有声书制作、视频创作、教育培训等领域,官网:https://qianyin123.com
    95次使用
  • MiniWork:智能高效AI工具平台,一站式工作学习效率解决方案
    MiniWork
    MiniWork是一款智能高效的AI工具平台,专为提升工作与学习效率而设计。整合文本处理、图像生成、营销策划及运营管理等多元AI工具,提供精准智能解决方案,让复杂工作简单高效。
    89次使用
  • NoCode (nocode.cn):零代码构建应用、网站、管理系统,降低开发门槛
    NoCode
    NoCode (nocode.cn)是领先的无代码开发平台,通过拖放、AI对话等简单操作,助您快速创建各类应用、网站与管理系统。无需编程知识,轻松实现个人生活、商业经营、企业管理多场景需求,大幅降低开发门槛,高效低成本。
    106次使用
  • 达医智影:阿里巴巴达摩院医疗AI影像早筛平台,CT一扫多筛癌症急慢病
    达医智影
    达医智影,阿里巴巴达摩院医疗AI创新力作。全球率先利用平扫CT实现“一扫多筛”,仅一次CT扫描即可高效识别多种癌症、急症及慢病,为疾病早期发现提供智能、精准的AI影像早筛解决方案。
    98次使用
  • 智慧芽Eureka:更懂技术创新的AI Agent平台,助力研发效率飞跃
    智慧芽Eureka
    智慧芽Eureka,专为技术创新打造的AI Agent平台。深度理解专利、研发、生物医药、材料、科创等复杂场景,通过专家级AI Agent精准执行任务,智能化工作流解放70%生产力,让您专注核心创新。
    97次使用
微信登录更方便
  • 密码登录
  • 注册账号
登录即同意 用户协议隐私政策
返回登录
  • 重置密码