当我查询的时候明明两张表都有数据,但是用了not in 之后就出问题了!! 这是为什么呢? 原因很简单:由于NULL不能进行如下的“操作” –如果null参与算术运算,则该算术表达式的值为null。...--如果在not in子查询中有null值的时候,则不会返回数据。 我们中了最后一条!!! 子查询的字段中如果有null 值则不会反悔任何数据!! ? 学到了 下次注意了!!哈哈!
如果下:Table_A表和Table_B表,要求查询出在Table_A表中不在Table_B表中的记录。 CREATE TABLE [dbo]....NULL ) ON [PRIMARY] GO ID Name NULL 张三 002 李四 NULL 王五 很容大家第一时间相当的写法是...dbo.Table_A AS a WHERE a.ID NOT IN ( SELECT b.ID FROM dbo.Table_B AS b) 然而查询出来并没有达到预期的...ID Name 001 张三 003 王五 原因很简单:由于NULL不能进行如何的“操作” –如果null参与算术运算,则该算术表达式的值为null。...--如果在not in子查询中有null值的时候,则不会返回数据。
目标:查询得到每组的max(或者min等其他聚合函数)值,并且得到这个行的其他字段 反模式:引用非分组列 单值规则:跟在Select之后的选择列表中的每一列,对于每个分组来说都必须返回且仅返回一直值...如何识别反模式:当输入一个违背了单值规则的查询时,会立刻返回给你一个错误。数据库会返回不同的错误信息。 在SQLite和MySQL中,有歧义的列可能包含不可预测的和不可靠的数据。...2、使用关联子查询:关联子查询会引用外连接查询,并且根据外联结果查询中的每一条记录最终返回不同的结果。...6、链接同组所有值:MySQL与SQLite提供了一个叫做Group_Contract()函数,能将这一组中的所有的值连在一起作为单一值返回, 多个值之间用逗号分隔。...结论:遵循单值规则,避免获得模棱两可的查询结果。 SQL反模式,系列学习汇总
当 WHERE 条件中的子查询返回多行数据时,不能再使用普通的比较运算符,因为它们不支持单个值和多个值的比较;如果想要判断某个字段是否在子查询返回的数据列表中,可以将子查询与 IN、ALL、ANY/SOME...,也就是当表达式在列子查询结果中时为 TRUE。...ALL 必须跟在比较运算符之后,如果表达式与子查询返回列中的所有值的比较结果为 TRUE,则返回 TRUE。...ANY 关键字必须跟在比较运算符之后,如果表达式与子查询返回列中的任何值的比较结果为 TRUE,则返回 TRUE。...3.4 表子查询 当子查询返回的结果包含多行多列数据时,称为表子查询。表子查询通常用于 FROM 子句或者查询条件中。
当 WHERE 条件中的子查询返回多行数据时,不能再使用普通的比较运算符,因为它们不支持单个值和多个值的比较;如果想要判断某个字段是否在子查询返回的数据列表中,可以将子查询与 IN、ALL、ANY/SOME...,也就是当表达式在列子查询结果中时为 TRUE。...ALL 必须跟在比较运算符之后,如果表达式与子查询返回列中的所有值的比较结果为 TRUE,则返回 TRUE。...ANY 关键字必须跟在比较运算符之后,如果表达式与子查询返回列中的任何值的比较结果为 TRUE,则返回 TRUE。...3.4 表子查询 当子查询返回的结果包含多行多列数据时,称为表子查询。 表子查询通常用于 FROM 子句或者查询条件中。
"+"号表示该注释是一个提示,该加号必须立即跟在"/*"的后面,中间不能有空格。 hint是下面介绍的具体提示之一,如果包含多个提示,则每个提示之间需要用一个或多个空格隔开。...也就是引导优化器合并子查询和主查询并且将其向连接类型转换。 NO_UNNEST 引导优化器让子查询能够独立地执行完毕之后再跟外围的查询做FILTER。...PUSH_SUBQ 使用该提示引导优化器为不能合并的子查询制定执行计划。不能合并的子查询被优先执行之后,该子查询的执行结果将扮演缩减主查询数据查询范围的提供者角色。...但是当优化器没能做出正确判断时,或者像从嵌套视图中所获得的结果集合那样不具备统计信息时,可以使用该提示。 6、和并行相关的 PARALLEL 指定SQL执行的并行度,这个值将会覆盖表自身设定的并行度。...AND_EQUAL 这个提示会使优化器合并表上的多个索引,而不是选择其中最好的索引(这是INDEX提示的用途)。
当我们遇到一个慢查询语句时,首先要做的是检查所编写的 SQL 语句是否合理,优化 SQL 语句从而提升查询效率。所以对 SQL 有一个整体的认识是有必要的。...这时候就要去优化掉子查询的使用。 如果子查询跟在 FROM 后面,即子查询为派生表,能够使用 Materialization 或是 Merging 优化方案优化。...当然也不需要将子查询视为洪水猛兽,子查询比起联表查询具有更好的可读性,在修改维护 SQL 时更加友好,而且在特定场景下可以作为一个优化的手段使用。...LIMIT 的使用方式为 LIMIT offset num ,每次从 offset + 1 条记录开始获取 num 条记录。而当 offset 非常大时,就有可能影响到查询性能。...如下: SELECT * FROM t1 WHERE id > ${cursor} ORDER BY id LIMIT 1000; 之后获取最大的 id 值,更新游标 cursor ,再次进行查询即可
可以在任何可以使用表达式的地方使用子查询。许多子查询返回单个列值,因为它们与比较运算符(=,!=,,> =)或表达式结合使用。当子查询不用作表达式或使用比较运算符时,它可以返回多个值。...接下来的几个例子将使用返回多个值和/或多个列的子查询。 FROM子句中的子查询示例 在FROM子句中,通常会标识您的Transact-SQL语句将对其执行的表或表的集合。...使用具有IN关键字的子查询的示例 您可以编写一个返回列的多个值的子查询的地方是当您的子查询生成与IN关键字一起使用的记录集时。 清单9中的代码演示了如何使用子查询将值传递给IN关键字。...当子查询用于FROM子句时 当IN子句中使用子查询时 当表达式中使用子查询时 当子查询与比较运算符一起使用时 问题3: 在WHERE子句中使用一个子查询的Transact-SQL语句总是比不包含子查询(...当用作表达式或在比较操作中时,子查询需要返回一个列值。当子查询与IN关键字一起使用时,它可以返回列的单个或多个值。如果在FROM子句中使用子查询,它只能返回一列和一个值,但也可以返回多个列和值。
子查询 在嵌套查询中,最外面查询结果集返回给调用方,称为外部查询。嵌套在外部查询内的查询称为子查询,子查询的结果集供外部查询使用。 根据是否依赖外部查询,可将子查询分为自包含子查询和相关子查询。...自包含子查询不依赖外部查询,相关子查询则依赖外部查询。 子查询结果是在运行时计算的,查询结果会跟随查询表的变化而改变。子查询可以返回单个值(标量)、多个值或者整个表结果。...dbo.Customers AS C ORDER BY C.custid ); 上述查询语句看起来可以正常运行,但当子查询的返回结果集中包含NULL值时,上述查询语句则不会返回任何数据。...:warning: 我们应时刻牢记SQL是三值逻辑,这点很容易引发错误 列名处理不当 子查询中的列名首先从当前查询中进行解析,若未找到则到外部查询中查找。...有时候会看到即使外部查询未使用ORDER BY但查询结果集按预期顺序返回了结果,这是由于数据库自身优化的结果,依然无法保证每次查询都能按预期结果返回。
一.WITH AS的含义 WITH AS短语,也叫做子查询部分(subquery factoring),可以定义一个SQL片断,该SQL片断会被整个SQL语句用到。...from person.CountryRegion where Name like 'C%' ) 上面的查询语句使用了一个子查询。...语句要比第一种方式更复杂,但却将子查询放在了表变量@t中,这样做将使SQL语句更容易维护,但又会带来另一个问题,就是性能的损失。...在使用CTE时应注意如下几点: 1. CTE后面必须直接跟使用CTE的SQL语句(如select、insert、update等),否则,CTE将失效。...如果CTE的表达式名称与某个数据表或视图重名,则紧跟在该CTE后面的SQL语句使用的仍然是CTE,当然,后面的SQL语句使用的就是数据表或视图了,如下面的SQL语句所示: -- table1是一个实际存在的表
自包含子查询不依赖外部查询,相关子查询则依赖外部查询。 子查询结果是在运行时计算的,查询结果会跟随查询表的变化而改变。子查询可以返回单个值(标量)、多个值或者整个表结果。...IN( SELECT TOP 10 C.custid FROM dbo.Customers AS C ORDER BY C.custid ); 上述查询语句看起来可以正常运行,但当子查询的返回结果集中包含...NULL值时,上述查询语句则不会返回任何数据。...⚠️ 我们应时刻牢记SQL是三值逻辑,这点很容易引发错误 列名处理不当 子查询中的列名首先从当前查询中进行解析,若未找到则到外部查询中查找。...有时候会看到即使外部查询未使用ORDER BY但查询结果集按预期顺序返回了结果,这是由于数据库自身优化的结果,依然无法保证每次查询都能按预期结果返回。
——INSERT 数据的更改——UPDATE 数据的删除——DELETE 数据的查询——SELECT 查询是SQL语言的中心内容,而用于表示SQL查询的SELECT语句,是SQL语句中功能最强大也是最复杂的语句...2)子查询与嵌套查询: 子查询是一个嵌套在 SELECT、INSERT、UPDATE 或 DELETE 语句或其他子查询中的查询。任何允许使用表达式的地方都可以使用子查询。 ...4)使用CASE函数进行查询: 联接可分为以下几类:内部联接、外部联接、交叉联接。 CASE函数用于计算条件列表并返回多个可能结果表达式之一。 ...批处理必须以 CREATE 语句开头,所有跟在该批处理后的其他语句将被解释为第一个 CREATE 语句定义的一部分。 不能在删除一个对象之后,在同一批处理中再次引用这个对象。 ...不能在定义一个CHECK约束之后,在同一个批处理中使用。 不能在修改表的一个字段之后,立即在同一个批处理中引用这个字段。 使用SET语句设置的某些选项值不能应用于同一个批处理中的查询。
【磁盘IO操作3次】 B+ 相对B树的不同特性: 非叶子节点的值会以最大或最小值出现在其子节点中,即叶子节点包含所有元素。...单行查询时与B树相同 范围查询时,比如查找大于3小于8的数据,根据单行查找方式查找到3之后,通过链表直接遍历后面的元素。 B+树优势: B+树的磁盘读写代价更低/效率更高。...前缀索引查询(注意选择性把握) 选择性指不重复的索引值和数据表的记录总数的比值。选择性最高时,即所有键不重复时选择性为1。...(高性能提到5.0之后的版本会各自使用pdl和timestamp字段,然后SQL服务器对多个索引结果做相交(AND)或联合操作(OR)操作,通过extra可查询,但是我的5.7没有这种优化,不知道为什么...这个字段表示存储引擎返回的数据在server层过滤后,剩下多少满足查询的记录数量的比例,图为百分之10。此值过低也不行。
,当索引列有大量数据重复时,SQL查询可能不会去利用索引,如一表中有字段 sex,male、female几乎各一半,那么即使在sex上建了索引也对查询效率起不了作用。...不允许字段为空,而用一个缺省值代替空值,如申请中状态字段不允许为空,缺省为申请。...其实我们区分in和exists主要是造成了驱动顺序的改变(这是性能变化的关键),如果是exists,那么以外层表为驱动表,先被访问,如果是in,那么先执行子查询,所以我们会以驱动表的快速返回为目标,那么就会考虑到索引及结果集的关系了...但是当服务器响应客户端请求时,客户端必须完整的接收整个返回结果,而不能简单的只取前面几条结果,然后让服务器停止发送。...join 代替 子查询 MySQL从4.1版开始支持子查询(一个查询的结果作为另一个select子句的条件),子查询虽然灵活但执行效率不高,因为使用子查询时,MySQL需要为内层查询语句的查询结果建立一个临时表
可选—ALL关键字指定返回满足SELECT条件的所有行。 这是SQL的默认值。 ALL关键字不执行任何操作; 它是为了SQL兼容性而提供的。...table-ref可以指定为一个或多个表、视图、表值函数或子查询,以逗号分隔的列表或使用JOIN语法指定。 在使用带有JOIN语法的视图时存在一些限制。 子查询必须用括号括起来。...在更复杂的查询中,SELECT可以检索列、聚合和非列数据,可以使用连接从多个表检索数据,也可以使用视图检索数据。 SELECT还可以用于从SQL函数、宿主变量或字面量返回值。...SELECT查询可以将返回这些非数据库值与从表或视图检索值结合起来。 当SELECT仅用于返回此类非数据库值时,FROM子句是可选的。 从SELECT查询返回的值称为结果集。...但是,对于声明游标并从多行获取数据的嵌入式SQL SELECT,当游标被推进到数据末尾时(SQLCODE=100),操作就完成了; 此时,%ROWCOUNT被设置为选中的行总数。
那说明这个库中的查询时比较多的,所以我们需要额外关注查询的效率。 关于具体的查询效率,我们可以通过查询数据库的慢 SQL 日志来查询。...通过 Explain 查询执行计划 结果输出展示: ID 该语句的唯一标识。如果 explain 的结果包括多个 id 值,则数字越大越先执行;而对于相同 id 的行,则表示从上往下依次执行。...这种类型常见于解析子查询 index_merge:此类型表示使用了索引合并优化,表示一个查询里面用到了多个索引 unique_subquery:该类型和 eq_ref 类似,但是使用了 IN 查询,且子查询是主键或者唯一索引...index:全索引扫描,和 ALL 类似,只不过 index 是全盘扫描了索引的数据。当查询仅使用索引中的一部分列时,可使用此类型。...key_len 索引使用的字节数。由于存储格式,当字段允许为 NULL 时,key_len 比不允许为空时大 1 字节。 ref 表示将哪个字段或常量和 key 列所使用的字段进行比较。
NULL 与不匹配 在通过过滤选择出不具有特定值的行时,你可能希望返回具有 NULL 值的行。但是,不行。因为未知具有特殊的含义,数据库不知道它们是否匹配,所以在匹配过滤或不匹配过滤时不返回它们。...子查询 版本要求 MySQL 4.1 引入了对子查询的支持,所以要想使用本章描述的 SQL,必须使用MySQL 4.1 或更高级的版本。...通常,子查询将返回单个列并且与单个列匹配,但如果需要也可以使用多个列。 虽然子查询一般与IN操作符结合使用,但也可以用于测试等于(=)、不等于()等。...企图检索多个列将返回错误。 tip: 逐渐增加子查询来建立查询 用子查询测试和调试查询很有技巧性,特别是在这些语句的复杂性不断增加的情况下更是如此。..., where 改成 on select xxx列 from 表A inner join 表b on 条件1=xxx 自然版 sql 的一对一, 多对多关系 子查询 有多个 select 关键字 可以出现的位置
使用 通配符* 可以表示返回所有列,但是为了检索效率考虑,尽量不要使用 * 去重 DISTINCT 需要检索不同的行数据时需要使用到 DISTINCT 关键字,使得执行 SQL 查询时只返回不同的值。...,NOT 否定跟在它之后的条件。...,返回一列的最小值/最大值 SUM 函数,返回一列的最大值 聚集不同值 ALL 返回所有行数,默认行为 DISTINCT 只返回包含不同的值 组合聚集函数 在一个查询语句允许采用多个函数。...第十五章 联结表 联结就是在正对多个表,进行SQL查询时的组合。能更有效地查询多表数据。...: 在单个查询中从不同的表返回一样结构的数据 在单个表执行多个查询,按照单个查询返回数据 如何使用组合查询 用 UNION 操作符组件多个 SQL 查询语句。
FROM dbo.UserInfo WHERE Name = '雪飞鸿' ); 注意,上述SET语句中的子查询必须只能返回标量,否则会报错,示例如下: USE WJChi; SET @age = (...SELECT Age FROM dbo.UserInfo ); 执行报错: 子查询返回的值不止一个。...当子查询跟随在 =、!=、、>= 之后,或子查询用作表达式时,这种情况是不允许的。...SQL Server中函数返回值分为:标量与表值两种。...Server内置常用函数 存储过程 存储过程与函数有相似之处,如都体现了封装的思想,但存储过程可以执行更为复杂的逻辑,可以有多个返回值。
查询 - 基于特定条件检索数据。这是 SQL 的一个重要组成部分。 语句 - 可以持久地影响纲要和数据,也可以控制数据库事务、程序流程、连接、会话或诊断。...mytable LIMIT 2, 3; 三、子查询 子查询是嵌套在较大查询中的 SQL 查询。...只能包含一个 ORDER BY 子句,并且必须位于语句的最后。 应用场景 在一个查询中从不同的表返回结构数据。 对一个表执行多个查询,按一个查询返回数据。...,当触发器所在表上出现指定事件时,将调用该对象,即表的操作事件触发表上的触发器的执行。...MySQL 不允许在触发器中使用 CALL 语句 ,也就是不能调用存储过程。 BEGIN 和 END 当触发器的触发条件满足时,将会执行 BEGIN 和 END 之间的触发器执行动作。 ?
领取专属 10元无门槛券
手把手带您无忧上云