问题: 使用游标遍历时,发现使用 select var into tmp where var=? 然后判断if tmp is null时,不能走完所有的遍历.经debug发现, 当var为空时,则跳出游标的遍历. 解决方式: 使用if not exists(select var into tmp where var=?)时,则ok. 这个可以从mysql官方文档中找到原因: 1. select var into tmp where var=? 中where 条件不支持为空,如下面红色部分所示.
前言 上一节我们分析了INNER JOIN和IN,对于不同场景其性能是不一样的,本节我们接着分析NOT EXISTS和NOT IN,简短的内容,深入的理解,Always to review the basics. 初步探讨NOT EXISTS和NOT IN NOT EXISTS和NOT IN有很大的不同,尤其是对NULL的处理,为何这样说,当子查询中有NULL时,此时NOT IN不会返回任何行,下面我们来看下简单的示例. USE TSQL2012 GO WITH table1 AS ( SELE
一直对exists的用法不清楚,本次学习exists,并作出相应学习总结. 1.创造测试环境SYS@ora122>create table a(id )); SYS@ora122>insert into a values(,'a'); SYS@ora122>insert into a values(,'b'); SYS@ora122>insert into a values(,'c'); SYS@ora122>insert into a values(,'a'); SYS@o