前面的文章一直都在讲述关于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] ...