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

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

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

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

Oracle 级联删除外

所谓的级联删除是指当主表中的一条记录被删除,那么子表中所关联的记录也相应的自动删除。本教程将教大家如何在Oracle中使用级联删除外。...此外,我们也可以创建一个具有多个字段的外(带级联删除),如下例所示: CREATE TABLE supplier ( supplier_id numeric(10) not null, supplier_name...根据supplier_id和supplier_name删除supplier表中的记录时,外fk_foreign_comp上的级联删除会导致products表中的所有对应记录也会被级联删除。...带级联删除),该外基于supplier_id字段引用supplier表。...此外,我们也可以创建一个具有多个字段的外(带级联删除),如下例所示: ALTER TABLE products ADD CONSTRAINT fk_supplier FOREIGN KEY (supplier_id

1.1K30

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

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

2K10

MySQL数据库:数据完整性及约束的应用

约束:constraint MySQL中的约束分类 主键:primary key 唯一:unique 非空:not null 缺省:default 外:foreign key 主键、唯一...、外都会自动创建索引 主键:一个表只能有一个主键,其可以对应一个字段,也可以对应多个字段(组合主键) 唯一:也成为候选主键(跟主键的区别在于可以存储null值) 外:来源于主表的主键或唯一...constraint 约束名 unique(字段名); 删除约束的数据 先删除子表数据,再删除主表数据 级联删除 on delete cascade 级联更新 on update cascade 关掉...mysql约束 SET FOREIGN_KEY_CHECKS=0; 打开mysql约束 SELECT @@FOREIGN_KEY_CHECKS; 删除外 注意:此语句在删除外后不能关联删除该外自动产生的约束...删除指定名称的索引 alter table 表名 drop index 索引名称; 提醒:对于有主外关联的表,删除表中数据,如果无删除的级联操作,那么删除主表数据之前,必须先删除从表对应数据

1.5K30

MySQL复习笔记(2)-约束

DQL查询语句 查询满足条件的数据 SELECT 字段 FROM 表名 WHERE 条件; MySQL运算符 > 大于 < 小于 <= 小于等于 >= 大于等于 = 等于 不等于 !...命令行备份 命令行 $ mysqldump -u用户名 -p密码 数据库 > 文件的路径 还原(还原的时候需要先登录MySQL,并选中对应的数据库) SOURCE 导入文件的路径 MySQL图形化界面工具备份...FOREIGN KEY(外约束名); 外级联 在修改和删除主表的主键时,同时更新或删除副表的外键值,称为级联操作 ON UPDATE CASCADE – 级联更新,主表更新时,从表跟着更新 ON...NAME VARCHAR(30), age INT, dep_id INT, -- 添加外约束,并且添加级联更新和级联删除 CONSTRAINT employee_dep_fk...两种建表原则: 外唯一:主表的主键和从表的外(唯一),形成主外关系,外唯一UNIQUE 外是主键:主表的主键和从表的主键,形成主外关系 一对多 例如:班级和学生,部门和员工,客户和订单,

87620

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

操作过程分为以下几个步骤: 步骤1:从源数据库生成数据结构脚本【不包表含外关系】   在数据源188连接上,右键点击源数据库》【任务】》【生成脚本】 ? 弹出“生成和发布脚本” ?...将“编写外脚本”的值设置为false,意思是这一步骤生成的数据结构脚本中不包含表之间的外关系。其他选项根据实际情况设置。 点击【确定】按钮,生成脚本,入下图。 ?...设置 SET IDENTITY_INSERT dbo.T_ACL_User Off ; 步骤5:从源数据库生成仅包含表外关系的数据结构脚本   步骤与步骤1大致相同,最后一步设置相反 ?...红色框内,将“编写外脚本”设置为True,其他选项与步骤1中设置相反。点击"确定"按钮,生成脚本,另存为“OriginalDataStructureOnlyWithFK.sql”。...外已经成功创建。

1.8K40

Hibernate配置文件详解-2

session session.close(); 执行代码,打印3条SQL语句,向customer表添加1条记录,向orders表添加2条记录,并且将customer的id值赋给cid字段,建立主外约束关系...session session.close(); 再次执行代码,打印5条SQL,向customer表添加1条记录,向orders表添加2条记录,并且将customer的id值赋给cid字段,建立主外约束关系...同时多了2条修改操作,再一次将customer的id值赋给cid字段,这2条SQL语句是在重复设置已经建立的主外约束关系。 为什么会出现这种情况?...因为当前Customer和Orders对象都在维护关系,所以会重复建立两次主外约束。 如何避免这种情况的出现呢? 第一种方式:在Java代码中去掉一方维护关系的代码。...看到控制台打印3条SQL,即建立了一次主外约束关系,并且是由Orders来维护的。 2.cascade:用来设置级联操作。

59820

mysql 分区_mysql分区

对于已经过期或者不需要保存的数据,可以通过删除与这些数据有关的分区来快速删除数据 跨多个磁盘来分散数据查询,以获得更大的查询吞吐量 分区:partition key 查看是否支持分区: mysql>.../唯一字段之外的其他字段进行分区。...对于上百万条记录的表来说,删除分区要比运行一个delete 语句有效得多 经常运行包含分区的查询,mysql可以很快地确定只有某一个或某些分区需要扫描。...同时hash分区只支持整数分区,而key分区支持使用除blob,text以外的其他类型; 与hash分区不同,创建可以分区表的时候,可以不指定分区,默认会首先选择使用主键作为分区;没有主键时,会选择非空唯一作为分区...; 子分区 对分区表中每一个分区再次分割,又被称为复合分区;适合用于保存非常大量的数据记录; mysql分区处理null值的方式 mysql禁止分区键值使用null,分区可能是一个字段或者一个用户定义的表达式

3.8K30

MySQL约束

**子表:**定义了外的表,外的取值要么取父表中字段对应的值,要么取NULL值,严重受限于父表 **父表:**被引用的字段要具有唯一性(绝大多数都是用的父表的主键) 八、外约束 8.1、外约束格式...+-----+--------+---------+--------------+--------------------------+ 2 行于数据集 (0.01 秒) 创建一个学生表(与班级表建立主外关联...这个时候我们就需要级联。...级联操作分为二种:级联更新、级联删除 9.2、级联操作方式 格式: on update cascade #级联更新 on delete cascade #级联操作 只能是创建表的时候创建级联关系。...更新主表中的主键,从表中的外列也自动同步更新 案例: 创建一个学生表(与班级表建立主外关联,并加入级联操作) create table stu -- 学生表 ( sid int primary key

6.5K10

Mysql 双主与级联复制结合架构

才能支撑读的压力 这时候,Master就会比较吃力了,因为仅仅连上来的Slave IO线程就比较多了,这样写的压力稍微大一点时,Master端因为复制就会消耗较多的资源,很容易造成复制的延时 解决方案:级联复制架构...首先通过少数几台MySQL从Master来进行复制,这几台机器称为第一级Slave集群,然后其他的Slave再从第一级Slave集群来进行复制,如果有需要,可以继续往下增加更多层次的复制。...这样,很容易就控制了每一台MySQL上面所附属Slave的数量 如果条件允许,建议通过拆分成多个复制集群来解决,因为Slave越多,整个集群的写IO总量也就会越多,增加复制的级联层次,同一个变更传到最底层的...Slave需要经过的MySQL也会更多,同样可能造成延时较长的风险 Dual Master与级联复制结合架构 级联复制在一定程度上能解决Master因为所附属的Slave过多而成为瓶颈的问题,但是它并不能解决人工维护和出现异常需要切换时可能存在重新搭建...这样就很自然地出现了Dual Master与级联复制结合的架构 这种方式最大的好处就是既可以避免主Master的写操作不会受到Slave集群的复制所带来的影响,同时主Master须要切换的时候也基本上不会出现重搭

1.5K50

mysql的外

MySQL 3.23.44版本后,InnoDB引擎类型的表支持了外约束。...外的使用条件: 1.两个表必须是InnoDB表,MyISAM表暂时不支持外(据说以后的版本有可能支持,但至少目前不支持); 2.外列必须建立了索引,MySQL 4.1.2以后的版本在建立外时会自动创建索引...,但如果在较早的版本则需要显示建立; 3.外关系的两个表的列必须是数据类型相似,也就是可以相互转换类型的列,比如int和tinyint可以,而int和char则不可以; 外的好处:可以使得两张表关联...,保证数据的一致性和实现一些级联操作; 外的定义语法: [CONSTRAINT symbol] FOREIGN KEY [id] (index_col_name, ...)...| SET NULL | NO ACTION | SET DEFAULT}] 该语法可以在 CREATE TABLE 和 ALTER TABLE 时使用,如果不指定CONSTRAINT symbol,MYSQL

5.4K70

MySQL约束

关系是关系数据库的重要组成部分。关系是一个表中的一个或几个属性,用来标识该表的每一行或与另一个表产生联系。...其中就包括外 1 主键(primary key或unique key) 又称主码,数据库表中对储存数据对象予以唯一和完整标识的数据列或属性的组合。...而unique key只是为了保证域/域组的唯一性 2 外(foreign key) 又称外部。...注意 : 外不一定要与相应主键同名,只是在应用中为便于识别,当主键与相应外属于不同关系时,往往取同名 作用 保持数据一致性,完整性,主要目的是控制存储在外表中的数据。...使两张表形成关联,外只能引用外表中的列的值或使用空值。 案例 如果不使用外,表2的学号字段插了一个值(比如20140999999),但该值在表1中并没有。

6.5K20

MySQL约束

什么是外检约束 外其实很好理解,简单的说就是两张表建立一个连接关系。这里我们那主表A和副表B举例,我A表中有用户信息,B表中有用户订单信息。...要是数据完整对应起来,肯定是需要把两张表关联起来,我们因此会在B表中村一个A表的字段,常见的我们存的是A表的主键ID外。 外检约束要求 .MySQL的数据表存储引擎必须为Innodb。...外约束的作用 保证数据的完整性和一致性. 创建语法 [CONSTRAINT [symbol]] FOREIGN KEY [index_name] (index_col_name, ...)...SET NULL: 从父表中删除或更新对应的行,同时将子表中的外列设为空。注意,这些在外列没有被设为NOT NULL时才有效。...实战演示 // 主表 mysql> create table userInfo( -> id int(4) not null primary key auto_increment, ->

5.9K20

Mysql约束

如果表A的主关键字是表B中的字段,则该字段称为表B的外,表A称为主表,表B称为从表。...外是用来实现参照完整性的,不同的外约束方式将可以使两张表紧密的结合起来,特别是修改或者删除的级联操作将使得日常的维护工作更加轻松。...外主要用来保证数据的完整性和一致性 两个表必须是InnoDB表,MyISAM表暂时不支持外列必须建立了索引,MySQL 4.1.2以后的版本在建立外时会自动创建索引,但如果在较早的版本则需要显示建立...; 外关系的两个表的列必须是数据类型相似,也就是可以相互转换类型的列,比如int和tinyint可以,而int和char则不可以; 创建外语法: 代码如下 复制代码 [CONSTRAINT...SET NULL: 从父表中删除或更新对应的行,同时将子表中的外列设为空。注意,这些在外列没有被设为NOT NULL时才有效。

5.8K81
领券