mysql -sql语句not in判断条件注意事项

sql语句not in判断条件注意事项

  问题描述:mysql数据库,存在两个表org表和kdorg表,用于存储组织信息。现在我需要从org表找出组织,条件为该组织不在kdorg表里。

  sql语句:select o.orgno o.orgname from org o where orgno not in(select kd.orgno from kdorg kd);

  明明org表里存在一些组织,该组织的组织编号不存在于kdorg表,但查询结果就是0条记录。搞了一天,也没搞出问题在哪,头都大了,就是一条简单的sql语句,条件满足,为何就是不对呢?

  原因分析:是因为kdorg表存在一条记录,该记录的orgno为null,导致查询结果为空。把orgno为null的记录从kdorg表删除,该sql语句就能成功查询出所需信息。

  总结: not in /in(不能存在null的字段,否则会导致条件失效,sql语句查不出所需数据)

  改进:(1)select o.orgno o.orgname from org o where orgno not in(select kd.orgno from kdorg kd where kd.orgno is not null);

  (2)保证子查询结果中不存在null。

sql语句not in判断条件注意事项

  问题描述:mysql数据库,存在两个表org表和kdorg表,用于存储组织信息。现在我需要从org表找出组织,条件为该组织不在kdorg表里。

  sql语句:select o.orgno o.orgname from org o where orgno not in(select kd.orgno from kdorg kd);

  明明org表里存在一些组织,该组织的组织编号不存在于kdorg表,但查询结果就是0条记录。搞了一天,也没搞出问题在哪,头都大了,就是一条简单的sql语句,条件满足,为何就是不对呢?

  原因分析:是因为kdorg表存在一条记录,该记录的orgno为null,导致查询结果为空。把orgno为null的记录从kdorg表删除,该sql语句就能成功查询出所需信息。

  总结: not in /in(不能存在null的字段,否则会导致条件失效,sql语句查不出所需数据)

  改进:(1)select o.orgno o.orgname from org o where orgno not in(select kd.orgno from kdorg kd where kd.orgno is not null);

  (2)保证子查询结果中不存在null。

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:mysql -sql语句not in判断条件注意事项 - Python技术站

(0)
上一篇 2023年4月14日
下一篇 2023年4月16日

相关文章

  • Redis3.2开启远程访问详细步骤

    下面我来为您讲解 Redis 3.2 开启远程访问的详细步骤。一共分为以下几步: 1. 修改 Redis 配置文件 要让 Redis 支持远程访问,需要修改 Redis 的配置文件redis.conf。在该文件中找到注释掉的 bind 配置项,并修改为下面的形式: bind 0.0.0.0 该配置项表示 Redis 服务器接受来自任意 IP 的连接。如果想要…

    database 2023年5月22日
    00
  • MySQL事务还没提交,Canal就能读到消息了?

    【问题描述】 开发有天碰到一个很奇怪的问题,他的场景是这样子的:通过Canal来订阅MySQL的binlog, 当捕获到有数据变化时,回到数据库,反查该数据的明细,然后做进一步处理。有一次,他碰到一个诡异的现象: 1. Canal收到消息,有一条主键id=31019319的数据插入 2. 11:19:51.081, 应用程序去反查数据库,11:19:51.0…

    MySQL 2023年4月18日
    00
  • MySQL聚合查询与联合查询操作实例

    MySQL聚合查询与联合查询操作实例 聚合查询 简介 聚合查询是在SELECT语句中使用一组聚合函数(比如SUM,AVG,MAX和COUNT等)在结果集上执行计算,返回一个统计值,而不是一列数据的列表。通常用于计算某一列的总和、平均值、最大/最小值、行数等。聚合查询能够提供有关群体的信息,而不是单独的行,这种信息对于分析数据和做出决策非常有用。 语法 SEL…

    database 2023年5月22日
    00
  • nginx常见问题整理和解决办法

    nginx常见问题整理和解决办法 1. 服务器上的nginx没有启动该怎么办? 首先,我们需要检查一下nginx是否已经正确安装了。可以使用nginx -v命令来查看当前安装的nginx版本信息。如果显示没有安装,则需要先安装nginx相关的软件包。 一般情况下,如果nginx没有启动,我们需要进入nginx安装目录下进行手动启动,通过以下命令启动nginx…

    database 2023年5月21日
    00
  • 详解MySQL中的分组查询与连接查询语句

    下面是针对“详解MySQL中的分组查询与连接查询语句”的完整攻略: 分组查询 在MySQL中,使用GROUP BY关键字可以对查询的结果集进行分组。 语法 SELECT col_name1, col_name2, … FROM table_name GROUP BY col_name1, col_name2, …; 示例说明 考虑下面这个表: stu…

    database 2023年5月21日
    00
  • MySQL8.0升级的踩坑历险记

    MySQL8.0升级的踩坑历险记 最近,我们的网站需要升级MySQL数据库,由于之前的版本较老,我们决定升级至MySQL8.0版本。在升级的过程中,我们踩了很多坑,现在来总结一下我们的经验,希望对其他人有所帮助。 1.备份原数据库 首先,升级之前一定要备份好原来的数据库。可以使用mysqldump命令备份整个数据库,也可以备份某些表或者某些数据。以下是备份整…

    MySQL 2023年5月18日
    00
  • mybatis中foreach报错:_frch_item_0 not found的解决方法

    针对mybatis中foreach报错:“_frch_item_0 not found”的解决方法,我将提供以下完整攻略。 问题分析 通过对mybatis中foreach的使用进行分析,可以得出使用foreach时,需要保证以下几点: collection属性必须设置为可遍历的集合类型(比如List、Set等)。 item属性必须设置,不然会报错。 当col…

    database 2023年5月21日
    00
  • SQL 查询 SELECT

    SQL(Structured Query Language)是一种可以用来查询和处理关系型数据库的计算机语言。SELECT 是 SQL 中最常用的命令之一,它用来获取表中的数据。 下面是 SELECT 命令的语法: SELECT column1, column2, … FROM table_name; 其中,column1,column2 表示需要返回的…

    database 2023年3月27日
    00
合作推广
合作推广
分享本页
返回顶部