MySQL之创建和管理数据库/表操作(DDL)

前言

我们知道在MySQL中SQL语句有三种分类,分别是:

DDL:数据定义语言。CREATE \ ALTER \ DROP \ RENAME \ TRUNCATE
一般用于:创建、删除、修改数据库和数据表的结构

DML:数据操作语言。INSERT \ DELETE \ UPDATE \ SELECT (重中之重)
一般用于:添加、删除、更新和查询数据库记录

DCL数据控制语言。COMMIT \ ROLLBACK \ SAVEPOINT \ GRANT \ REVOKE
一般用于:定义数据库、表、字段的访问权限和安全级别

关于常见的增删改查(DML)这里就不介绍,该篇文章主要记录MySQL中对数据库和表的操作,不多说,直接上干货。

文章目录

  • 前言
  • 1、创建和管理数据库
    • 1.1、创建数据库
    • 1.2、使用数据库
    • 1.3、修改数据库
  • 2、创建表
  • 3、修改表
    • 3.1、新增列
    • 3.2、修改列
    • 3.3、重命名列
    • 3.4、删除一个列
  • 4、重命名表
  • 5、删除表
  • 6、清空表
  • 总结


1、创建和管理数据库

1.1、创建数据库

总共有三种方式创建数据库,推荐方式三

# 方式1:创建数据库
CREATE DATABASE 数据库名;

# 方式2:创建数据库并指定字符集
CREATE DATABASE 数据库名 CHARACTER SET 字符集;

# 方式3:判断数据库是否已经存在,不存在则创建数据库( 推荐 )
CREATE DATABASE IF NOT EXISTS 数据库名;

1.2、使用数据库

# 查看当前所有的数据库 
SHOW DATABASES;  #有一个S,代表多个数据库

# 查看当前正在使用的数据库
SELECT DATABASE(); #使用的一个 mysql 中的全局函数

# 查看指定库下所有的表
SHOW TABLES FROM 数据库名;

# 查看数据库的创建信息
SHOW CREATE DATABASE 数据库名;

# 使用/切换数据库
USE 数据库名;

1.3、修改数据库

  • 更改数据库字符集
ALTER DATABASE 数据库名 CHARACTER SET 字符集; #比如:gbk、utf8等
  • 删除指定的数据库
# 方式1
DROP DATABASE 数据库名;

#方式2( 推荐 )
DROP DATABASE IF EXISTS 数据库名;

2、创建表

创建方式1

语法格式

CREATE TABLE [IF NOT EXISTS] 表名(
    字段1, 数据类型 [约束条件] [默认值],
    字段2, 数据类型 [约束条件] [默认值],
    字段3, 数据类型 [约束条件] [默认值],
    ……
    [表约束条件]
)

示例

CREATE TABLE dept(
    -- int类型,自增
    deptno INT(2) AUTO_INCREMENT,
    dname VARCHAR(14),
    loc VARCHAR(13),
    -- 主键
    PRIMARY KEY (deptno)
);

创建方式2
使用 AS subquery 选项,将创建表和插入数据结合起来

举例

# 举例1
CREATE TABLE emp1 
AS 
SELECT * FROM employees; -- 创建的emp1表自带这里所有的数据

# 举例2
CREATE TABLE emp2 
AS 
SELECT * FROM employees 
WHERE 1=2; -- 创建的emp2表是空表(因为1永远不可能等于2)

查看数据表结构

SHOW CREATE TABLE 表名

3、修改表

3.1、新增列

# 语法格式
ALTER TABLE 表名 
ADD 【COLUMN】 字段名 字段类型 【FIRST|AFTER 字段名】;

# 举例
ALTER TABLE dept80
ADD job_id varchar(15);


3.2、修改列

# 语句发个
ALTER TABLE 表名 
MODIFY 【COLUMN】 字段名1 字段类型 【DEFAULT 默认值】【FIRST|AFTER 字段名2】;


# 举例1
ALTER TABLE dept80
MODIFY last_name VARCHAR(30);

# 举例2
ALTER TABLE dept80
MODIFY salary double(9,2) default 1000; -- 修改列的同时给定默认值
# 注意:对默认值的修改只影响今后对表的修改



3.3、重命名列

# 语法格式
ALTER TABLE 表名 
CHANGE 【column】 列名 新列名 新数据类型;

# 举例
# 将 dept80表中的 department_name 列名改为 dept_name
ALTER TABLE dept80
CHANGE department_name dept_name varchar(15);

3.4、删除一个列

# 语法格式
ALTER TABLE 表名 DROP 【COLUMN】字段名

# 举例
ALTER TABLE dept80
DROP COLUMN job_id;

4、重命名表

重命名表有两种方式

# 方式一:使用RENAME(推荐)
RENAME TABLE emp TO myemp;  
# emp 旧表名      myemp 新表名      


# 方式二:
ALTER table dept
RENAME [TO] detail_dept; -- [TO]可以省略

5、删除表

# 语法格式
DROP TABLE [IF EXISTS] 数据表1 [, 数据表2, …, 数据表n];

# 举例
DROP TABLE t_user;

注意:DROP TABLE语句不能回滚

准确的说:DDL语句都不能回滚

6、清空表

清空表数据有两种方式

# 方式1
TRUNCATE TABLE emp2;

# 方式2
DELETE FROM emp2;

TRUNCATE语句不能回滚,而使用 DELETE 语句删除数据,可以回滚

阿里开发规范: 【参考】TRUNCATE TABLE 比 DELETE 速度快,且使用的系统和事务日志资源少,但 TRUNCATE 无 事务且不触发 TRIGGER,有可能造成事故,故不建议在开发代码中使用此语句。 说明:TRUNCATE TABLE 在功能上与不带 WHERE 子句的 DELETE 语句相同。

也就是说,虽然TRUNCATE速度快一点,但是有可能造成事故,所以还是推荐使用:DETELE FROM来清空表数据


总结

因为关于DDL的操作也只有在项目刚启动的时候用得到,中后期用的基本就很少了,所以很容易忘记,该篇文章就适合不记得的时候拿出来快速的查看一下,简单明了。

你可能感兴趣的:(MySQL,数据库,mysql,database)