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日

相关文章

  • 也许是被忽略的update语句(update技巧)

    当我们开发网站或者其他软件时,经常需要对数据库中的数据进行修改。而更新数据最常用的方法就是使用 UPDATE 语句。但是有时候我们可能会犯一些错误,比如操作数据表时,我们可能会忽略掉 update 语句。本文将详细讲解“也许是被忽略的update语句(update技巧)”的完整攻略。 1. update 语句的作用 update 语句可以用于更新数据库表中的…

    database 2023年5月21日
    00
  • MySQL Where 条件语句介绍和运算符小结

    MySQL是一种非常流行的关系型数据库管理系统,非常适合于处理大量数据。在使用MySQL时,Where条件语句是非常重要的一部分,可以通过使用Where来根据条件过滤数据,从而获取我们想要的数据。 本文将深入讲解MySQL中Where条件语句的使用方法和运算符小结。 一、Where条件语句介绍 Where条件语句是用于从表中的记录中选择特定记录的语句。Whe…

    database 2023年5月22日
    00
  • linux尝试登录失败后锁定用户账户的两种方法

    在Linux中,有时候出于安全考虑需要在一定的登陆尝试次数失败后锁定用户账户来防止恶意攻击和暴力破解等行为。以下是两种常用的锁定用户账户的方法: 方法一:使用pam_tally2 1. 安装pam_tally2 pam_tally2是一个账户锁定模块,提供了一种在用户尝试次数达到限制后锁定账户的方式。 要使用pam_tally2,需要先安装它。在Debian…

    database 2023年5月22日
    00
  • PHP基于mssql扩展远程连接MSSQL的简单实现方法

    下面是“PHP基于mssql扩展远程连接MSSQL的简单实现方法”的完整攻略: 1. 确认mssql扩展已安装 在远程连接 MSSQL 数据库之前,需要在使用该扩展的 PHP 环境中安装 mssql 扩展。可以通过以下命令检查是否已经安装了 mssql 扩展。 php -m | grep mssql 如果输出 mssql 则表示已安装 mssql 扩展,否则…

    database 2023年5月22日
    00
  • MySQL启动1053错误解决方法

    以下是详细讲解“MySQL启动1053错误解决方法”的完整攻略。 MySQL启动1053错误解决方法 问题描述 在启动MySQL服务时,会出现1053错误,错误提示信息为:服务没有及时响应启动或控制请求。 可能原因 MySQL服务端口被占用; MySQL服务配置文件配置有误; MySQL服务文件损坏; MySQL服务安装不完整。 解决方法 方法一:检查MyS…

    MySQL 2023年5月18日
    00
  • MySQL按时间统计数据的方法总结

    MySQL按时间统计数据的方法总结 MySQL是一个常用的关系型数据库管理系统,常常需要按时间进行统计数据。本文总结了常见的按时间统计数据的方法。 方法一:使用DATE_FORMAT函数 SELECT DATE_FORMAT(created_at, ‘%Y-%m-%d’) AS day, COUNT(*) AS count FROM table GROUP …

    database 2023年5月22日
    00
  • mysql8.0.20配合binlog2sql的配置和简单备份恢复的步骤详解

    mysql8.0.20配合binlog2sql的配置和简单备份恢复的步骤详解 MySQL是常用的开源关系型数据库管理系统,在使用MySQL进行数据管理的过程中,经常需要进行数据备份和恢复操作,以保障数据的安全性和稳定性。其中,binlog2sql是一种常见的MySQL备份恢复工具,可以将二进制日志文件binlog转换成SQL语句,并执行这些SQL语句,生成一…

    database 2023年5月21日
    00
  • Oracle查询当前的crs/has自启动状态实例教程

    Oracle查询当前的CRS/HA自启动状态实例教程 背景介绍 在Oracle数据库的运维中,我们需要对CRS(Cluster Ready Services)或HA(High Availability)机制进行管理,了解当前实例的自启动状态,以便在需要时更好地进行故障恢复和管理。在本文中,我将向您介绍如何查询当前的CRS/HA自启动状态实例。 查询CRS/H…

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