mysql主键,外键,非空,唯一,默认约束及创建表的方法

目录
  • 一、操作前提
  • 二、mysql创建/新建表
    • 1、首先我们需要创建一个数据库;
    • 2、然后进入这个数据库;
    • 3、创建表;
    • 4、查看表;
  • 三、使用主键约束
    • 1、单字段主键
    • 2、多字段联合主键
  • 四、使用外键约束
    • 1、mysql中外键是什么?
    • 2、什么是主表?什么是从表?
    • 3、如何在​​mysql​​中创建外键呢?
  • 五、使用非空约束
  • 六、使用唯一性约束
  • 七、使用默认约束
  • 八、设置表的属性值自动增加

前言:

在数据库中,数据表是数据库中最重要、最基本的操作对象,是数据存储的基本单位。数据表被定义为列的集合,数据在表中是按照行和列的格式来存储的。每一行代表一条唯一的记录,每一列代表记录中的一个域。

一、操作前提

创建数据表必须是在已经有数据库的前提下的哈,首先需要切换到数据库中,使用​​use​​命令进行切换。

mysql> use yunweijia;
Database changed
mysql>

二、mysql创建/新建表

create table <表名> (
字段1,数据类型 [列级别约束条件] [默认值],
字段2,数据类型 [列级别约束条件] [默认值],
字段3,数据类型 [列级别约束条件] [默认值],
------
[表级别约束条件]
)

例如我们创建一个表结构如下:


字段名称


数据类型


备注


id


INT


员工编号


name


VARCHAR(25)


员工名称


deptid


INT


所在部门编号


money


FLOAT


工资

1、首先我们需要创建一个数据库;

mysql> create database test_db;
Query OK, 1 row affected (0.02 sec)

mysql>

2、然后进入这个数据库;

mysql> use test_db;
Database changed
mysql>

3、创建表;

mysql> CREATE TABLE `test_user` (
-> `id` int(0) NULL DEFAULT NULL COMMENT '员工编号',
-> `name` varchar(25) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NULL DEFAULT NULL COMMENT '员工姓名',
-> `deptid` int(0) NULL DEFAULT NULL COMMENT '所在部门编号',
-> `money` float NULL DEFAULT NULL COMMENT '工资'
-> );
Query OK, 0 rows affected, 2 warnings (0.03 sec)

mysql>

4、查看表;

mysql> show tables;
+-------------------+
| Tables_in_test_db |
+-------------------+
| test_user |
+-------------------+
1 row in set (0.00 sec)

mysql> desc test_user;
+--------+-------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+--------+-------------+------+-----+---------+-------+
| id | int | YES | | NULL | |
| name | varchar(25) | YES | | NULL | |
| deptid | int | YES | | NULL | |
| money | float | YES | | NULL | |
+--------+-------------+------+-----+---------+-------+
4 rows in set (0.00 sec)

mysql>

释义:

​desc​​​命令是查看​​mysql​​表结构的命令;

三、使用主键约束

主键,又称主码,是表中一列或多列的组合。主键约束(​​Primary KeyConstraint​​)要求主键列的数据唯一,并且不允许为空。主键能够唯一地标识表中的一条记录,可以结合外键来定义不同数据表之间的关系,并且可以加快数据库查询的速度。主键和记录之间的关系如同身份证和人之间的关系,它们之间是一一对应的。主键分为两种类型:单字段主键多字段联合主键

1、单字段主键

主键由一个字段组成,​​SQL​​语句格式分为以下两种情况。

(1.1)在定义列的时候指定主键

语法:

字段名 数据类型 PRIMARY KEY [默认值]

示例:

mysql> CREATE TABLE `test_user_2` (
-> `id` int(0) PRIMARY KEY COMMENT '员工编号' ,
-> `name` varchar(25) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NULL DEFAULT NULL COMMENT '员工姓名',
-> `deptid` int(0) NULL DEFAULT NULL COMMENT '所在部门编号',
-> `money` float NULL DEFAULT NULL COMMENT '工资'
-> );
Query OK, 0 rows affected, 2 warnings (0.03 sec)

mysql>

看下结果:

mysql> show tables;
+-------------------+
| Tables_in_test_db |
+-------------------+
| test_user |
| test_user_2 |
+-------------------+
2 rows in set (0.00 sec)

mysql> desc test_user_2;
+--------+-------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+--------+-------------+------+-----+---------+-------+
| id | int | NO | PRI | NULL | |
| name | varchar(25) | YES | | NULL | |
| deptid | int | YES | | NULL | |
| money | float | YES | | NULL | |
+--------+-------------+------+-----+---------+-------+
4 rows in set (0.00 sec)

mysql>

(1.2)在定义完所有列之后指定主键;

语法:

[CONSTRAINT <约束名>] PRIMARY KEY [字段名]示例:

mysql> CREATE TABLE `test_user_3` (
-> `id` int(0) COMMENT '员工编号' ,
-> `name` varchar(25) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NULL DEFAULT NULL COMMENT '员工姓名',
-> `deptid` int(0) NULL DEFAULT NULL COMMENT '所在部门编号',
-> `money` float NULL DEFAULT NULL COMMENT '工资',
-> PRIMARY KEY(id)
-> );
Query OK, 0 rows affected, 2 warnings (0.03 sec)

mysql>

看下结果:

mysql> show tables;
+-------------------+
| Tables_in_test_db |
+-------------------+
| test_user |
| test_user_2 |
| test_user_3 |
+-------------------+
3 rows in set (0.00 sec)

mysql> desc test_user_3;
+--------+-------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+--------+-------------+------+-----+---------+-------+
| id | int | NO | PRI | NULL | |
| name | varchar(25) | YES | | NULL | |
| deptid | int | YES | | NULL | |
| money | float | YES | | NULL | |
+--------+-------------+------+-----+---------+-------+
4 rows in set (0.00 sec)

mysql>

2、多字段联合主键

主键由多个字段联合组成,语法规则如下:

PRIMARY KEY [字段1, 字段2, ...,字段n]

示例:

mysql> CREATE TABLE `test_user_4` (
-> `id` int(0) COMMENT '员工编号' ,
-> `name` varchar(25) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci COMMENT '员工姓名',
-> `deptid` int(0) COMMENT '所在部门编号',
-> `money` float NULL DEFAULT NULL COMMENT '工资',
-> PRIMARY KEY(name, deptid)
-> );
Query OK, 0 rows affected, 2 warnings (0.03 sec)

mysql>

看下结果:

mysql> show tables;
+-------------------+
| Tables_in_test_db |
+-------------------+
| test_user |
| test_user_2 |
| test_user_3 |
| test_user_4 |
+-------------------+
4 rows in set (0.00 sec)

mysql> desc test_user_4;
+--------+-------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+--------+-------------+------+-----+---------+-------+
| id | int | YES | | NULL | |
| name | varchar(25) | NO | PRI | NULL | |
| deptid | int | NO | PRI | NULL | |
| money | float | YES | | NULL | |
+--------+-------------+------+-----+---------+-------+
4 rows in set (0.00 sec)

mysql>

语句执行后,便创建了一个名为​​test_user_4​​​的数据表,​​name​​​字段和​​deptid​​​字段组合在一起成为​​test_user_4​​的多字段联合主键。

四、使用外键约束

外键用来在两个表的数据之间建立连接,可以是一列或者多列。一个表可以有一个或多个外键。外键对应的是参照完整性,一个表的外键可以是空值,若不为空值,则每一个外键值必须等于另一个表中主键的某个值

1、mysql中外键是什么?

外键:首先他是表中的一个字段,虽可以不是本表的主键,但要对应另外一个表的主键。外键的主要作用是保证数据引用的完整性,定义外键后,不允许删除在另一个表中具有关联关系的行。外键的作用是保持数据的一致性、完整性。

2、什么是主表?什么是从表?

  • 主表(父表):对于两个具有关联关系的表而言,相关联字段中主键所在的那个表是主表
  • 从表(子表):对于两个具有关联关系的表而言,相关联字段中外键所在的那个表是从表

3、如何在​​mysql​​中创建外键呢?

语法:

[CONSTRAINT <外键名>] FOREIGN KEY 字段名1 [ ,字段名2,…]
REFERENCES <主表名> 主键列1 [ ,主键列2,…]

外键名为定义的外键约束的名称,一个表中不能有相同名称的外键

字段名表示子表需要添加外键约束的字段列;

主表名即被字表外键所依赖的表的名称;

主键列表示主表中定义的主键列,或者列组合。

例如我们新建一个​​test_dept​​的表,表结构如下:

字段名称数据类型备注idINT部门编号nameVARCHAR(30)部门名称locationVARCHAR(50)部门位置

首先我们创建一下这个表:

mysql> CREATE TABLE `test_dept` (
-> `id` int(0) PRIMARY KEY COMMENT '部门编号',
-> `name` varchar(30) CHARACTER set utf8mb4 COLLATE utf8mb4_0900_ai_ci COMMENT '部门名称',
-> `localhost` varchar(50) CHARACTER set utf8mb4 COLLATE utf8mb4_0900_ai_ci COMMENT '部门位置'
-> );
Query OK, 0 rows affected, 1 warning (0.03 sec)

mysql> show tables;
+-------------------+
| Tables_in_test_db |
+-------------------+
| test_dept |
| test_user |
| test_user_2 |
| test_user_3 |
| test_user_4 |
+-------------------+
5 rows in set (0.00 sec)

mysql>

定义数据表​​test_user_5​​​,让他的键​​deptid​​​作为外键关联到​​test_dept​​​中的主键​​id​​​,那么我们的​​SQL​​语句应该这么写;

mysql> CREATE TABLE `test_user_5` (
-> `id` int(0) PRIMARY KEY COMMENT '员工编号' ,
-> `name` varchar(25) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci COMMENT '员工姓名',
-> `deptid` int(0) COMMENT '所在部门编号',
-> `money` float NULL DEFAULT NULL COMMENT '工资',
-> CONSTRAINT fk_user_dept FOREIGN KEY(deptid) REFERENCES test_dept(id)
-> );
Query OK, 0 rows affected, 2 warnings (0.07 sec)

mysql>

通过上面的语句,可以看到,我们创建了一个名为​​test_user_5​​​的表,主键为​​id​​​,且创建了一个名为​​fk_user_dapt​​​的外键约束,外键名称为​​deptid​​​,其依赖于​​test_dept​​​表中的主键​​ID​​。

注意点:

子表的外键必须关联父表的主键,且关联字段的数据类型必须匹配,如果类型不一样,则创建子表时,就会出现错误​​ERROR 1005 (HY000):Can't create table 'database.tablename'(errno: 150)​​。

五、使用非空约束

非空约束(​​Not Null Constraint​​)指字段的值不能为空。对于使用了非空约束的字段,如果用户在添加数据时没有指定值,数据库系统会报错。

语法:

字段名 数据类型 not null

那么,我们根据上面的内容,再创建一个​​test_user_6​​​表,并指定​​name​​不能为空;

mysql> CREATE TABLE `test_user_6` (
-> `id` int(0) PRIMARY KEY COMMENT '员工编号' ,
-> `name` varchar(25) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NOT NULL COMMENT '员工姓名',
-> `deptid` int(0) COMMENT '所在部门编号',
-> `money` float NULL DEFAULT NULL COMMENT '工资'
-> );
Query OK, 0 rows affected, 2 warnings (0.03 sec)

mysql>

六、使用唯一性约束

唯一性约束(​​Unique Constraint​​)要求该列唯一,允许为空,但只能出现一个空值。唯一约束可以确保一列或者几列不出现重复值。

语法:

字段名 数据类型 UNIQUE

那么,我们根据该内容,创建一个​​test_user_7​​​表,并指定​​id​​唯一;

mysql> CREATE TABLE `test_user_7` (
-> `id` int(0) UNIQUE PRIMARY KEY COMMENT '员工编号' ,
-> `name` varchar(25) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci COMMENT '员工姓名',
-> `deptid` int(0) COMMENT '所在部门编号',
-> `money` float NULL DEFAULT NULL COMMENT '工资'
-> );
Query OK, 0 rows affected, 2 warnings (0.05 sec)

mysql>

注意点:

​UNIQUE​​​和​​PRIMARY KEY​​​的区别:一个表中可以有多个字段声明为​​UNIQUE​​​,但只能有一个​​PRIMARY KEY​​​声明;声明为​​PRIMARY KEY​​​的列不允许有空值,但是声明为​​UNIQUE​​​的字段允许空值(​​NULL​​)的存在。

七、使用默认约束

默认约束(​​Default Constraint​​)指定某列的默认值。如男性同学较多,性别就可以默认为"男"。如果插入一条新的记录时没有为这个字段赋值,那么系统会自动为这个字段赋值为"男"。

语法:

字段名 数据类型 DEFAULT 默认值

那我们在这个基础上,再新建一个​​test_user_8​​​表,并指定默认所在部门编号为​​0001​​,那么创建的时候就应该这么写;

mysql> CREATE TABLE `test_user_8` (
-> `id` int(0) COMMENT '员工编号' ,
-> `name` varchar(25) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci COMMENT '员工姓名',
-> `deptid` int(0) DEFAULT 0001 COMMENT '所在部门编号',
-> `money` float COMMENT '工资'
-> );
Query OK, 0 rows affected, 2 warnings (0.03 sec)

mysql>

八、设置表的属性值自动增加

在数据库应用中,经常希望在每次插入新记录时,系统自动生成字段的主键值。

可以通过为表主键添加​​AUTO_INCREMENT​​关键字来实现。

默认的,在​​MySQL​​​中​​AUTO_INCREMENT​​​的初始值是​​1​​​,每新增一条记录,字段值自动加​​1​​。一个表只能有一个字段使用​​AUTO_INCREMENT​​约束,且该字段必须为主键的一部分。​​AUTO_INCREMENT​​​约束的字段可以是任何整数类型(​​TINYINT、SMALLIN、INT、BIGINT​​等)。

语法:

字段名 数据类型 AUTO_INCREMENT

例如我们这里创建一个​​test_user_9​​表,并执行员工编号自动递增,那么我们应该这么写:

mysql> CREATE TABLE `test_user_9` (
-> `id` int(0) PRIMARY KEY AUTO_INCREMENT COMMENT '员工编号' ,
-> `name` varchar(25) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci COMMENT '员工姓名',
-> `deptid` int(0) DEFAULT 0001 COMMENT '所在部门编号',
-> `money` float COMMENT '工资'
-> );
Query OK, 0 rows affected, 2 warnings (0.04 sec)
mysql>

我们在这个表里插入两条数据试试看;

mysql> insert into test_user_9 (name, deptid, money) value ('张三', '0001', '10000'), ('李四', '0001', '10000'), ('王五', '0001', '10000');
Query OK, 3 rows affected (0.01 sec)
Records: 3 Duplicates: 0 Warnings: 0

mysql> select * from test_user_9;
+----+--------+--------+-------+
| id | name | deptid | money |
+----+--------+--------+-------+
| 1 | 张三 | 1 | 10000 |
| 2 | 李四 | 1 | 10000 |
| 3 | 王五 | 1 | 10000 |
+----+--------+--------+-------+
3 rows in set (0.00 sec)
mysql>

可以看到​​id​​确实递增了哈。

到此这篇关于mysql主键,外键,非空,唯一,默认约束及创建表的方法的文章就介绍到这了,更多相关mysql主键,外键 内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • 快速理解MySQL中主键与外键的实例教程

    主键与外键的关系,通俗点儿讲,我现在有一个论坛,有两张表,一张是主贴 thread,一张是回帖 reply 先说说主键,主键是表里面唯一识别记录的字段,一般是帖子id,体现在访问的时候,例如是 thread.php?id=1   表示我要访问的是帖子id是1 的帖子- 再来说说外键,当我们删除某个帖子的时候,需要执行另一个操作,就是删除所有回帖,如果正常情况下,我们需要执行两次delete操作(thread和 reply),这时候如果存在外键,例如,在reply 表里面建立一个指向thread表

  • MySQL约束之默认约束default与零填充约束zerofill

    目录 默认约束 添加默认约束 删除默认约束 零填充约束 总结 默认约束 MySQL 默认值约束用来指定某列的默认值. 添加默认约束 方式1: <字段名> <数据类型> default <默认值>; 方式2: alter table 表名 modify 列名 类型 default 默认值; create table t_user10 ( id int , name varchar(20) , address varchar(20) default '北京' -- 指定默认

  • MySQL创建表操作命令分享

    目录 一.表命令 1.查看所有表 2.创建表 3.创建一个用户表 二.MySQL支持的常用数据类型 1.数字型 2.字符串 3.日期 三.MySQL支持的常用约束 四.存储引擎 五.表命令(crud) 1.查看表结构 2.查看表的创建语句 3.更改表名称 4.修改表 5.删除表 六.更新约束 1.先创建一个表,除了主键,不加其他约束. 2.给手机号添加唯一约束 3.删除唯一约束 4.给名字添加非空约束 5.删除非空约束 6.给生日添加默认约束 7.删除默认约束 一.表命令 1.查看所有表 sho

  • MySQL 创建主键,外键和复合主键的语句

    1.创建主键语法 ALTER TABLE table_name ADD CONSTRAINT pk_name PRIMARY KEY(列名); 2.创建外键语法 ALTER TABLE news_info[子表名] ADD CONSTRAINT FK_news_info_news_type[约束名] FOREIGN KEY (info_id)[子表列] REFERENCES news_type[主表名] (id)[主表列] ; 3.使用组合主键 如果一列不能唯一区分一个表里的记录时,可以考虑多个

  • 简述MySQL主键和外键使用及说明

    目录 一.外键约束 什么是外键: 外键的使用条件: 外键的定义语法: 简单演示使用 一.外键约束 MySQL通过外键约束来保证表与表之间的数据的完整性和准确性. 什么是外键: 主键:是唯一标识一条记录,不能有重复的,不允许为空,用来保证数据完整性 外键:是另一表的主键, 外键可以有重复的, 可以是空值,用来和其他表建立联系用的.所以说,如果谈到了外键,一定是至少涉及到两张表.例如下面这两张表: 外键的使用条件: 1.两个表必须是InnoDB表,MyISAM表暂时不支持外键(据说以后的版本有可能支

  • MySQL 创建三张关系表实操

    目录 1.创建学生表 2.创建科目表 3.创建分数表 4.插入数据 5.查询全部分数 6.查询学生的平均分 7.总分排行榜 1.创建学生表 create table tbl_stu ( id int not null primary key auto_increment, name varchar(45) not null )engine=innodb default charset=utf8; 2.创建科目表 create table tbl_sub ( id int not null pri

  • mysql创建表添加字段注释的实现方法

    直接po代码和案例 #创建表的时候写注释 CREATE TABLE userinfo( id INT COMMENT '编号', uname VARCHAR(40) COMMENT '用户名', address VARCHAR(120) COMMENT '家庭住址', hobby VARCHAR(200) COMMENT '爱好' )COMMENT = '用户信息表'; #修改表的注释 ALTER TABLE userinfo COMMENT '用户信息资料表'; #修改字段的注释,注意:字段名

  • mysql数据库入门第一步之创建表

    创建数据库 右键-新建数据库 输入库名.选择字符集和排序规则,点确定 创建数据库成功 新建表 my-表-右键-新建表 如上图所示,在第一个标签页"栏位"中 名:字段的名字 类型:字段的类型,有几十种,常用的有以下几种 char,可以存定长的字符串 varchar,可以存变长的字符串(定长和变长的区别在长度中介绍) int,可以存-2^31 (-2,147,483,648) 到 2^31 - 1 (2,147,483,647) 之间的数字 datetime,可以存日期类型的数据 长度:数

  • mysql主键,外键,非空,唯一,默认约束及创建表的方法

    目录 一.操作前提 二.mysql创建/新建表 1.首先我们需要创建一个数据库: 2.然后进入这个数据库: 3.创建表: 4.查看表: 三.使用主键约束 1.单字段主键 2.多字段联合主键 四.使用外键约束 1.mysql中外键是什么? 2.什么是主表?什么是从表? 3.如何在​​mysql​​中创建外键呢? 五.使用非空约束 六.使用唯一性约束 七.使用默认约束 八.设置表的属性值自动增加 前言: 在数据库中,数据表是数据库中最重要.最基本的操作对象,是数据存储的基本单位.数据表被定义为列的集

  • MySQL删除有外键约束的表数据方法介绍

    在MySQL中删除一张表或一条数据的时候,出现 [Err] 1451 -Cannot deleteorupdatea parent row: aforeignkeyconstraintfails (...) 这是因为MySQL中设置了foreign key关联,造成无法更新或删除数据.可以通过设置FOREIGN_KEY_CHECKS变量来避免这种情况. 禁用外键约束,我们可以使用: SETFOREIGN_KEY_CHECKS=0; 然后再删除数据 启动外键约束,我们可以使用: SETFOREIG

  • MySQL之存储过程按月创建表的方法步骤

    具体不多说,直接上代码.欢迎一起交流和学习. 创建一个按月创建表的存储过程,SQL语句如下: DELIMITER // DROP PROCEDURE IF EXISTS create_table_by_month // CREATE PROCEDURE `create_table_by_month`() BEGIN #--提前申明变量,后面会用到 DECLARE nextMonth varchar(20); DECLARE nextTABLE varchar(20); DECLARE csql

  • mysql实现查询数据并根据条件更新到另一张表的方法示例

    本文实例讲述了mysql实现查询数据并根据条件更新到另一张表的方法.分享给大家供大家参考,具体如下: 原本的数据库有3张表 travel_way :旅游线路表,存放线路的具体信息 traveltag :线路标签表,存放线路目的地等信息 tagrelation:标签对应表,存放线路和目的地的对应关系 因为业务逻辑的改变,现在要把它们合并为一张表,把traveltag中的目的地信息插入到travel_way中. 首先获取到所有线路对应的目的地,以线路ID分组,合并目的地到一行,以逗号分隔. 复制代码

  • mysql处理添加外键时提示error 150 问题的解决方法

    像这种不能创建一个.frm 文件的报错好像暗示着操作系统的文件的权限错误或者其它原因,但实际上,这些都不是的,事实上,这个mysql报错已经被报告是一个mysql本身的bug并出现在mysql 开发者列表当中很多年了,然而这似乎又是一种误导. 在很多实例中,这种错误的发生都是因为mysql一直以来都不能很好的支持的关系的问题, 更不幸的是它也并没有指明到底是哪一个问题会导致上面那种错误,下面我把导致这个可怕 的150错误的常见原因列出来了,并且我以可能性的大小作了排序 已知的原因: 1, 两个字

  • 详解MySQL中的外键约束问题

    使用MySQL开发过数据库驱动的小型web应用程序的人都知道,对关系数据库的表进行创建.检索.更新和删除等操作都是些比较简单的过程.理论上,只要掌握了最常见的SQL语句的用法,并熟悉您选择使用的服务器端脚本语言,就足以应付对MySQL表所需的各种操作了,尤其是当您使用了快速MyISAM数据库引擎的时候.但是,即使在最简单的情况下,事情也要比我们想象的要复杂得多.下面我们用一个典型的例子进行说明.假设您正在运行一个博客网站,您几乎天天更新,并且该站点允许访问者评论您的帖子. MySQL外键约束条件

  • 如何获取SqlServer2005表结构(字段,主键,外键,递增,描述)

    1.获取表的基本字段属性 复制代码 代码如下: --获取SqlServer中表结构 SELECT syscolumns.name,systypes.name,syscolumns.isnullable,syscolumns.length FROM syscolumns, systypes WHERE syscolumns.xusertype = systypes.xusertype AND syscolumns.id = object_id('你的表名') 运行效果 2.如果还想要获取字段的描述

  • MySQL删除外键、增加外键以及删除主键、增加主键的实战步骤

    目录 一.MySQL删除外键 二.MySQL增加外键 三.MySQL删除主键 四.MySQL增加主键 补充:MySQL中有外键时数据表的删除方法 总结 一.MySQL删除外键 格式: alter table 表名 drop foreign key 外键名; 表名就是有外键存在的那个表. 外键名可以通过查看表的创建信息得到. 查看表的创建信息格式: show create table 表名; 二.MySQL增加外键 外键可以在修改表时添加,但是添加外键的前提是: 从表中外键列中的数据必须与主表中主

随机推荐