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

用mysql创建表和外键

基础概念

MySQL是一种关系型数据库管理系统,它使用结构化查询语言(SQL)进行数据操作。在MySQL中,表是数据的容器,而外键是用来建立两个表之间关系的约束。

创建表

创建表的基本语法如下:

代码语言:txt
复制
CREATE TABLE table_name (
    column1 datatype constraints,
    column2 datatype constraints,
    ...
);

例如,创建一个名为students的表:

代码语言:txt
复制
CREATE TABLE students (
    id INT AUTO_INCREMENT PRIMARY KEY,
    name VARCHAR(100) NOT NULL,
    age INT
);

创建外键

外键用于在一个表中引用另一个表的主键。创建外键的基本语法如下:

代码语言:txt
复制
ALTER TABLE table_name
ADD CONSTRAINT fk_name
FOREIGN KEY (column_name)
REFERENCES referenced_table_name (referenced_column_name);

例如,创建一个名为courses的表,并将其与students表通过外键关联:

代码语言:txt
复制
CREATE TABLE courses (
    id INT AUTO_INCREMENT PRIMARY KEY,
    name VARCHAR(100) NOT NULL,
    student_id INT
);

ALTER TABLE courses
ADD CONSTRAINT fk_student
FOREIGN KEY (student_id)
REFERENCES students(id);

优势

  1. 数据完整性:外键约束确保了数据的引用完整性,即只有在父表中存在的值才能被插入到子表的外键列中。
  2. 数据一致性:通过外键,可以维护不同表之间的数据一致性。
  3. 查询优化:外键可以帮助数据库引擎优化查询性能。

类型

MySQL中的外键约束主要有以下几种类型:

  1. CASCADE:当父表中的记录被更新或删除时,子表中的相关记录也会被相应地更新或删除。
  2. SET NULL:当父表中的记录被删除时,子表中的外键列会被设置为NULL。
  3. SET DEFAULT:当父表中的记录被删除时,子表中的外键列会被设置为其默认值。
  4. NO ACTION(或RESTRICT):当父表中的记录被删除或更新时,如果子表中有相关记录,则不允许该操作。

应用场景

外键广泛应用于需要维护数据关系的场景,例如:

  1. 学生管理系统:学生表和课程表之间的关系。
  2. 电商系统:订单表和产品表之间的关系。
  3. 社交网络:用户表和朋友关系表之间的关系。

常见问题及解决方法

问题:为什么无法创建外键?

原因

  1. 引用的列不是主键或唯一键。
  2. 数据类型不匹配。
  3. 引用的表不存在。

解决方法

  1. 确保引用的列是主键或唯一键。
  2. 确保数据类型匹配。
  3. 确保引用的表存在。

例如,如果students表中的id列不是主键,则无法创建外键:

代码语言:txt
复制
-- 错误示例
CREATE TABLE students (
    id INT,
    name VARCHAR(100) NOT NULL,
    age INT
);

CREATE TABLE courses (
    id INT AUTO_INCREMENT PRIMARY KEY,
    name VARCHAR(100) NOT NULL,
    student_id INT
);

ALTER TABLE courses
ADD CONSTRAINT fk_student
FOREIGN KEY (student_id)
REFERENCES students(id); -- 会报错

解决方法

代码语言:txt
复制
CREATE TABLE students (
    id INT AUTO_INCREMENT PRIMARY KEY,
    name VARCHAR(100) NOT NULL,
    age INT
);

CREATE TABLE courses (
    id INT AUTO_INCREMENT PRIMARY KEY,
    name VARCHAR(100) NOT NULL,
    student_id INT
);

ALTER TABLE courses
ADD CONSTRAINT fk_student
FOREIGN KEY (student_id)
REFERENCES students(id); -- 成功

参考链接

希望这些信息对你有所帮助!如果有更多问题,请随时提问。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

Mysql创建失败原因总结

例如,如果一个是int(10),那么也必须设置成int(10),而不是int(11),也不能是tinyint。...原因三 试图设置的字段没有建立起索引,或者不是一个primary key(主键)。如果其中一个不是primary key的话,你必须先为它创建一个索引。...若想要使用约束,必须是InnoDB引擎(实际上,如果两个都是MyISAM 引擎的,这个错误根本不会发生,但也不会产生,只会建立索引)你需要检查表的引擎类型。...原因五 的名字不能重复。你应该检查你的数据库以确保外健名字是唯一的,或者你在键名后面加上几个随机的字符以测试是否是这个原因。...原因六 请确定你的CharsetCollate选项在字段级上的一致。 原因七 你可能设置为设置了一个默认值,如default=0。 原因八 ALTER声明中有语法错误。

4.7K00
  • Django(15)关系

    删除操作 如果一个模型使用了。那么在对方那个模型被删掉后,该进行什么样的操作。可以通过on_delete来指定。可以指定的类型如下: CASCADE:级联操作。...如果对应的那条数据被删除了,那么这条数据也会被删除。 PROTECT:受保护。即只要这条数据引用了的那条数据,那么就不能删除外的那条数据。 SET_NULL:设置为空。...如果的那条数据被删除了,那么本条数据上就将这个字段设置为默认值。如果设置这个选项,前提是要指定这个字段一个默认值。 SET():如果的那条数据被删除了。...关系 之间的关系都是通过来进行关联的。而之间的关系,无非就是三种关系:一对一、一对多、多对多等。以下将讨论一下三种关系的应用场景及其实现方式。...这个中间分别定义了两个,引用到articletag两张的主键。

    2.1K40

    sqlserver语句创建表格_创建的sql语句

    今天介绍一下如何使用SQL Server语句创建并添加数据 首先先了解一下的模式,在数据库中根据模式进行分组避免名称的冲突 在SQL Server 2014中直接新建是默认的前缀dbo 而命名其他的模式需要使用...SQL Server语句进行创建 下面将一步一步的进行演示,首先是创建一个数据库 然后创建模式在后面使用 根据创建的模式或者使用默认的模式名,进行创建,语句如下图 下面解释一下句子的意思 看一下新建好的...后面介绍如何在新表里面添加数据 根据的列数对应的数据类型在括号中一一对应的添加数据并使用逗号隔开 注意,以上添加数据的方法需要同时添加全部字段 如果需要添加单个字段或者较多且不是全部字段则方法如下...当添加不是全部字段时注意不能为空的字段必须写入数据 最后看一下添加好数据的 发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/183704.html原文链接:https

    2.2K10

    MySQL约束

    其中就包括 1 主键(primary key或unique key) 又称主码,数据库中对储存数据对象予以唯一完整标识的数据列或属性的组合。...在关系数据库中,每个数据都是由关系来连系彼此的关系,父数据(Parent Entity)的主键(primary key)会放在另一个数据,当做属性以创建彼此的关系,而这个属性就是。...注意 : 不一定要与相应主键同名,只是在应用中为便于识别,当主键与相应属于不同关系时,往往取同名 作用 保持数据一致性,完整性,主要目的是控制存储在外中的数据。...使两张表形成关联,只能引用外表中的列的值或使用空值。 案例 如果不使用2的学号字段插了一个值(比如20140999999),但该值在1中并没有。...这就是所谓的保持数据的一致性完整性。 如果2还引用1的某个学号,你却把1中的这个学号删了,2就不知道这个学号对应的学生是哪个学生。

    6.5K20

    mysql

    MySQL 3.23.44版本后,InnoDB引擎类型的支持了约束。...的使用条件: 1.两个必须是InnoDB,MyISAM暂时不支持(据说以后的版本有可能支持,但至少目前不支持); 2.列必须建立了索引,MySQL 4.1.2以后的版本在建立时会自动创建索引...,但如果在较早的版本则需要显示建立; 3.关系的两个的列必须是数据类型相似,也就是可以相互转换类型的列,比如inttinyint可以,而intchar则不可以; 的好处:可以使得两张关联...,保证数据的一致性实现一些级联操作; 的定义语法: [CONSTRAINT symbol] FOREIGN KEY [id] (index_col_name, ...)...ON DELETE、ON UPDATE表示事件触发限制,可设参数: RESTRICT(限制外表中的改动) CASCADE(跟随改动) SET NULL(设空值) SET DEFAULT(设默认值

    5.5K70

    mysql如何添加一个

    1:创建一个父,主键作为子表的: 1 create table province( 2 pId int primary key auto_increment, 3 pName varchar...(20) 4 ); 2:创建子表,是父的主键: 1 create table user( 2 userId int primary key auto_increment, 3 userName varchar...(40), 4 pid int, 5 foreign key(pid) references province(pId) 6 ); 给一张添加,即给子表的添加主键的规则: 在子表声明一个字段pid...int,用于作为子表的,foreign key(子表的字段) references 父名(父的主键的字段名); 3:当创建好数据时添加约束: alter table user add...foreign key(pid) references province(pId); alter table 子表的数据名 add foreign key(子表的键名称) references 父的数据名称

    4.3K70

    Mysql约束

    如果A的主关键字是B中的字段,则该字段称为B的A称为主表,B称为从。...是用来实现参照完整性的,不同的约束方式将可以使两张紧密的结合起来,特别是修改或者删除的级联操作将使得日常的维护工作更加轻松。...主要用来保证数据的完整性一致性 两个必须是InnoDB,MyISAM暂时不支持 列必须建立了索引,MySQL 4.1.2以后的版本在建立时会自动创建索引,但如果在较早的版本则需要显示建立...; 关系的两个的列必须是数据类型相似,也就是可以相互转换类型的列,比如inttinyint可以,而intchar则不可以; 创建语法: 代码如下 复制代码 [CONSTRAINT...如果父试图UPDATE或者DELETE任何子表中存在或匹配的键值,最终动作取决于约束定义中的ON UPDATEON DELETE选项。

    5.9K81

    MySQL约束

    什么是检约束 其实很好理解,简单的说就是两张建立一个连接关系。这里我们那主表AB举例,我A中有用户信息,B中有用户订单信息。...要是数据完整对应起来,肯定是需要把两张关联起来,我们因此会在B中村一个A的字段,常见的我们存的是A的主键ID检约束要求 .MySQL的数据存储引擎必须为Innodb。....主表关联的字段数据类型的一致。 .字段不能设置为NULL。 .主表中的字段需为主键。 约束的作用 保证数据的完整性一致性....CASCADE: 从父中删除或更新对应的行,同时自动的删除或更新自中匹配的行。ON DELETE CANSCADEON UPDATE CANSCADE都被InnoDB所支持。 2....SET NULL: 从父中删除或更新对应的行,同时将子表中的列设为空。注意,这些在外列没有被设为NOT NULL时才有效。

    5.9K20

    MySQL【四】---案例实战{拆分多表、创建等}

    int类型且数值范围相同,  设置 关联cate_idgoods_cate的id 约束也可以在修改时添加,但是添加约束的前提是:从中外列中的数据必须与主表中主键列中的数据一致或者是没有数据...>); 删除外约束 当一个中不需要约束时,就需要从中将其删除。...一旦删除,就会解除主表间的关联关系。...3.4 修改brands_name品牌如上述 创建插入数据一起操作 create table goods_brands( id int unsigned primary key auto_increment...key goods_ibfk_1; 在实际开发中,很少使用约束,会极大的降低更新效率; mysql存储在硬盘上,性能比较差,cpu>内存>固态>机械硬盘:

    1.1K10

    MySQL约束使用

    什么是约束在MySQL中,约束用于确保两个之间的数据一致性。约束是一种限制,它将一个中的列与另一个中的列相关联。具体来说,它要求在一个中的某个列中的值必须在另一个的某个列中存在。...约束可以确保数据的完整性一致性,防止数据被删除或修改时发生错误。在MySQL中,约束由FOREIGN KEY关键字REFERENCES子句定义。...FOREIGN KEY关键字用于创建约束,REFERENCES子句用于指定关联列。...如何创建约束在MySQL中,创建约束需要以下步骤:第一步:创建主表约束通常涉及到两个,一个主表一个从。主表包含一个列或一组列,其值将在从中进行比较。...FOREIGN KEY子句用于指定要添加约束的列,REFERENCES子句用于指定关联列。如何使用约束一旦约束被创建,就可以使用它来确保数据的完整性一致性。

    4.1K30

    MySql---复习

    复习 MySQL约束(FOREIGN KEY) 主表 选取设置 MySQL 约束的字段 在创建时设置约束 部门员工案例演示 如果添加不符合约束的数据,会报错 小总结 注意事项...级联操作 格式 测试级联操作 ---- MySQL约束(FOREIGN KEY) MySQL 约束(FOREIGN KEY)用来在两个的数据之间建立链接,它可以是一列或者多列。...---- 选取设置 MySQL 约束的字段 定义一个时,需要遵守下列规则: 父必须已经存在于数据库中,或者是当前正在创建。...---- 在创建时设置约束 在数据创建使用 FOREIGN KEY 关键字,具体的语法规则如下: [CONSTRAINT ] FOREIGN KEY 字段名 [,字段名2,…]...---- 部门员工案例演示 创建 USE test1; #部门--父创建 #主表: 可以约束其他的字段值的 CREATE TABLE depart( id INT(4) PRIMARY

    5.2K30

    重温MySQL约束

    重温MySQL约束 MySQL约束是用来在两个之间建立链接的,其中一个发生变化,另外一个也发生变化。从这个特点来看,它主要是为了保证数据的一致性完整性的。...对于两个通过关联的,相关联字段中主键所在的是主表,也称之为父所在的是从,也称之为子表,定义的时候需要遵守几个规则: 1、父必须已经存在于数据库中,或者是当前正在创建。...也就是说,只要的每个非空值出现在指定的主键中,这个的内容就是正确的。 4、中列的数目必须的主键中列的数目相同。 5、中列的数据类型必须主键中对应列的数据类型相同。...=2的数据,然后再子表插入数据,子表插入uid=1uid=2的数据都能成功,而要插入uid=3的数据时提示失败,也就是说,默认情况下,子表进行插入时,插入的关联字段值必须是父被关联的列包含的值。...在上面的测试中,我们反复提到一个词,就是默认情况,我们没有设置的删除更新规则,这里mysql帮我们使用了最严格的的规则,那就是restrict,其实还有其他一些规则,这里全部列出来: delete

    6.4K10

    14.MySQL(二) 数据之操作内容操作Mysql 连接事务

    primary key; alter table 名 modify 列名 int, drop primary key; 添加:alter table 从 add constraint...键名称(形如:FK_从_主表) foreign key 从(字段) references 主表(主键字段); 删除外:alter table 名 drop foreign key 键名称...4、可靠性:软、硬件崩溃后,InnoDB数据驱动会利用日志文件重构修改。可靠性高速度不可兼得, innodb_flush_log_at_trx_commit选项 决定什么时候吧事务保存到日志里。...-->要写入的内容 rollback; -->回滚到原来状态 commit; -->确认提交 MySQL支持的存储引擎只有InnoDB ,...在创建的时候 , 要求父必须有对应的索引 , 子表在创建的时候也会自动创建对应的索引

    3.2K90
    领券