SQL中 and or优先级问题

SQL中 and or优先级问题,where 后面如果有and,or的条件,则or自动会把左右的查询条件分开,即先执行and,再执行or。原因就是:a

刚刚在项目中遇到这样一个问题,SQL语句如下:

select * from LOAN_BACK_LIBRARY where LIBRARY_ID=1 or LIB_ID=1 and STATUS=3

我想要的结果的条件是:1. LIBRARY_ID=1 或者 LIB_ID=1

                                       2.STATUS=3

但是结果并非如此,出现了STATUS!=3的结果,但是却匹配了 LIBRARY_ID=1 or LIB_ID=1

为什么呢

原来这个SQL的执行是这样的:

select * from LOAN_BACK_LIBRARY where LIBRARY_ID=1 or LIB_ID=1 and STATUS=3

修改为:

呵呵,发现问题了:

where 后面如果有and,or的条件,则or自动会把左右的查询条件分开,即先执行and,再执行or。原因就是:and的执行优先级最高!

关系型运算符优先级高到低为:not and or

问题的解决办法是:

用()来改变执行顺序!!!!

上面我所需要的SQL语句是这样的

这样就是完美的答案了!!!!

linux

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/1932596.html

(0)
上一篇 2025年2月22日 21:55:47
下一篇 2025年2月22日 21:56:47

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • 如何将 AWS Glue 爬网程序与 Amazon Athena 结合使用

    作为数据专业人员,您需要处理来自各种来源的大量数据。这可能会给数据管理和分析带来挑战。幸运的是,两项 AWS 服务可以提供帮助:AWS Glue 和 Amazon Athena。 当您集成这些服务时,您就释放了 AWS 生态系统中的数据发现…

    2025年2月23日
    100
  • Navicat实用功能:数据备份与结构同步

    摘要 当我们要对数据库做有风险的操作时需要对数据库备份,每次上线项目时,线上与线下数据库结构总会有不一致的情况,本文将讲解如何利用Navicat来方便的解决这两个问题。 Navicat Navicat是一套快速、可靠的数据库管理工具,专为简…

    2025年2月23日 数据库
    100
  • sql文件怎么导入navicat

    打开Navicat for MySQL后点击新建链接,会呈现很多未打开的数据库,在任意一个数据库上右键点击,选择“新建数据库”。 会出现一个弹窗,输入数据库的名字,随便写一个,字符集选择GBK,排序规则可以不用选。 相关推荐:《Navica…

    2025年2月23日 数据库
    100
  • navicat premium怎么上传数据库

    首先,在Navicat Premium中连接要导出数据库的mysql数据库。 填写好连接数据库的信息后就可以连接到需要导出的数据库了。 打开要导出的数据库。 将数据库的结构和数据导出为SQL文件。 相关推荐:《Navicat for mys…

    2025年2月23日 数据库
    100
  • navicat怎么打开数据库

    1、打开Navicat,点击左上角的‘Conection’按钮。 2、点击后,弹出菜单,我们要选择是哪种类型的数据库,根据你本地部署的数据库类型来选就行了,我这里选择MySql。 3、选择后,弹出窗口,在这个窗口上我们先输入数据库的Host…

    2025年2月23日 数据库
    100
  • navicat怎么清除数据库备份

    第一步,打开Navicat。 第二步,打开mysql数据库连接。 相关推荐:《Navicat for mysql使用图文教程》 第三步,点击备份所在的数据库,并选中备份菜单,此时显示已建的备份。 第四步,右击要删除的备份,在弹出菜单中选择“…

    2025年2月23日 数据库
    100
  • navicat怎么执行sql

    首先,使用Navicat for MySQL连接数据库并创建一个数据库。 接着点击查询,这里有两个查询,随便点击一个都可以。 既然是要执行SQL语句,所以我们要先新建一个查询窗体才得。 相关推荐:《Navicat for mysql使用图文…

    2025年2月23日 数据库
    100
  • navicat for mysql怎么导入sql

    Navicat for Mysql 是应用比较多的mysql的视图管理工具。下面为大家记录下Navicat for mysql如何导入sql文件。 推荐教程:MySQL入门视频教程 1、首先创建一个数据库(因为我导入的sql文件只有建表和插…

    2025年2月23日 数据库
    100
  • navicat怎么备份数据库

    本篇经验将和大家介绍如何利用Navicat for MySQL进行数据库备份的操作,希望对大家的工作和学习有所帮助! 推荐教程:mysql入门视频教程 1、打开桌面上的或者从开始程序中找到Navicat for MySQL,如下图所示: 2…

    2025年2月23日 数据库
    100
  • navicat新建数据库的步骤

    打开navicat工具,连接上您自己的mysql服务器,然后在如图所示的连接上右击,选择新建数据库。 相关推荐:《Navicat for mysql使用图文教程》 在新建数据库对话框中,需要输入数据库名称,选择字符集和排序规则,名称建议使用…

    2025年2月23日 数据库
    100

发表回复

登录后才能评论