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

读书笔记-《基于Oracle的SQL优化》-第一章-3

访问索引的方法: (1)、索引唯一性扫描:INDEX UNIQUE SCAN,仅适用于where条件中是等值查询的目标SQL。...(2)、索引范围扫描:INDEX RANGE SCAN,当扫描的对象是唯一性索引时,目标SQL的where条件一定是范围查询(谓词条件为BETWEEN、等);当扫描的对象是非唯一性索引时,对目标SQL...在同等条件下,当目标索引的索引行的数量大于1时,索引范围扫描所耗费的逻辑读至少会比相应的索引唯一性扫描多1。 (3)、索引全扫描:指要扫描目标索引所有叶子块的所有索引行。...索引跳跃式扫描:INDEX SKIP SCAN,它使那些在where条件中没有对目标索引的前导列指定查询条件但同时又对该索引的非前导列指定了查询条件的目标SQL依然可以用上该索引,这就像在扫描该索引时跳过了它的前导列...Oracle中的索引跳跃式扫描仅适用于那些目标索引前导列的distinct值数量较少,后续非前导列的可选择性又非常好的情形,因为索引跳跃式扫描的执行效率一定会随着目标索引前导列的distinct值数量的递增而递减

78620
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    实战讲解MySQL执行计划,面试官当场要了我

    当查询仅使用属于单个索引一部分的列时,MySQL可以使用此连接类型。 explain select title from film; 1.4.3 range 使用索引查询行,仅检索给定范围内的行。...1.4.9 ref 对于先前表中的每个行组合,将从该表中读取具有匹配索引值的所有行。...如果连接仅使用键的最左前缀,或者如果该键不是PRIMARY KEY(主键)或UNIQUE(唯一)索引(即如果连接无法根据键值选择单行),则会使用ref。...当连接使用索引的所有部分并且索引是PRIMARY KEY或UNIQUE NOT NULL索引时,将使用它。...因为只有一行,所以优化器的其余部分可以将这一行中列的值视为常量。 const表非常快,因为它们仅读取一次。 当将PRIMARY KEY或UNIQUE索引的所有部分与常量值进行比较时,将使用const。

    1.3K10

    编写高效SQL的三个基础原则

    前三种范式是: 第一范式 (1NF): 每一行和每一列都存储单个值,并且没有重复的行。第二范式 (2NF): 没有依赖于主键或唯一键一部分的列。...要解决此问题,请将相关列拆分为新表或将其完全删除。 例如,假设您正在构建一个答题应用程序。当玩家提交答案时,您希望记录他们开始、完成和完成测验所用的时间,以及他们的答案。...如果您更改表的主键或其唯一约束之一中的所有列,则会出现这种情况。在这种情况下,您正在更改行的标识符,因此其他值也可能会发生更改。 与糟糕的名称一样,未规范化的表在现有应用程序中难以更改。...外键指向子表中的列到父表中的主键或唯一约束。有了这个,您就不能拥有孤立的行。非空约束: 确保您只能在列中存储非空值,即它们是强制性的。检查约束: 验证对于每一行,条件为真或未知。...选择好的名称、规范化您的表格和创建约束,可以让您在编写SQL时拥有坚实的基础。有了这些基础,您可以将注意力转向有效地构建您的SQL。

    6700

    MySQL中SQL执行计划详解

    当数据规模比较大的时候,sql执行的时候,执行计划不同,会直接影响sql的执行速度。这个时候,就需要对sql语句执行进行调试。...当两个表联查时使用索引的所有部分(针对的是组合索引),且索引是 主键或唯一索引时使用它。使用“=”运算符来进行索引列的比较。   4.ref 非唯一索引扫描,返回某个匹配值的所有行。常用语非唯一索引。...Full scan on NULL key当优化程序无法使用索引查找访问方法时,子查询优化将作为回退策略发生。 Impossible HAVING该HAVING子句始终为false,无法选择任何行。...Range checked for each record MySQL发现没有好的索引可以使用,但发现在前面的表的列值可能会使用某些索引。...然后对键进行排序,并按排序顺序检索行 Using index 仅使用索引树中的信息从表中检索列信息,而不必另外寻找读取实际行。当查询仅使用属于单个索引的列时,可以使用此策略。

    3.2K20

    编写高效SQL的三个基础原则

    前三种范式是: 第一范式 (1NF): 每一行和每一列都存储单个值,并且没有重复的行。第二范式 (2NF): 没有依赖于主键或唯一键一部分的列。...要解决此问题,请将相关列拆分为新表或将其完全删除。 例如,假设您正在构建一个答题应用程序。当玩家提交答案时,您希望记录他们开始、完成和完成测验所用的时间,以及他们的答案。...如果您更改表的主键或其唯一约束之一中的所有列,则会出现这种情况。在这种情况下,您正在更改行的标识符,因此其他值也可能会发生更改。 与糟糕的名称一样,未规范化的表在现有应用程序中难以更改。...外键指向子表中的列到父表中的主键或唯一约束。有了这个,您就不能拥有孤立的行。非空约束: 确保您只能在列中存储非空值,即它们是强制性的。检查约束: 验证对于每一行,条件为真或未知。...选择好的名称、规范化您的表格和创建约束,可以让您在编写SQL时拥有坚实的基础。有了这些基础,您可以将注意力转向有效地构建您的SQL。

    8510

    SqlServer 索引

    索引类型 •          唯一索引:唯一索引不允许两行具有相同的索引值 •          主键索引:为表定义一个主键将自动创建主键索引,主键索引是唯一索引的特殊类型。...唯一索引: 唯一索引不允许两行具有相同的索引值。 如果现有数据中存在重复的键值,则大多数数据库都不允许将新创建的唯一索引与表一起保存。当新数据将使表中的键值重复时,数据库也拒绝接受此数据。...例如,如果在stuInfo表中的学员员身份证号(stuID) 列上创建了唯一索引,则所有学员的身份证号不能重复。 提示:创建了唯一约束,将自动创建唯一索引。...主键索引要求主键中的每个值是唯一的。当在查询中使用主键索引时,它还允许快速访问数据。 聚集索引(clustered index) 在聚集索引中,表中各行的物理顺序与键值的逻辑(索引)顺序相同。...–         该列用于频繁搜索 –         该列用于对数据进行排序 •          请不要使用下面的列创建索引: –         列中仅包含几个不同的值。

    3.2K90

    【21】进大厂必须掌握的面试题-65个SQL面试

    主键 是一列(或列的集合)或一组列的唯一标识表中的每一行。 唯一标识表中的一行 不允许为空值 示例-在学生表中,Stu_ID是主键。 Q8。 什么是约束?...它用于从满足联接条件的多个表中返回所有行。 左连接: MySQL中的左连接用于返回左表中的所有行,但仅返回右表中满足连接条件的匹配行。...右连接: MySQL中的右连接用于返回右表中的所有行,但仅返回满足连接条件的左表中的匹配行。 完全联接: 当任何表中都存在匹配项时,完全联接将返回所有记录。...第一范式(1NF) –行内没有重复的组 第二范式(2NF) –每个非键(支持)列的值都取决于整个主键。 第三范式(3NF) –仅取决于主键,而没有其他非键(支持)列值。 Q23。...插入数据时如何在列中插入NULL值? 可以通过以下方式插入NULL值: 隐式地通过从列列表中省略列。 通过在VALUES子句中指定NULL关键字来显式 Q36。”

    6.9K22

    SQL命令 DISTINCT

    DISTINCT BY (item {,item2}) - 可选-返回按(项)值唯一的行的选择项值。 ALL - 可选-返回结果集中的所有行。默认设置。...它将每个不同(唯一)值返回的行数限制为一个任意行。如果未指定DISTINCT子句,则默认情况下显示满足选择条件的所有行。...如果DISTINCT子句中指定的列包含NULL(不包含值)行,则DISTINCT将返回一行作为DISTINCT(唯一)值的NULL,如以下示例所示: SELECT DISTINCT FavoriteColors...星号语法:DISTINCT*语法是合法的,但没有意义,因为根据定义,所有行都包含一些不同的唯一标识符。不同于(*)的语法不合法。...如果SELECT不包含FROM子句,则DISTINCT是合法的,但没有意义。 聚合函数:可以在聚合函数中使用DISTINCT子句,以仅选择要包含在聚合中的不同(唯一)字段值。

    4.4K10

    python数据科学系列:pandas入门详细教程

    或字典(用于重命名行标签和列标签) reindex,接收一个新的序列与已有标签列匹配,当原标签列中不存在相应信息时,填充NAN或者可选的填充值 set_index/reset_index,互为逆操作,...切片形式访问时按行进行查询,又区分数字切片和标签切片两种情况:当输入数字索引切片时,类似于普通列表切片;当输入标签切片时,执行范围查询(即无需切片首末值存在于标签列中),包含两端标签结果,无匹配行时返回为空...例如,当标签列类型(可通过df.index.dtype查看)为时间类型时,若使用无法隐式转换为时间的字符串作为索引切片,则引发报错 ? 切片形式返回行查询,且为范围查询 ?...,要求每个df内部列名是唯一的,但两个df间可以重复,毕竟有相同列才有拼接的实际意义) merge,完全类似于SQL中的join语法,仅支持横向拼接,通过设置连接字段,实现对同一记录的不同列信息连接,支持...unique、nunique,也是仅适用于series对象,统计唯一值信息,前者返回唯一值结果列表,后者返回唯一值个数(number of unique) ?

    15K20

    实战讲解MySQL的expain执行计划,面试官当场要了我

    当查询仅使用属于单个索引一部分的列时,MySQL可以使用此连接类型。 explain select title from film; 1.4.3 range 使用索引查询行,仅检索给定范围内的行。...1.4.9 ref 对于先前表中的每个行组合,将从该表中读取具有匹配索引值的所有行。...如果连接仅使用键的最左前缀,或者如果该键不是PRIMARY KEY(主键)或UNIQUE(唯一)索引(即如果连接无法根据键值选择单行),则会使用ref。...当连接使用索引的所有部分并且索引是PRIMARY KEY或UNIQUE NOT NULL索引时,将使用它。...因为只有一行,所以优化器的其余部分可以将这一行中列的值视为常量。 const表非常快,因为它们仅读取一次。 当将PRIMARY KEY或UNIQUE索引的所有部分与常量值进行比较时,将使用const。

    79150

    关于Oracle 数据块、B树索引和5种索引扫描

    仅适用于where条件是等值查询的SQL,因为扫描对像是唯一索引,所有扫描结果最多只返回一行记录 2、INDEX RANGE SCAN【索引范围扫描】 如果查询条件相同的情况下...对于单一列建立的索引(单一索引),当该索引列无非空约束时,在具体检索中只检索该列全部数据,且是对该列的统计(count)或者非空条件查询(is not null),会使用“索引全扫描”。...对于单一列建立的索引(单一索引),当该索引列无非空约束时,在具体检索中只检索该列全部数据,且是对该列的常规查询,不会使用“索引全扫描”。...(这是因为对于oracle索引,对于列中存在的null值不记录在b-tree索引中) 对于多个列建立的索引(组合索引),当该索引列有非空约束时,在具体检索中只检索组合索引中涉及的全部列或者部分列的全部数据...对于多个列建立的索引(组合索引),当该索引列无非空约束时,在具体检索中只检索组合索引中涉及的全部列或者部分列的全部数据,且是对该列的常规查询,不会使用“索引全扫描”。

    96530

    SQL命令 UPDATE(一)

    SQL命令 UPDATE(一) 为指定表中的指定列设置新值。...多个数据值指定为逗号分隔的列表,其中每个数据值依次对应于一个列。 :array() - 仅嵌入式SQL—指定为主机变量的值数组。 数组的最低下标级别必须是未指定的。...UPDATE命令为包含这些列的一个或多个现有基表行提供一个或多个新列值。 将数据值赋给列是使用值赋值语句完成的。 默认情况下,值赋值语句更新表中的所有行。...要列出为指定表定义的所有字段名。 如果字段存在,但没有字段值满足UPDATE命令的WHERE子句,则不影响任何行,并发出SQLCODE 100(数据末尾)。...例如: (StatusDate,Status) VALUES ('05/12/06','Purged') 当将标量表达式值赋给列列表时,每个指定的列必须有一个标量表达式。

    2.9K20

    DBA-MySql面试问题及答案-上

    InnoDB 存储引擎和数据列 建议使用 VARCHAR类型 对于InnoDB数据表,内部的行存储格式没有区分固定长度和可变长度列(所有数据行 都使用指向数据列值的头指针) ,因此在本质上,使用固定长度的...使用不等于查询 NULL值 列参与了数学运算或者函数 在字符串like时左边是通配符.比如 %xxx 当mysql分析全表扫描比使用索引快的时候不使用索引....如果是Innodb引擎表,type列在这个情况通常都是all或者index 2、const 最多只有一行记录匹配。当联合主键或唯一索引的所有字段跟常量值比较时,join类型为const。...当主键或唯一非NULL索引的所有字段都被用作join联接时会使用此类型。 eq_ref可用于使用’='操作符作比较的索引列。比较的值可以是常量,也可以是使用在此表之前读取的表的列的表达式。...Select tables optimized away:这个值意味着仅通过使用索引,优化器可能仅从聚合函数结果中返回一行。

    32020

    这是我见过最有用的Mysql面试题,面试了无数公司总结的(内附答案)

    定义主键时,可以自动应用唯一索引。它确保索引键列中的值是唯一的。 2.聚集索引:聚集索引对表的物理顺序进行重新排序,并根据键值进行搜索。每个表只有一个聚集索引。...SQL SELECT DISTINCT查询仅用于返回唯一值。它消除了所有重复的值。 31.Rename和Alias有什么区别?...内部联接:当正在比较的两个(或多个)表之间至少有一些匹配数据时,内部联接将返回行。 外部联接:外部联接从两个表返回行,这些行包括与一个或两个表不匹配的记录。 36.什么是SQL约束?...38.什么是唯一约束? 使用唯一约束来确保字段/列中没有重复值。 39.什么是主键? 一个PRIMARY KEY 约束唯一标识数据库表中的记录。 参与主键约束的所有列均不得包含NULL值。...联合:省略重复的记录,仅返回两个或多个select语句的不同结果集。 全部合并: 返回不同选择语句结果集中的所有行,包括重复项。

    27.1K20

    MySQL性能优化(七):MySQL执行计划,真的很重要,来一起学习吧

    2)index 全索引扫描,和全表扫描ALL类似,扫描表时按索引次序进行,而不是按行扫描,即:只遍历索引树。 index与ALL虽然都是读全表,但index是从索引中读取,而ALL是从硬盘读取。...4)ref 非唯一性索引扫描,返回匹配某个单独值的所有行。本质是也是一种索引访问,它返回所有匹配某个单独值的行,然而它可能会找到多个符合条件的行,所以它属于查找和扫描的混合体。...此类型只有当使用非唯一索引或者唯一索引的非唯一性前缀时,才会发生。...5)eq_ref 唯一索引扫描。常见于主键或唯一索引扫描。 6)const 通过索引一次就能找到,const用于比较primary key 或者unique索引。因为只需匹配一行数据,所有很快。...2)Using where 许多where条件里是涉及索引中的列,当它读取索引时,就能被存储引擎检验,因此不是所有带·where子句的查询都会显示“Using where”。

    5.4K71

    SQL命令 SELECT(一)

    它可能作为选择项列出,也可能不作为选择项列出。 可选—ALL关键字指定返回满足SELECT条件的所有行。 这是SQL的默认值。 ALL关键字不执行任何操作; 它是为了SQL兼容性而提供的。...INTO host-variable-list - 可选-(仅嵌入式SQL):一个或多个主机变量,将选择项值放入其中。 多个主机变量被指定为逗号分隔的列表或单个主机变量数组。...SELECT查询可以将返回这些非数据库值与从表或视图检索值结合起来。 当SELECT仅用于返回此类非数据库值时,FROM子句是可选的。 从SELECT查询返回的值称为结果集。...但是,对于声明游标并从多行获取数据的嵌入式SQL SELECT,当游标被推进到数据末尾时(SQLCODE=100),操作就完成了; 此时,%ROWCOUNT被设置为选中的行总数。...当使用SELECT *时,请注意列级权限覆盖GRANT语句中命名的所有表列; 表级权限涵盖所有表列,包括分配权限后添加的列。 没有必要的特权将导致SQLCODE -99错误(特权违反)。

    5.3K10

    SQL优化篇:如何成为一位写优质SQL语句的绝顶高手!

    当使用*时,查询时每条数据会返回所有字段值,然后这些查询出的数据会先被放到结果集中,最终查询完成后会统一返回给客户端,但线上Java程序和MySQL都是分机器部署的,所以返回数据时需要经过网络传输,而由于返回的是所有字段数据...还有一种情况是基于主键/唯一索引字段查询数据时,由于这些字段值本身具备唯一性,因此MySQL在执行时,当匹配到第一个值时就会自动停止扫描,因此上述这个方案只适用于普通索引字段、或表中的普通字段。...如果表中有相关列的索引,MySQL可以快速确定在数据文件中间找到的位置,而不需要查看所有的数据。这比按顺序读取每一行要快得多。 大多数MySQL索引(主键、唯一、索引和全文)都存储在b-tree中。...3.7.2字符和字符串类型 当比较不同列的值时,尽可能用相同的字符集和排序来声明这些列,以避免运行查询时的字符串转换。 对于小于8KB的列值,使用二进制varchar而不是blob。...当MySQL从行中检索任何值时,它读取一个包含该行所有列(可能还有其他相邻行)的数据块。保持每一行的大小并只包含最常用的列,使每个数据块可以容纳更多的行。

    1.4K50

    SQL命令 CREATE VIEW(一)

    要从正在创建的视图的SELECT子句中引用的对象中进行选择,需要具有适当的权限: 使用动态SQL或xDBC创建视图时,必须对从视图引用的基础表(或视图)中选择的所有列具有SELECT权限。...默认值是1(启用)。 当SQL Security被启用时,用户只能对已被授予权限的表或视图执行操作。 这是该选项的推荐设置。...类名仅包含字母数字字符(字母和数字),并且在前96个字符内必须是唯一的。...如果省略了列逗号,下面的应用程序: 选择源表的列名用于在使用视图时访问和显示数据。 如果任何选择源表列名具有列别名,则列别名是使用视图时用于访问和显示数据的名称。...与表行ID编号一样,这些视图行ID编号是系统分配的、唯一的、非零的、非空的和不可修改的。此%VID通常是不可见的。与表行ID不同,它在使用星号语法时不会显示;只有在SELECT中显式指定时才会显示。

    6.4K21

    视图索引

    创建索引视图 视图也称为虚拟表,这是因为由视图返回的结果集其一般格式与由列和行组成的表相似,并且,在 SQL 语句中引用视图的方式也与引用表的方式相同。...视图的聚集索引必须唯一,从而提高了 SQL Server 在索引中查找受任何数据更改影响的行的效率。 与基表上的索引相比,对索引视图的维护可能更复杂。...视图中的 SELECT 语句不能包含下列 Transact-SQL 语法元素: 选择列表不能使用 * 或 table_name.* 语法指定列。...通过一个既可以取值为 float 值也可以使用 float 表达式求值的表达式而生成的列不能作为索引视图或表的索引的键。...与基表上的聚集索引一样,聚集索引的 B 树结构仅包含键列,但数据行包含视图结果集中的所有列。 若想为现有系统中的视图添加索引,必须计划绑定任何想要放入索引的视图。

    1.2K30
    领券