首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

SQL NOT IN()不工作,返回不应该返回的数据

SQL NOT IN()是一种用于过滤数据的查询条件,用于在查询结果中排除指定的值。然而,有时候可能会出现查询结果不符合预期的情况。

可能导致SQL NOT IN()不工作的原因有以下几个方面:

  1. 数据类型不匹配:SQL中的数据类型需要匹配才能正确进行比较。如果数据类型不一致,可能会导致查询结果不正确。在使用SQL NOT IN()时,需要确保比较的数据类型一致。
  2. NULL值处理:SQL中的NULL值与其他值的比较结果不确定。使用SQL NOT IN()时,如果查询结果中包含NULL值,可能会导致不符合预期的结果。在处理包含NULL值的情况下,可以使用IS NULL或IS NOT NULL来进行精确的比较。
  3. 列中包含空格或特殊字符:列中包含空格或特殊字符可能会导致查询结果不符合预期。在使用SQL NOT IN()时,确保列中的值没有额外的空格或特殊字符,可以使用TRIM()函数来去除空格。
  4. 子查询中的结果不正确:如果SQL NOT IN()中使用了子查询,确保子查询的结果准确无误。子查询可能返回错误的结果,导致主查询的结果也不正确。

为了解决SQL NOT IN()不工作的问题,可以尝试以下方法:

  1. 使用其他的条件运算符:尝试使用其他的条件运算符,如NOT EXISTS、LEFT JOIN等来代替SQL NOT IN(),看是否能得到正确的结果。
  2. 检查数据类型:确保比较的数据类型一致,可以使用CAST()或CONVERT()函数进行数据类型转换。
  3. 处理NULL值:对于包含NULL值的情况,使用IS NULL或IS NOT NULL进行精确的比较。
  4. 检查列中的空格或特殊字符:使用TRIM()函数去除列中的空格或特殊字符,确保比较的准确性。

总结起来,SQL NOT IN()不工作可能是由于数据类型不匹配、NULL值处理、列中包含空格或特殊字符、子查询结果不正确等原因导致的。通过检查数据类型、处理NULL值、去除空格或特殊字符以及检查子查询结果的准确性,可以解决SQL NOT IN()不工作的问题。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

sql返回指定节点的树形结构数据

背景 就是有这么一个需求,返回指定组织下的组织机构,以及所在该组织机构下的人。(用sql) 简单描述就是如下: ?...请叫我树形图 使用sql,返回部门1以及其子部门数据。 很明显就是一个树形递归嘛,用代码就比较好实现。 但是要用sql实现,就稍微麻烦点。...正文 创建符合上述思维导图的表department,如下图: ? 请叫我数据表 我就不按网上百度的sql树形递归的思路讲了。我也去百度了,感觉一大扒拉,又不想看。...返回指定节点以及其下子节点数据 到此,本文需求功能已实现。 知识点 1.数据库是mysql,所用的函数也是mysql的函数。 2....如果str不在strlist 或strlist 为空字符串,则返回值为 0 。如任意一个参数为NULL,则返回值为 NULL。 结语 不积跬步无以至千里。觉得不错,记得点亮小星星。

2.6K31

nc命令卡住不返回的分析

具体通过如下命令获取zk的状态: echo stat | nc 192.168.73.77 2181 出现问题时,发现nc命令一直没有返回,导致无法执行后续的步骤(程序压根没启动)。...不信邪,再多试几次,nc命令均正确返回退出,并且能获取到对应的状态信息,看来是个偶现问题。 既然命令当前执行都正常,难道是执行nc命令的那个时刻,zk出现了异常导致没有响应?...s.accept() msg=c.recv(1024) print(msg) c.sendall('hncscwc') time.sleep(1000) c.close() 然后再执行命令,可以发现nc未返回...通过增加参数“+vvvvvv”查看nc命令执行过程中的输出,对比正常情况和异常情况,可以清楚的看到这一点: 正常退出的情况: 异常不退出的情况: 清楚了问题的所有环节,只剩下为什么nc命令没有收到...简单man了一把nc,发现有一个"-i"参数,指的是连接的最大读写空闲时间。加上参数,再来进行测试,发现连接虽然处于FIN_WAIT2状态,但等待指定时长后,nc命令返回退出了。

2.7K30
  • 记录工作小问题-数据库返回类型

    记录工作中一个小问题 在我的虚拟机里面, 与前端同学进行接口联调, 完成后发版到测试环境时, 前端同学突然说这个不对劲, 以为啥不对呢, 原来说的是返回值类型不对....不慌不忙, 去测试环境抓包看了下, 接口返回有 int 有 string, 再看我的虚拟机服务返回的全是 string....什么参数会影响数据库查询值 首先我的虚拟机直连的测试库, 排除掉数据库服务端配置问题....视线转移到客户端配置: PDO::ATTR_STRINGIFY_FETCHES 表示提取的时候将数值转换为字符串 这个参数是可以影响到返回值的, 但是配置项经过跟测试环境比对, 底层设置默认都是 false...因此,您不需要安装MySQL即可构建PHP或运行PHP数据库应用程序。 由于MySQL本机驱动程序是作为PHP扩展编写的,因此它与PHP的工作紧密相关。

    74830

    工作中递归返回多层级josn数据

    (相当于定义泛型,T[]是在使用泛型T) 泛型是Java SE 1.5的新特性,泛型的本质是参数化类型,也就是说所操作的数据类型被指定为一个参数。...这种参数类型可以用在类、接口和方法的创建中,分别称为泛型类、泛型接口、泛型方法 2.该方法返回集合中所有元素的数组;返回数组的运行时类型与指定数组的运行时类型相同。...(elementData, 0, result, 0, size); return result; } 从源码中可以看出它仅能返回 Object[]类型的,相当于toArray(new Object...[0]) 注意:数组不能强制转换 不带参数的toArray方法,是构造的一个Object数组,然后进行数据拷贝,此时进行转型就会产生ClassCastException String[] tt =(String...带参数的toArray方法,则是根据参数数组的类型,构造了一个对应类型的,长度跟ArrayList的size一致的空数组,虽然方法本身还是以 Object数组的形式返回结果,不过由于构造数组使用的ComponentType

    71750

    程序返回数据的标准格式

    当你需要写一个函数来验证,处理数据时,返回数据是必须的 通常来讲,写函数是为了重用代码,使这个函数可以通用在很多地方,比如验证表单信息,验证会员身份,验证余额,处理会员数据,查询数据 这个时候,就得返回验证失败或者成功...,验证失败也有验证失败的提示信息,返回数据也有可能有错误信息,也有返回成功的数据,所以我们应该规范一个返回数据的类型格式 简洁来说,一个函数,验证失败应该返回false,并且返回失败信息,验证成功应该返回...true,并且返回数据信息 在很多代码里面,都是返回以下的一种数组格式 $result['status']=true;//false $result['message']='出错信息,验证失败信息';...$result['data']=$data;//返回数据 上面的数组基本是通用格式,并且用处广泛,可以用于接口,自己程序的各种验证函数,数据处理函数,全部通用,希望大家养成一个编码的好习惯.

    1.1K30

    SQL Server 返回最后插入记录的自动编号ID

    IDENT_CURRENT 返回为任何会话和任何作用域中的特定表最后生成的标识值。IDENT_CURRENT 不受作用域和会话的限制,而受限于指定的表。...IDENT_CURRENT 返回为任何会话和作用域中的特定表所生成的值。 @@IDENTITY 返回为当前会话的所有作用域中的任何表最后生成的标识值。...SCOPE_IDENTITY 返回为当前会话和当前作用域中的任何表最后生成的标识值 SCOPE_IDENTITY 和 @@IDENTITY 返回在当前会话中的任何表内所生成的最后一个标识值。...IDENT_CURRENT(‘TableName’) –返回指定表中生成的最后一个标示值 SELECT IDENT_INCR(‘TableName’)–返回指定表的标示字段增量值 SELECT...IDENT_SEED(‘TableName’)–返回指定表的标示字段种子值 返回最后插入记录的自动编号 SELECT IDENT_CURRENT(‘TableName’) 返回下一个自动编号

    2.3K40

    由Dapper QueryMultiple 返回数据的问题

    今天帮群友整理Dapper基础教程的时候手脚快了点,然后遇到了一个小问题,Dapper QueryMultiple 返回数据的问题 多个返回值用QueryMultiple ,这个大家都知道,如果不清楚的看下下面的文档...= @idselect * from Returns where CustomerId = @id";using (var multi = connection.QueryMultiple(sql,...其实就是顺序弄颠倒了,园友可以当个经验==》Dapper QueryMultiple并不会帮我们识别多个返回值的顺序 Read获取的时候必须是按照上面返回表的顺序 (article,qqmodel,seotkd...官方文档是这样写的,那我们能不能玩点其他的?就一定得定义一个类来获取对应的强类型吗?多返回值就不能动态获取吗???NONONO 直接 if (!...multi.IsConsumed) { ////强类型 ////注意一个东西,Read获取的时候必须是按照上面返回表的顺序 (article

    1.7K120

    Go: 命名返回值的使用, return携带还是不携带?

    在Go语言中,命名返回值提供了一种声明函数返回值的方式,它可以增加代码的可读性和灵活性。但是,在使用命名返回值时,return语句是否应该明确携带返回值,是一个常见的困惑。...带命名返回值的return 如果在函数中使用了命名返回值,你可以在return语句中明确指定返回的值,如下所示: func sum(a, b int) (result int) { result =...不带命名返回值的return 或者,你可以省略return语句中的返回值,让Go自动返回命名返回值的当前值: func sum(a, b int) (result int) { result = a...建议做法 对于简单的函数,可以考虑省略return语句中的返回值,使代码更精简。 对于复杂的函数或重要的库,可能更适合明确指定返回值,以增加代码的可读性和可维护性。...总结 命名返回值在Go语言中是一个强大的工具,但如何使用它没有固定的规则。选择是否在return语句中携带返回值取决于多个因素,包括代码的复杂性、团队的编程风格以及可读性和可维护性的需求。

    48830

    WebAPI返回数据类型解惑 以及怎样解决Extjs无法解析返回的xml

    2.怎么修改WebAPI的返回数据类型,我用IE浏览器请 求返回的数据都是JSON格式的,用Firefox和Chrome返回数据格式是XML,然后自己用HttpWebRequest请求返回的是JSON格...IE浏览器返回的数据是json,而使用Firefox和Chrome返回的则为xml,经研究发现IE在发生http请求时请求头accpet节点相比Firefox和Chrome缺少"application/...数据,下面是IE、Firefox和Chrome浏览器的请求头 浏览器 返回数据格式 accept请求头 IE json text/html, application/xhtml+xml, */* Firefox...=0.9,结果返回了xml 由此可以得出结论:   WebAPI的返回数据类型是有请求头的accept来决定的,默认返回类型为json     1.application/json和application.../json和application/json时,返回数据类型和两者的顺序无关,若两者优先级相同则返回json,若优先级不同则返回优先级高的类型 详见下表: Accept头 返回类型 application

    1.9K80

    Mybatis映射文件深入 - 新增数据后返回主键ID - 动态SQL - SQL片段

    Mybatis映射文件深入 - 新增数据后返回主键ID - 动态SQL - SQL片段 前言 在前面的篇章中,我们已经认识了如何使用 resultMap标签 映射查询的结果集字段、多条件查询、模糊查询。...下面我们继续来深入认识一下 MyBatis 的映射文件。 新增数据后,返回主键 ID 应用场景 向数据库保存一个user对象后, 然后在控制台打印此新增user的主键值(id) # 点外卖 1....需要返回这条记录的主键, 然后给第三方配送平台, 送外卖 实现案例一:基于MyBatis 框架自带的主键返回功能 ① UserMapper接口 /* * # 复杂操作:插入一条数据返回对应的主键...下面我们来模拟查询,如下: -- 查询数据的同时,查询返回自增的ID -- 注意:这两行SQL要按照顺序同时执行,否则单独查询 SELECT LAST_INSERT_ID(); 不会返回最新的自增ID...① UserMapper接口 public interface UserMapper { /* * # 复杂操作:插入一条数据返回对应的主键 * sql:

    1.1K30

    函数出错返回的数据类型

    函数出错返回的数据类型有4中情况:错误码、NULL值、空对象、异常对象。 1. 错误码 C语言中没有异常这样的语法机制,返回错误码便是最常用的的出错处理方式。...对于查找函数(get、find、select、search、query 等单词开头的函数),数据不存在是一种正常行为,并非是一种异常情况,所以返回表示不存在语义的NULL值比返回异常更合理。...返回空对象 返回NULL值有各种弊端,对此有一个比较经典的应对策略,就是应用空对象设计模式(Null Object Design Pattern)。...当函数返回的数据是字符串类型或者集合类型的时候,我们可以用空字符串或空集合替代 NULL 值,来表示不存在的情况。这样,我们在使用函数的时候,就可以不用做 NULL 值判断。...对于函数抛出的异常,我们有三种处理方法:直接吞掉、直接往上抛出、包裹成新的异常抛出。 返回 NULL 值还是异常对象,要看获取不到数据是正常行为,还是异常行为。

    2.2K20

    SpringMVC + Mybatis bug调试 SQL正确,查数据库却返回NULL

    今天碰到个bug,有点意思 背景是SpringMVC + Mybatis的一个项目,mapper文件里写了一条sql 大概相当于 select a from tableA where b = "123"...这样的级别 然后不管传进去的是什么 数据库里有没有 都会返回null ---- 第一反应是sql语句写错了,比如把1和小写L弄混了之类的,传给sql的参数里有奇怪的空格等等 于是打开debug log...拿到传给sql的preparedStatement 和对应的参数 复制到console里自己查了一下,可以执行,返回结果也正确,说明不是sql的问题 ---- 既然不是sql的问题,那只好调试一下代码了...既然preparedStatement sql能够被打印出来,所以就不从业务逻辑加断点了,直接定位到PreparedStatement类 找到execute方法,上个断点开始单步 单步的时候发现了奇怪的现象...,ide提示说源代码和class文件对应行不一致,单步调试时代码在不同行之间乱跳,并且对我正在监视的变量报了一个类中不存在该变量的错 所以怀疑是引用冲突了 ---- 接下来确认一下是不是引用了奇怪的类

    1.4K70

    【Rust问答】关于函数不写return时候返回值的疑惑

    | | -- help: consider using a semicolon here | |_____| | expected this to be `()` 看的出来编译器认为这个函数返回的是...unit (),而if里面的0却是integer,所以报错了 我知道下面2种做法可以编译通过: 把1放进else里面 在0前面显式的加上return 现在问题来了: 这个编译不通过的函数,我标注了返回类型为...i32,而且函数体内怎么看返回的也不是()啊,为什么编译器会认为返回的是()类型呢?...if n > 0 { 0 } 和 1 因为没有else,所以它不认为if 代码块是表达式的一部份 所以做为函数返回值的是 1 这个表达式 第一个语句中的代码块的最后一行是表达式,但其它本身又不是条件赋值语句...,所以编译器认为代码块应该返回的是(),也就是unit类型 c5soft 2019-12-18 21:26 if 作为rust的表达式,要求 if 和 else 两部分类型相同,如果缺少 else 部分

    2.8K20
    领券