SQL学习之alter table语句

参考源

SQL alter table 语句

SQL alter talbe 语句用于向已有的表中添加、删除或修改列 ( 字段 )

  1. 向表中添加列

    ALTER TABLE table_name ADD [COLUMN] column_name data_type
    
  2. 删除表中的列

    ALTER TABLE table_name DROP [COLUMN] column_name
    
  3. 修改表中列的数据类型
    SQL Server / MS Access

    ALTER 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 基本使用

  1. 添加列

    如果我们想给表添加一列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  |      |
    +----+---------------------+-------+---------------------+------+
    
  2. 修改字段

    一般情况下 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    |                |
    +------------+-------------+------+-----+---------+----------------+
    
  3. 删除列

    如果要删除 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    |                |
    +------------+-------------+------+-----+---------+----------------+
    
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值