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

Hive优化器原理与源码解析系列—统计信息UniqueKeys列集合

如两个RelNode进行Join时,Join返回记录数多少由的主键侧记录数选择率和外键侧非重复值的UniqueKeys唯一键共同决定的。...Join的RowCount等于Math.min(1.0, 主键侧选择率 * 主键侧ndv缩放因子) * 非重复外键侧记录数。...强调一点,这里讲到主键侧PK side不是指其主键,是带有主键的那一侧,就JoinKey关联键外键而言,它是重复的,如员工表的外键部门编号就是含有重复值的,所以使用主键侧的选择率和外键的非重复记录数进行估算...Hive优化器原理与源码解析系列—统计信息中间结果估算文章只是提到了UniqueKeys唯一键的使用,但没有展开UniqueKeys唯一键是如何识别的,接下来我们讲解分析。...遍历每列的统计信息的NDV(Number of Distinct Value)与中记录数进行表,如果非重复个数大于或等于总记录数数,说明此列为UniqueKey。

1K20

【MySQL 系列】MySQL 语句篇_DDL 语句

外键相对于主键而言,用来引用其他表。外键通过子表的一个或多个列对应到父表的主键或唯一键值,将子表的行和父表行建立起关联关系。 例如,Sakila 示例数据库中的 country 表和 city 表。...我们可以使用以下 3 个策略中的一个: CASCADE:如果被引用的表中的一行被删除或更新,该表中匹配行的值会自动删除或更新。...SET NULL:如果被引用的表中的一行被删除或更新,该表中匹配行的值设置为 NULL。...3.2.2、添加外键 如果建表的时候没有定义外键,你也可以后来通过以下语法添加外键: ALTER TABLE child_table_name ADD [CONSTRAINT foreign_key_name...当父表的行的键值更新的时候,子表中匹配的行的字段也会被更 3.3、唯一键约束 唯一约束与主键约束有一个相似的地方,就是它们都能够确保列的唯一性。

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

    YashanDB数据完整性

    外键约束(Foreign key)指定一个列作为外键,在外键和主键或唯一键之间建立关系,也称为引用键。外键的值必须在主键或唯一键内存在。检查性约束(Check)要求对应列满足指定的条件。...唯一约束列都为空值也始终满足唯一键约束。# 主键约束在一个主键约束中的列或列集,其键值能唯一地标识一行。每个表只能有一个主键,起确定行的作用,并确保不存在任何重复的行。...通常,外键约束要求约束列或列集中的每个值都必须与另一个表的指定列中的值相匹配,例如教师所带的班级必须是班级信息表中存在(教师信息表到班级信息表的外键约束)。...术语定义外键/复合外键约束定义中包含的列称为外键,一个外键由多个列组成时称为复合外键。外键会引用另一个表的主键或唯一键,复合外键则需引用相同数量和数据类型列的复合主键或复合唯一键。...外键的值,要么匹配被引用主键或唯一键的值,要么为空。如果复合外键中存在空值列,该键的非空列不再强制要求匹配父项中的对应列。被引用键被外键所引用的表中的唯一键或主键。

    5800

    spring batch数据库表数据结构

    不是为每种类型创建一个单独的表格,而是有一个表格带有指示类型的列,如下所示: 以下列表描述了每列: JOB_EXECUTION_ID:BATCH_JOB_EXECUTION表中的外键,指示参数条目所属的作业执行...DOUBLE_VAL:参数值,如果类型是双倍的。 IDENTIFYING:指示参数是否有助于相关身份的标志JobInstance。 请注意,此表没有主键。这是因为框架没有用于一个,因此不需要它。...END_TIME:表示执行完成时的时间戳,无论成功或失败。即使作业当前未运行,此列中的空值也表示存在某种类型的错误,并且框架无法在失败之前执行上次保存。 STATUS:表示执行状态的字符串。...以下清单显示了该BATCH_JOB_EXECUTION_CONTEXT表的定义: 以下列表描述了每列: JOB_EXECUTION_ID:表示JobExecution上下文所属的外键。...以下清单显示了该BATCH_STEP_EXECUTION_CONTEXT表的定义 : 以下列表描述了每列: STEP_EXECUTION_ID:表示StepExecution上下文所属的外键。

    4.5K80

    mysql学习笔记(四)约束与索引

    PRIMARY KEY主键约束不能重复,不能为空NOT NULL 非空约束不能为空DEFAULT默认约束插入数据时此列没有值插入,则使用默认值UNIQUE KEY唯一约束此列不能有重复值FROEIGN...KEY外键约束约束表之间的关系 一、主键约束(primary key constraint)  主键创建时默认会自动生成约束,也可通过显示声明。 ...一个表可以有很多的外键约束 外键约束需要一个表的两个字段或者两个表的两个字段之间建立外键约束 外键约束一定是在从表、子表中建立的。...例如学生表和课程表 从表:外键所在,依赖主表的表。...,唯一键意味着唯一,可以为NULL,这意味着除了NULL值其他的都必须唯一,而可以有多个NULL值。

    2.1K00

    SqlAlchemy 2.0 中文文档(三十八)

    autoincrement – 为没有外键依赖的整数主键列设置“自动递增”语义(有关更具体的定义,请参见本文档字符串后面)。...警告 MetaData.sorted_tables属性本身无法自动解决表之间的依赖关系循环,这通常是由相互依赖的外键约束引起的。当检测到这些循环时,这些表的外键将被从排序考虑中省略。...这基于由Column.autoincrement参数定义的Column的规则,通常意味着不受外键约束的单个整数列主键约束中的列。如果表没有这样的主键约束,则没有“自动增量”列。...autoincrement – 设置“自动递增”语义,用于没有外键依赖的整数主键列(详见本文档字符串后面的更具体定义)。...这基于Column的规则,由Column.autoincrement参数定义,通常意味着在不受外键约束的单整数列主键约束内的列。如果表格没有这样的主键约束,那么就没有“自动增量”列。

    20710

    MySQL 约束介绍

    PRIMARY KEY(字段名1,字段名2); 4、自增长约束 某个字段的值自增 一个表最多只能有一个自增长列 当需要产生唯一标识符或顺序值时,可设置自增长 自增长列约束的列必须是键列(主键列,唯一键列...外键约束 限定某个表的某个字段的引用完整性 从表的外键列,必须引用/参考主表的主键或唯一约束的列 在创建外键约束时,如果不给外键约束命名,默认名不是列名,而是自动产生一个外键名(例如student_ibfk...方式:在父表上update/delete记录时,同步update/delete掉子表的匹配记录 Set null方式:在父表上update/delete记录时,将子表上匹配记录的列设为null,但是要注意子表的外键列不能为...not null No action方式:如果子表中有匹配的记录,则不允许对父表对应候选键进行update/delete操作 Restrict方式:同no action, 都是立即检查外键约束(如果没有指定等级...Set default方式:父表有变更时,子表将外键列设置成一个默认的值,但Innodb不能识别 6、默认值约束 给某个字段/某列指定默认值,一旦设置默认值,在插入数据时,如果此字段没有显式赋值,则赋值为默

    1.6K41

    详解 MySQL 执行计划 -- Explain

    DERIVED 表示该查询是在首要表 from 列表中包含的子查询,DERIVED 表示这是一个针对临时表的查询。 3.2.4....Null 表示在优化器优化后就已经得到结果,不需要再通过执行器访问存储引擎来实现查询操作,例如: explain select max(id) from person; 3.5.2. const 当使用主键或惟一键进行查询且只匹配一行时...3.5.3. eq_ref 对于每个来自于前面的表的行组合,从该表中读取一行,并通过这一行可以通过主键或惟一键定位到聚簇索引中具体的一系列数据。...如果此列是 NULL,则没有相关的索引。 3.7. key key 列指出了 MySQL 优化器最终选定的索引。...3.9. ref 该字段显示使用哪个列或常数与 key 一起从表中选择数据行,有三种选项可选: NULL — 不使用索引 func — 用于索引匹配的值是函数计算的结果 const — 用于索引匹配的值是常量

    91911

    详解Mysql执行计划explain

    这是const连接类型的特殊情况。 const :读常量,且最多只会有一条记录匹配。表中的一个记录的最大值能够匹配这个查询(索引可以是主键或惟一索引)。...eq_ref:最多只会有一条匹配结果,一般是通过主键或者唯一键索引来访问;在连接中,MYSQL在查询时,从前面的表中,对每一个记录的联合都从表中读取一个记录,它在查询使用了索引为主键或惟一键的全部时使用...ref:Join 语句中被驱动表索引引用查询,这个连接类型只有在查询使用了不是惟一或主键的键或者是这些类型的部分(比如,利用最左边前缀)时发生。对于之前的表的每一个行联合,全部记录都将从表中读出。...:子查询中的返回结果字段组合是一个索引(或索引组合),但不是一个主键或者唯一索引; index:全索引扫描,这个连接类型对前面的表中的每一个记录联合进行完全扫描(比ALL更好,因为索引一般小于表数据)。...“对于每一种与另一个表中记录的组合,MySQL将从当前的表读取所有带有匹配索引值的记录。

    95820

    MySQL表的约束

    唯一键允许为空,而且可以多个为空,因为空字段不做唯一性比较。 唯一键和主键的区别: 在使用中,主键是标识唯一性,而唯一键是保证业务中的数据唯一性。 主键一个表只能有一个,唯一键可以有多个。...主键不能为空,唯一键可以为空,甚至多个为空。 对于主键的标识唯一性以及唯一键的业务唯一性的理解: 一个表中若存在id,name,telephone三个字段,无疑id是要被标识唯一性主键的。...外键是用于定义主表和从表之间的关系 外键约束主要定义在从表上,主表则必须是有主键约束或unique约束。当定义外键后,要求外键列数据必须在主表的主键列存在或为null。...外键存在两种关系: 关联关系:逻辑上的关系,表与表之间有相同字段。 约束关系:通过关联关系实现表之间的约束。 此时student中的class_id存在外键之名(关联关系),但是没有外键之实。...注:主表在从表存在的前提下,不能drop table 主表。 ---- 外键约束中,也存在constraint将外键约束命名,不过mysqld内部会自动做这样的操作。

    22650

    数据库常见的面试题大全

    缺点: 性能:查询视图时,必须把视图的查询转化成对基本表的查询,如果这个视图是由一个复杂的多表查询所定义,那么,那么就无法更改数据 11、列举几种表连接方式,有什么区别?...内连接、自连接、外连接(左、右、全)、交叉连接 内连接:只有两个元素表相匹配的才能在结果集中显示。 外连接: 左外连接:左边为驱动表,驱动表的数据全部显示,匹配表的不匹配的不会显示。...右外连接:右边为驱动表,驱动表的数据全部显示,匹配表的不匹配的不会显示。 全外连接:连接的表中不匹配的数据全部会显示出来。 交叉连接: 笛卡尔效应,显示的结果是链接表数的乘积。...12、主键和外键的区别? 主键在本表中是唯一的、不可唯空的,外键可以重复可以唯空;外键和另一张表的主键关联,不能创建对应表中不存在的外键。 13、在数据库中查询语句速度很慢,如何优化?...第一范式:列不可再分 第二范式:行可以唯一区分,主键约束 第三范式:表的非主属性不能依赖与其他表的非主属性 外键约束 且三大范式是一级一级依赖的,第二范式建立在第一范式上,第三范式建立第一第二范式上 15

    1.4K40

    关键字类定义,外键定义,索引定义,方法定义

    class_keyword_list(可选)是以逗号分隔的关键字列表,这些关键字(在大多数情况下)会影响编译器如何为此类定义生成代码。如果省略此列表,也要省略方括号。...Class_members是类成员的零个或多个定义。第二章 外键定义描述外键定义的结构。介绍外键定义了引用完整性约束。修改包含外键约束的表时,将检查外键约束。可以将外键定义添加到持久类中。...name(必需)是外键的名称。这必须是有效的类成员名称,并且不能与任何其他类成员名称冲突。 key_props(必需)指定受该外键约束的一个或多个属性。具体来说,该属性必须与外部表中的引用值匹配。...这是一个逗号分隔的属性名称列表。这些属性必须在定义外键的同一类中。 referenced_class(必需)指定外键表(即外键指向的类)。...keyword_list(可选)是以逗号分隔的关键字列表,用于进一步定义外键。如果省略此列表,也要省略方括号。

    1K10

    mysql常用语句大全_什么是SQL语句

    states varchar(2) ## 删除表的主键约束 alter table store drop primary key ## 删除表的外键约束 (删除需要带上外键名称) alter table...* from test limit 0 , 3 3.1数据表的关联关系 ## 一对一关联 # 1.主键关联–两张数据表中主键相同的数据为相互对应的数据 # 2.唯一外键–在任意一张表中添加一个字段添加外键约束与另一张表主键关联...## 一对多,多对一 # 1.设置外键–在多的一方表中添加一个字段添加外键约束与另一张表主键关联。 ## 多对多 # 1.新建关系表–在关系表中定义两个外键,分别与两个数据表的主键相关联。...2.唯一索引:在数据库表中的唯一列创建的索引(unique),此列的所有值只能出现一次,可以为null。 3.普通索引:在普通字段上创建的索引,没有唯一性的限制。...2.在创建数据表时,将字段声明为唯一键(添加唯一约束),会自动在唯一字段创建唯一索引。

    81620

    Java面试之数据库面试题

    缺点: 性能:查询视图时,必须把视图的查询转化成对基本表的查询,如果这个视图是由一个复杂的多表查询所定义,那么,那么就无法更改数据 11、列举几种表连接方式,有什么区别?...内连接、自连接、外连接(左、右、全)、交叉连接 内连接:只有两个元素表相匹配的才能在结果集中显示。 外连接: 左外连接:左边为驱动表,驱动表的数据全部显示,匹配表的不匹配的不会显示。...右外连接:右边为驱动表,驱动表的数据全部显示,匹配表的不匹配的不会显示。 全外连接:连接的表中不匹配的数据全部会显示出来。 交叉连接: 笛卡尔效应,显示的结果是链接表数的乘积。...12、主键和外键的区别? 主键在本表中是唯一的、不可唯空的,外键可以重复可以唯空;外键和另一张表的主键关联,不能创建对应表中不存在的外键。 13、在数据库中查询语句速度很慢,如何优化?...第一范式:列不可再分 第二范式:行可以唯一区分,主键约束 第三范式:表的非主属性不能依赖与其他表的非主属性 外键约束 且三大范式是一级一级依赖的,第二范式建立在第一范式上,第三范式建立第一第二范式上 15

    1.5K20

    MySQL_库和表的使用(部分未完

    设置现有列(字段)为主键 在添加新字段时设置为主键 前提是表中没有主键 设置复合主键 创建新表时设置 不能用第一种方式创建 会报错“定义了重复主键” 设置现有字段为复合主键 此前表中没有主键 更多...关于主键、默认值(default)、唯一键、外键等SQL字段约束相关知识,在慕雪的寒舍-SQL字段约束 修改列的数据类型 将SC表中的Sno的数据类型由int(11)改为int(20) 查看一下表结构:...,其主键或唯一键,与表中现存数据重合,则插入数据失败。...在test表中插入数据Sno、Sage(Sno必填,因为是主键),如果填入的内容与主键发生重复冲突,则更新update语句后面指定字段中的内容 示例中是,如果发生主键/唯一键冲突,则将该主键/唯一键对应的数据中...要插入的数据的主键/唯一键与现有数据冲突时,replace将现有数据所有字段删除,将要插入的数据重新插入。即replace在遇到冲突时,是先删除,后插入。

    12210

    数据库经典面试题,都给你收集好了!!!

    缺点: 性能:查询视图时,必须把视图的查询转化成对基本表的查询,如果这个视图是由一个复杂的多表查询所定义,那么,那么就无法更改数据 11、列举几种表连接方式,有什么区别?...内连接、自连接、外连接(左、右、全)、交叉连接 内连接:只有两个元素表相匹配的才能在结果集中显示。 外连接: 左外连接:左边为驱动表,驱动表的数据全部显示,匹配表的不匹配的不会显示。...右外连接:右边为驱动表,驱动表的数据全部显示,匹配表的不匹配的不会显示。 全外连接:连接的表中不匹配的数据全部会显示出来。 交叉连接: 笛卡尔效应,显示的结果是链接表数的乘积。...12、主键和外键的区别? 主键在本表中是唯一的、不可唯空的,外键可以重复可以唯空;外键和另一张表的主键关联,不能创建对应表中不存在的外键。 13、在数据库中查询语句速度很慢,如何优化?...第一范式:列不可再分 第二范式:行可以唯一区分,主键约束 第三范式:表的非主属性不能依赖与其他表的非主属性 外键约束 且三大范式是一级一级依赖的,第二范式建立在第一范式上,第三范式建立第一第二范式上 15

    1.6K30

    Java面试之数据库面试题

    缺点: 性能:查询视图时,必须把视图的查询转化成对基本表的查询,如果这个视图是由一个复杂的多表查询所定义,那么,那么就无法更改数据 11、列举几种表连接方式,有什么区别?...内连接、自连接、外连接(左、右、全)、交叉连接 内连接:只有两个元素表相匹配的才能在结果集中显示。 外连接: 左外连接:左边为驱动表,驱动表的数据全部显示,匹配表的不匹配的不会显示。...右外连接:右边为驱动表,驱动表的数据全部显示,匹配表的不匹配的不会显示。 全外连接:连接的表中不匹配的数据全部会显示出来。 交叉连接: 笛卡尔效应,显示的结果是链接表数的乘积。...12、主键和外键的区别? 主键在本表中是唯一的、不可唯空的,外键可以重复可以唯空;外键和另一张表的主键关联,不能创建对应表中不存在的外键。 13、在数据库中查询语句速度很慢,如何优化?...第一范式:列不可再分 第二范式:行可以唯一区分,主键约束 第三范式:表的非主属性不能依赖与其他表的非主属性 外键约束 且三大范式是一级一级依赖的,第二范式建立在第一范式上,第三范式建立第一第二范式上 15

    1.5K41

    MySQL数据库:表的约束

    ,数据不能重复,但是一张表中只能有一个主键:唯一键就可以解决表中有多个字段需要唯一性约束的问题。...唯一键的本质和主键差不多,唯一键允许为空,而且可以多个为空,空字段不做唯一性比较。 关于唯一键和主键的区别: 我们可以简单理解成,主键更多的是标识唯一性的。...而我们设计员工工号的时候,需要一种约束:而所有的员工工号都不能重复。具体指的是在公司的业务上不能重复,我们设计表的时候,需要这个约束,那么就可以将员工工号设计成为唯 一键。...外键用于定义主表和从表之间的关系:外键约束主要定义在从表上,主表则必须是有主键约束或unique约束。...当定义外键后,要求外键列数据必须在主表的主键列存在或为null。

    28230

    MySQL:表的约束

    如果我们没有明确指定一列要插入,用的是default。如果建表中,对应列默认没有设置default,无法直接插入。 default和not null不冲突,而是互相补充的。...唯一键 创建带有唯一键的表: 唯一键表达了类似于主键的功能,不能发生冲突。 但是,唯一键是可以为空的,这是区别于主键的地方。 主键与唯一键并不冲突,是互相补充的!!!...关于唯一键和主键的区别: 我们可以简单理解成,主键更多的是标识唯一性的。而唯一键更多的是保证在业务上,不要和别的信息出现重复。 九....外键 外键用于定义主表和从表之间的关系:外键约束主要定义在从表上,主表则必须是有主键约束或unique约束。当定义外键后,要求外键列数据必须在主表的主键列存在或为null。...语法: foreign key (字段名) references 主表(列) 案例: 这样的student只是有外键之名(关联关系),但是没有外键之实(没有约束)。重新创建一个。

    6710

    SQL命令 UPDATE(一)

    如果没有提供WHERE子句(或WHERE CURRENT OF子句),UPDATE将更新表中的所有行。...如果插入请求失败由于违反唯一键(字段(s)的一些独特的关键,存在这一行已经有相同的值(s)为插入指定的行),然后它会自动变成一个更新请求这一行,并插入或更新使用指定的字段值来更新现有的行。...要更新表,更新必须满足所有表、列名和值要求,如下所示。 表: 表必须存在于当前(或指定)命名空间中。 如果无法找到指定的表,IRIS将发出SQLCODE -30错误。...如果更新将违反字段的唯一性约束,则不能更新字段值。 试图更新一个字段(或一组字段)的值,使更新违反惟一性约束或主键约束,将导致SQLCODE -120错误。...如果更新其中一个指定的行会违反外键引用完整性(并且没有指定%NOCHECK), UPDATE将无法更新任何行,并发出SQLCODE -124错误。

    2.9K20
    领券