SQL系列(十三)—— 关于表的DDL

前面的文章一直都在讲述关于DML方面的SQL Statement。这篇文章来说说表方面的DDL:

  • CREATE 创建表
  • ALTER 修改表
  • DROP 删除表
CREATE
1.语法
CREATE TABLE [IF NOT EXISTS] table_name (
    column1_name 类型,
    column2_name 类型,
    [UNIQUE|FULLTEXT|SPATIAL] INDEX index_name (columnJ[length][ASC|DESC]),
    [CONSTRAINT constraint_name PRIMARY KEY (columnJ,...)],
    [CONSTRAINT constraint_name FOREIGN KEY (columnJ,...) REFERENCES talbe_name (columnK,...)]
) [COMMENT "xxxx"];

大致的语法如上,对于不同的数据库的CREATE语法还不尽相同,有特定的参数。比如Mysql中可以创建表时,指定字符编码、存储引擎等。

2.示例
CREATE TABLE IF NOT EXISTS student (
    id varchar(18) NOT NULL UNIQUE,
    name varchar(10) NOT NULL,
    INDEX idx_name (name(5) DESC),
    PRIMARY KEY (id);
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT "学生表";


ALTER
1.语法
-- 增加表列、索引
ALTER TABLE table_name
    ADD [COLUMN] cloumnJ 类型,
    ADD {INDEX|KEY} index_name (columnJ[length][ASC|DESC]);

-- 删除表的列、索引、主键、外键
ALTER TABLE table_name
    DROP [COLUMN] cloumnJ,
    ADD {INDEX|KEY} index_name,
    DROP PRIMARY KEY,
    DROP FOREIGN KEY fk_symbol;

修改表非常复杂,不同的数据库也不一样,不过大多数情况下可以参考文档,如Mysql可以参考:
Data Definition Statements

2.示例
ALTER TABLE student ADD COLUMN age smallint NOT NULL;


DROP
1.语法
DROP TABLE [IF EXISTS] table_name [, tbl_name] ...

转载于:https://www.cnblogs.com/lxyit/p/9342638.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值