MYSQL(6) 修改数据表 列和约束的修改

本文详细介绍了如何通过SQL语句实现表结构的多种变更操作,包括添加和删除单列或多列、添加各种类型的约束(如主键、唯一、外键等)、修改列定义以及表更名等,并提供了具体实例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.添加单列;

           ALTER TABLE tb_name ADD[COLUMN] col_name column_definition[FIRST|AFTER col_name];

2.添加多列

           ALTER TABLE tb_name ADD[COLUMN] (col_name1,col_name2……);

3.删除列

            ALTER TABLE tb_name DROP col_name;

4.删除多列

            ALTER TABLE tb_name DROP col_name1,col_name2……;

5.添加主键约束

            ALTER TABLE tb_name ADD[CONSTRAINT[symbol]] PRIMARY KEY [index_type](index_col_name,……);

6.添加唯一约束

        ALTER TABLE tb_name ADD [CONSTRAINT] UNIQUE [INDEX|KEY][index_name][index_type](index_col_name,……);

7.添加外键约束

        ALTER TABLE tb_name ADD [CONSTRAINT[symbol]] FOREIGN KEY [index_name](index_col_name,……)                                reference_definition;

       例:ALTER TABLE users2 ADD FOREIGN KEY (pid) REFERENCES province (id)

8.添加/删除默认约束

        ALTER TABLE tb_name ALTER [COLUMN] col_name {SET DEFAULT literal | DROP DEFAULT};

9.删除主键约束

        ALTER TABLE tb_name DROP PRIMARY KEY

10.删除唯一约束:字段仍然存在

        ALTER TABLE tb_name DROP INDEX {INDEX | KEY} index_name

11.删除外键约束

        ALTER TABLE tb_name DROP FOREIGN KEY fk_symbol

12.修改列定义

        ALTER TABLE tb_name MODIFY [COLUMN] col_name collumn_definition [FIRST | AFTER col_name];

        ALTER TABLE tb_name  CHANGE [COLUMN] old_col_name new_col_name column_definition 

                   [FIRST | AFTER ]  col_name;

13.数据表更名(尽量少使用)

        (1)ALTER TABLE tb_name RENAME [TO|AS] new_tb_name

          (2)  RENAME TABLE tb_name TO new_table_name,[tb_name2 TO new_tb_name2]

                   可以为多张数据表更名

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值