参考源
- 简单教程
- 菜鸟教程
SQL alter table 语句
SQL alter talbe
语句用于向已有的表中添加、删除或修改列 ( 字段 )
-
向表中添加列
ALTER TABLE table_name ADD [COLUMN] column_name data_type
-
删除表中的列
ALTER TABLE table_name DROP [COLUMN] column_name
-
修改表中列的数据类型
SQL Server / MS AccessALTER TABLE table_name ALTER COLUMN column_name data_type
MySQL / Oracle
ALTER TABLE table_name MODIFY COLUMN column_name data_type
Oracle 10G 之后版本
ALTER TABLE table_name MODIFY column_name data_type;
示例数据
CREATE DATABASE IF NOT EXISTS hardy_db default character set utf8mb4 collate utf8mb4_0900_ai_ci;
USE hardy_db;
DROP TABLE IF EXISTS lesson;
CREATE TABLE lesson (
id int(11) NOT NULL PRIMARY KEY AUTO_INCREMENT,
name varchar(32) default '',
views int(11) NOT NULL default '0',
created_at TIMESTAMP
);
INSERT INTO lesson(id,name,views,created_at) VALUES
(1, 'Python 基础教程',981,'2017-04-18 13:52:03'),
(2, 'Scala 基础教程',73,'2017-04-18 16:03:32'),
(3, 'Ruby 基础教程',199,'2017-05-01 06:16:14');
SQL alter table 基本使用
-
添加列
如果我们想给表添加一列
varchar(128)
用于表示课程的路径,可以使用下面的 SQL 语句ALTER TABLE lesson ADD slug VARCHAR(128) NOT NULL DEFAULT '';
然后我们使用
desc lesson;
看一下 lesson 的表结构mysql> desc lesson; +------------+--------------+------+-----+---------+----------------+ | Field | Type | Null | Key | Default | Extra | +------------+--------------+------+-----+---------+----------------+ | id | int(11) | NO | PRI | NULL | auto_increment | | name | varchar(32) | YES | | | | | views | int(11) | NO | | 0 | | | created_at | datetime | YES | | NULL | | | slug | varchar(128) | NO | | | | +------------+--------------+------+-----+---------+----------------+
顺带看一下数据
mysql> SELECT * FROM lesson; +----+---------------------+-------+---------------------+------+ | id | name | views | created_at | slug | +----+---------------------+-------+---------------------+------+ | 1 | Python 基础教程 | 981 | 2017-04-18 13:52:03 | | | 2 | Scala 基础教程 | 73 | 2017-04-18 16:03:32 | | | 3 | Ruby 基础教程 | 199 | 2017-05-01 06:16:14 | | +----+---------------------+-------+---------------------+------+
-
修改字段
一般情况下 slug 32 个字符足够了,所以我们可以使用下面的 SQL 语句更改下
ALTER TABLE lesson MODIFY COLUMN slug VARCHAR(32) NOT NULL DEFAULT '';
然后使用
desc lesson;
看一下表结构mysql> desc lesson; +------------+-------------+------+-----+---------+----------------+ | Field | Type | Null | Key | Default | Extra | +------------+-------------+------+-----+---------+----------------+ | id | int(11) | NO | PRI | NULL | auto_increment | | name | varchar(32) | YES | | | | | views | int(11) | NO | | 0 | | | created_at | datetime | YES | | NULL | | | slug | varchar(32) | NO | | | | +------------+-------------+------+-----+---------+----------------+
如果我们少定义了一些项,它会使用数据库系统的默认设置,而不是表中的原先定义
ALTER TABLE lesson MODIFY COLUMN slug VARCHAR(16);
使用
desc lesson;
可以看到这点不同mysql> desc lesson; +------------+-------------+------+-----+---------+----------------+ | Field | Type | Null | Key | Default | Extra | +------------+-------------+------+-----+---------+----------------+ | id | int(11) | NO | PRI | NULL | auto_increment | | name | varchar(32) | YES | | | | | views | int(11) | NO | | 0 | | | created_at | datetime | YES | | NULL | | | slug | varchar(16) | YES | | NULL | | +------------+-------------+------+-----+---------+----------------+
-
删除列
如果要删除 slug 列,可以使用下面的 SQL 语句
ALTER TABLE lesson DROP COLUMN slug;
使用
desc lesson;
命令可以看到结果如下mysql> desc lesson; +------------+-------------+------+-----+---------+----------------+ | Field | Type | Null | Key | Default | Extra | +------------+-------------+------+-----+---------+----------------+ | id | int(11) | NO | PRI | NULL | auto_increment | | name | varchar(32) | YES | | | | | views | int(11) | NO | | 0 | | | created_at | datetime | YES | | NULL | | +------------+-------------+------+-----+---------+----------------+