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

【数据库】MySQL进阶一、主外讲解

MySQL进阶主外讲解 1.什么是外: 主键:是唯一标识一条记录,不能有重复的,不允许为空,用来保证数据完整性 外:是另一表的主键, 外可以有重复的, 可以是空值,用来和其他表建立联系用的...Id=Dept_id,而Dept_id就是员工表的外:因为员工表的员工需要知道自己属于哪个部门,就可以通过外Dept_id找到对应的部门,然后才能找到部门表里的各种字段信息,从而让二者相关联。...所以说,外一定是在从表创建,从而找到与主表之间的联系;从表负责维护二者之间的关系。 2.外的使用需要满足下列的条件:(这里涉及到了InnoDB的概念) 1....MySQL常见引擎有两种:InnoDB和MyISAM,后者不支持外。 2. 建立关系的对应列必须具有相似的InnoDB内部数据类型。 3....建立关系的对应列必须建立了索引。 4. 假如显式的给出了CONSTRAINT symbol,那symbol在数据库必须是唯一的。假如没有显式的给出,InnoDB会自动的创建。

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

在PowerDesigner设计物理模型1——表和主外

在PD建立物理模型由以下几种办法: 直接新建物理模型。 设计好概念模型,然后由概念模型生成物理模型。 设计好逻辑模型,然后由逻辑模型生成物理模型。...3.切换到Keys选项卡,在其中添加一行命名为PK_ClassRoom,然后单击工具栏的“属性”按钮,打开属性窗口,在该窗口中切换到Columns选项卡,单击添加列按钮,弹出列选择窗口,选中主键应该包含的列...另外需要注意的是,在建立主键时,系统会在主键上建立索引,索引分为聚集索引和非聚集索引,在“属性”窗口的General选项卡可以设置该主键上建立的索引是聚集索引还是非聚集索引,如图所示: 外 如果是由概念模型或者逻辑模型生成物理模型...,那么外是通过Relationship生成的,也可以通过工具栏的Reference来实现两表之间的外关系。...”按钮,然后在设计面板,课程表上按下鼠标左键,并拖拽到教师表中放开鼠标,这时如果课程表没有RoomID列,系统会自动创建RoomID列并创建该列上的外引用,如果已经存在RoomID列,则只添加外引用

2K10

MySQL操作之数据查询语言:(DQL)(四-2)(多表查询)

主表的主键和从表的外形成主外关系 从表外的值是对主表主键的引用。...从表外类型,必须与主表主键类型一致。 建立的表必须是InnDB型,不能是临时表。 外键名不能用引号。FK_ID错误。应为FK_ID。、 添加数据时:从表的外,只能添加主表主键存在的数据。...ADD CONSTRAINT FK_ID FOREIGN KEY (gid) REFERENCES grade (id); 1.2 外约束 建立约束是为了保证数据的完整性和一致性,但是如果主表数据被删除或修改...ALTER TABLE 表名 DROP FOREIGN KEY 外键名; 具体: ALTER TABLE student DROP FOREIGN KEY FK_ID; 二、一对多操作 1.添加主外约束...1、创建中间表,给中间表添加两个外约束 2、创建表、添加数据 订单表和订单项表的主外关系 alter table `orderitem` add constraint orderitem_orders_fk

25030

MySQL建立自己的哈希索引(书摘备查)

MySQL,只有Memory存储引擎支持显式的哈希索引,但是可以按照InnoDB使用的方式模拟自己的哈希索引。这会让你得到某些哈希索引的特性,例如很大的也只有很小的索引。...然而,它将会使用的哈希值进行查找,而不是自身。你所要做的事情就是在where子句中手动地定义哈希函数。 一个不错的例子就是URL查找。URL通常会导至B-Tree索引变大,因为它们非常长。...//www.mysql.com'); 这种方式很不错,因为MysSQL查询优化器注意到url_crc列上有很小的、选择性很高的索引,并且它会使用里面的值进行索引查找。...你可以手工进行维护,在MySQL 5.0及以上版本,可以使用触发器来进行维护。下面的例子显示了触发器如何在插入和更新值的时候维护url_crc列。...://www.mysql.com'); 哈希碰撞几率的增长比想象的要快。

2.1K30

MySQL创建外的错误:1215 Cannot add the foreign key constraint

引言: MySQL中经常会需要创建父子表之间的约束,这个约束是需要建立主外基础之上的,这里解决了一个在创建主外约束过程碰到的一个问题。 1....HASH ) ENGINE=InnoDB AUTO_INCREMENT=5 DEFAULT CHARSET=utf8; 接下来我们需要关联product.sid 至 sealer.id,进行父子表的主外关联...问题分析 主外更多的是某表的主键与子表的某个列进行关联,要求是具备相同的数据类型和属性,问题会不会出现在这里?...解决的办法 修改product.sid的数据类型,添加unsigned和字段的长度,将其设置为相同即可。 5....总结 之所以出现1215的问题,是由于主外之间的数据类型不一致造成的,以后类似问题,皆可按此处理。

2.4K50

SQL Server数据库中导入导出数据及结构时主外关系的处理

将“编写外脚本”的值设置为false,意思是这一步骤生成的数据结构脚本不包含表之间的外关系。其他选项根据实际情况设置。 点击【确定】按钮,生成脚本,入下图。 ?...选中新建的数据库,打开步骤一保存的”OriginalDataStructureWithoutFK.sql“脚本文件,运行该文件,运行成功后,目标数据库成功创建了表、视图、存储过程、自定义函数,如下图...红色框内,将“编写外脚本”设置为True,其他选项与步骤1设置相反。点击"确定"按钮,生成脚本,另存为“OriginalDataStructureOnlyWithFK.sql”。...步骤6:导入外结构关系脚本至目标数据库   选中目标数据库,打开步骤5保存的“OriginalDataStructureOnlyWithFK.sql”脚本文件,运行之,运行成功后,查看表结构 ?...外已经成功创建。

1.8K40

常见的面试问题

阅读量: 60 1、Mysql链表概述   因为表与表之间有关系,而且查询时需要两张表的某些数据。 链表的前提是:表与表之间必须设置主外吗?   ...不是的,其实表与表之间不需要设置主外关系,用数据库语句就可以实现链表查询,删除,修改,增加等操作。 为什么要设置主外呢?   通常我们看到表与表之间有关系,常常设置主外。为什么?...假设一个不了解你表结构的人,都能够任意的修改你的外。那这个表就不严谨了。 我们到底设不设主外呢?这就要分情况: 1、如果表结构简单,少量的表。逻辑不复杂。那么这个就不需要设置主外了。...那么自己不可能记住所有主外之间的关系,那么就需要设置主外。 链表查询又分为:左联表,右链表。等。 链表不仅可以进行查询,还可以链表查询,链表增加,链表删除,链表修改。...在MySQL5.1和更新的版本,InnoDB可以在服务器端过滤掉行后就释放锁,但在早期的MySQL版本,InnoDB直到事务提交时才会解锁。对不需要的元组的加锁,会增加锁的开销,降低并发性。

74010

mysql 分区_mysql分区

对于已经过期或者不需要保存的数据,可以通过删除与这些数据有关的分区来快速删除数据 跨多个磁盘来分散数据查询,以获得更大的查询吞吐量 分区:partition key 查看是否支持分区: mysql>...对于上百万条记录的表来说,删除分区要比运行一个delete 语句有效得多 经常运行包含分区的查询,mysql可以很快地确定只有某一个或某些分区需要扫描。...例如,上述例子检索store_id ,大于10的记录,mysql只需要扫描p1 ; 可以使用explain 来检测,查询使用的是哪个分区; List分区: list 分区是建立离散的值列表告诉数据库特定的值属于哪个分区...; 在执行hash分区时,mysql会对分区应用一个散列函数,以此确定数据应当放在N个分区的哪个分区。...; 子分区 对分区表每一个分区再次分割,又被称为复合分区;适合用于保存非常大量的数据记录; mysql分区处理null值的方式 mysql禁止分区键值使用null,分区可能是一个字段或者一个用户定义的表达式

3.8K30

mysql建立联合索引_mysql之联合索引

mysql之联合索引测试: 前期准备: 建立联合索引?...,则该索引仅出现在key列表 rows: 根据表统计信息及索引选用情况,大致估算出找到所需的记录所需要读取的行数 Extra: 1、Using filesort : mysql对数据使用一个外部的索引排序...也就是说mysql无法利用索引完成的排序操作成为“文件排序” 2、Using temporary: 使用临时表保存中间结果,也就是说mysql在对查询结果排序时使用了临时表,常见于order by 和...就是select列表的字段,只用从索引中就能获取,不必根据索引再次读取数据文件,换句话说查询列要被所建的索引覆盖。...测试语句是否使用了索引: 网上说联合索引 test_col1_col2_col3 实际建立了(col1)、(col1,col2)、(col,col2,col3)三个索引。

4.9K30

使用MySQL Workbench建立数据库,建立新的表,向表添加数据

我用的MySQL数据库,使用MySQL Workbench管理。下面简单介绍一下如何使用MySQL Workbench建立数据库,建立新的表,为表添加数据。...点击上图中的“加号”图标,新建一个连接, 如上图,先输入数据库的账号密码,帐号默认为root,填好密码后 点击“OK”,连接就建立好了,建立完成后,会出现一个长方形的框框,双击它,出现下图所示页面...of a pk) 主键 NN: not null (column is nullable) 是否为空 -UQ: unique (column is part of a unique key) 外...Numeric Types”) 出现如下页面 接下来向建好的tb_student表添加数据 右键点击tb_student,再点击select rows limit 1000 在mysql workbench...向数据库的表添加数据大致就是这个样子。

9.6K30

建立索引的原理和实验

但发现有时开发人员提交SQL语句时未必会注意外列需要定义索引,或者不清楚为什么外列需要建立索引,网上一些所谓的“宝典”也会将外列建索引作为其中的一条,包括TOM大师,曾说过: 导致死锁的头号原因是外未加索引...2)如果删除了父表的一行,整个子表也会被锁住(由于外上没有索引)。 因此,无论从什么角度看,都有必要从原理上好好理解外为何需要创建索引,或者说外不创建索引会有什么问题?...(2) 删除主表记录的过程,会根据外字段检索子表记录,select /+ all_rows / count(1) from “TEST”.”T2” where “T1_ID” = :1,这就意味着,...(4) 只有外创建索引,(1)的操作才不会出现锁或hang状态,(2)的操作才有可能使用索引。...通过以上实验,至少对外建立索引产生的影响,有了一些感性的认识,对外为何要建立索引,应该有了更深入的理解。

2.6K20

MySQL索引的建立方式

MySQL索引的建立对于MySQL的高效运行是很重要的,索引可以大大提高MySQL的检索速度。...打个比方,如果合理的设计且使用索引的MySQL是一辆兰博基尼的话,那么没有设计和使用索引的MySQL就是一个人力三轮车。...因为更新表时,MySQL不仅要保存数据,还要保存一下索引文件。 建立索引会占用磁盘空间的索引文件。 ---- 普通索引 创建索引 这是最基本的索引,它没有任何限制。...以下实例为在表添加索引。 mysql> ALTER TABLE testalter_tbl ADD INDEX (c); 你还可以在 ALTER 命令中使用 DROP 子句来删除索引。...---- 显示索引信息 你可以使用 SHOW INDEX 命令来列出表的相关的索引信息。可以通过添加 \G 来格式化输出信息。

2.3K00

Mysql合理建立索引,索引优化

对数据较小的列使用索引,可以使索引文件更小,同时内存也可以装载更多的索引。 为较长的字符串使用前缀索引。比如数据的长度大部分是150个字节,我们只建立前100个字节的索引。...常见的可以用于建立索引的字段场景: ① 用户id 在订单表的用户id字段上建立索引,根据用户id筛选订单,则会很快查询出用户的订单。...用户一般是在自己的后台查看订单,所以表的其他用户数据与他无关,如果没有建立索引,每次查询都是全表扫描,则会很慢。...mysql,多个索引同时使用?...优先对数据量比较小的字段建立索引,可以使索引文件更小,同时内存也可以装载更多的索引。 规范sql语句的生成,禁止发生列运算、类型转换的发生。

4.7K20
领券