数据库 SQL DDL DATABASE TABLE VIEW INDEX 约束
DDL 的主要功能是定义数据库对象(如:数据库、数据表、视图、索引等)。

数据库(DATABASE)

创建数据库

  1. CREATE DATABASE test;

删除数据库

  1. DROP DATABASE test;

选择数据库

  1. USE test;

数据表(TABLE)

创建数据表

普通创建

  1. CREATE TABLE user (
  2. id int(10) unsigned NOT NULL COMMENT 'Id',
  3. username varchar(64) NOT NULL DEFAULT 'default' COMMENT '用户名',
  4. password varchar(64) NOT NULL DEFAULT 'default' COMMENT '密码',
  5. email varchar(64) NOT NULL DEFAULT 'default' COMMENT '邮箱'
  6. ) COMMENT='用户表';

根据已有的表创建新表

  1. CREATE TABLE vip_user AS
  2. SELECT * FROM user;

删除数据表

  1. DROP TABLE user;

修改数据表

添加列

  1. ALTER TABLE user
  2. ADD age int(3);

删除列

  1. ALTER TABLE user
  2. DROP COLUMN age;

修改列

  1. ALTER TABLE `user`
  2. MODIFY COLUMN age tinyint;

添加主键

  1. ALTER TABLE user
  2. ADD PRIMARY KEY (id);

删除主键

  1. ALTER TABLE user
  2. DROP PRIMARY KEY;

视图(VIEW)

  • 定义
    • 视图是基于 SQL 语句的结果集的可视化的表。
    • 视图是虚拟的表,本身不包含数据,也就不能对其进行索引操作。对视图的操作和对普通表的操作一样。
  • 作用
    • 简化复杂的 SQL 操作,比如复杂的联结;
    • 只使用实际表的一部分数据;
    • 通过只给用户访问视图的权限,保证数据的安全性;
    • 更改数据格式和表示。

创建视图

  1. CREATE VIEW top_10_user_view AS
  2. SELECT id, username
  3. FROM user
  4. WHERE id < 10;

删除视图

  1. DROP VIEW top_10_user_view;

索引(INDEX)

  • 作用
    • 通过索引可以更加快速高效地查询数据。
    • 用户无法看到索引,它们只能被用来加速查询。
  • 注意
    • 更新一个包含索引的表需要比更新一个没有索引的表花费更多的时间,这是由于索引本身也需要更新。因此,理想的做法是仅仅在常常被搜索的列(以及表)上面创建索引。
  • 唯一索引
    • 唯一索引表明此索引的每一个索引值只对应唯一的数据记录。

创建索引

  1. CREATE INDEX user_index
  2. ON user (id);

创建唯一索引

  1. CREATE UNIQUE INDEX user_index
  2. ON user (id);

删除索引

  1. ALTER TABLE user
  2. DROP INDEX user_index;

约束

SQL 约束用于规定表中的数据规则。

  • 如果存在违反约束的数据行为,行为会被约束终止。
  • 约束可以在创建表时规定(通过 CREATE TABLE 语句),或者在表创建之后规定(通过 ALTER TABLE 语句)。
  • 约束类型
    • NOT NULL - 指示某列不能存储 NULL 值。
    • UNIQUE - 保证某列的每行必须有唯一的值。
    • PRIMARY KEY - NOT NULL 和 UNIQUE 的结合。确保某列(或两个列多个列的结合)有唯一标识,有助于更容易更快速地找到表中的一个特定的记录。
    • FOREIGN KEY - 保证一个表中的数据匹配另一个表中的值的参照完整性。
    • CHECK - 保证列中的值符合指定的条件。
    • DEFAULT - 规定没有给列赋值时的默认值。

创建表时使用约束条件:

  1. CREATE TABLE Users (
  2. Id INT(10) UNSIGNED NOT NULL AUTO_INCREMENT COMMENT '自增Id',
  3. Username VARCHAR(64) NOT NULL UNIQUE DEFAULT 'default' COMMENT '用户名',
  4. Password VARCHAR(64) NOT NULL DEFAULT 'default' COMMENT '密码',
  5. Email VARCHAR(64) NOT NULL DEFAULT 'default' COMMENT '邮箱地址',
  6. Enabled TINYINT(4) DEFAULT NULL COMMENT '是否有效',
  7. PRIMARY KEY (Id)
  8. ) ENGINE=InnoDB AUTO_INCREMENT=2 DEFAULT CHARSET=utf8mb4 COMMENT='用户表';