一、数据库的创建、修改、删除操作

1.1 数据库标识符命名规则

  • 数据库名、表名不得超过30个字符,变量名限制为29个
  • 必须只能包含 A–Z, a–z, 0–9, _共63个字符
  • 数据库名、表名、字段名等对象名中间不要包含空格
  • 同一个MySQL软件中,数据库不能同名;同一个库中,表不能重名;同一个表中,字段不能重名必须保证你的字段没有和保留字、数据库系统或常用方法冲突。如果坚持使用,请在SQL语句中使用`(着重号)引起来
  • 保持字段名和类型的一致性:在命名字段并为其指定数据类型的时候一定要保证一致性,假如数据类型在一个表里是整数,那在另一个表里可就别变成字符型了      

1.2 创建数据库

方式1:创建数据库

CREATE DATABASE 数据库名;

 方式2:创建数据库并指定字符集

CREATE DATABASE 数据库名 CHARACTER SET 字符集;

 方式3:判断数据库是否已经存在,不存在则创建数据库( 推荐 )

CREATE DATABASE IF NOT EXISTS 数据库名 CHARACTER SET 字符集;
#如果MySQL中已经存在相关的数据库,则忽略创建语句,不再创建数据库。

数据库创建后,可以使用以下方式查看数据库的相关信息

  • 查看当前所有的数据库
SHOW DATABASES; #有一个S,代表多个数据库
  • 查看当前正在使用的数据库 
SELECT DATABASE(); #使用的一个 mysql 中的全局函数
  • 查看指定库下所有的表
SHOW TABLES FROM 数据库名;
  • 查看数据库的创建信息
SHOW CREATE DATABASE 数据库名;
或者:
SHOW CREATE DATABASE 数据库名\G
  • 使用/切换数据库
USE 数据库名;

注意:要操作表格和数据之前必须先说明是对哪个数据库进行操作,否则就要对所有对象加上“数
据库名.”,即下面这种方式。

#假设有一个数据库为database_test,现要在此库中创建一个表
CREATE TABLE `database_test`.`user_tb`(
	id BIGINT(15) PRIMARY KEY AUTO_INCREMENT COMMENT '账号主键id',
	...
	yn TINYINT(1) NOT NULL DEFAULT '1' COMMENT '是否有效'
	
)
ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='测试表';

 1.3 修改数据库 

  • 更改数据库字符集
ALTER DATABASE 数据库名 CHARACTER SET 字符集; #比如:gbk、utf8等

1.4 删除数据库

注意:删除数据库操作会将数据库中的所有表和数据删掉,请谨慎操作

  • 方式1:删除指定的数据库 
DROP DATABASE 数据库名;
  • 方式2:删除指定的数据库( 推荐 ) 
DROP DATABASE IF EXISTS 数据库名;

二、表(TABLE) 的创建、修改、删除操作

2.1 表的创建-- create Table

想要创建表其必须要有对应的权限

  • 数据库中表的创建语法格式 方式一:
CREATE TABLE [IF NOT EXISTS] 表名(
字段1, 数据类型 [约束条件] [默认值],
字段2, 数据类型 [约束条件] [默认值],
字段3, 数据类型 [约束条件] [默认值],
……
[表约束条件]
);

提示:加上了IF NOT EXISTS关键字,则表示:如果当前数据库中不存在要创建的数据表,则创建数据表;
如果当前数据库中已经存在要创建的数据表,则忽略建表语句,不再创建数据表。

  创建表的简单举例示例如下:

-- 创建表
CREATE TABLE emp (
emp_id INT,-- int类型
emp_name VARCHAR(20),-- 最多保存20个中英文字符
salary DOUBLE,-- 总位数不超过15位
birthday DATE -- 日期类型
);
  • 查看表的信息
DESC 表名

使用示例如下图:

mysql建表时给表指定中文名 mysql创建中文名数据库_mysql建表时给表指定中文名

 

  • 数据库中表的创建语法格式 方式二:
CREATE TABLE 表名 [字段1,字段2,...]
AS 
SELECT 字段1,字段2,... 
FROM 其他表名
[WHERE 条件]
;

CREATE TABLE emp2 AS SELECT * FROM employees WHERE 1=2; -- 创建的emp2是空表

此方式是将创建表和插入数据结合起来 ,即创建的表结构使用查询表对应的查询字段的结构定义,且将对应查处的数据插入到新创建的表中

 注意:

  • 当创建的表有明确的字段时,其指定的列和子查询中的列要一一对应
  • 通过列名和默认值定义列

 简单使用示例:

CREATE TABLE dept80
AS
SELECT employee_id, last_name, salary*12 ANNSAL, hire_date
FROM employees
WHERE department_id = 80;
-- 此语句会创建一个dept80的一张新表,并将employee_id, last_name, salary*12 ANNSAL, hire_date这写查询的列作为自己的列,且对应的类型和约束一致
-- 并会将employees表中department_id = 80的数据插入到表dept80中
  • 查看数据表结构

在MySQL中创建好数据表之后,可以查看数据表的结构。MySQL支持使用 DESCRIBE/DESC 语句查看数据
表结构,也支持使用 SHOW CREATE TABLE

语法格式如下:SHOW CREATE TABLE 表名\G 

提示:使用SHOW CREATE TABLE语句不仅可以查看表创建时的详细语句,还可以查看存储引擎和字符编码。如下图:

mysql建表时给表指定中文名 mysql创建中文名数据库_mysql建表时给表指定中文名_02

2.2 修改表 -- ALTER TABLE

修改表指的是修改数据库中已经存在的数据表的结构。

使用 ALTER TABLE 语句可以实现:

  • 向已有的表中添加列
  • 修改现有表中的列
  • 删除现有表中的列
  • 重命名现有表中的列

   1.向表中追加一个列 ,语法格式:

ALTER TABLE 表名 ADD 【COLUMN】 字段名 字段类型 【FIRST|AFTER 字段名】 ;
或
ALTER TABLE `数据库名.表名` ADD 【COLUMN】 字段名 字段类型 【FIRST|AFTER 字段名】[COMMENT 列的表述] ;

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

  2. 修改表中的一个列,语法:

 具体可以修改列的数据类型长度默认值位置,对默认值的修改只影响今后对表的修改,此外,还可以通过此种方式修改列的约束 

ALTER TABLE `数据库名.表名` MODIFY 【COLUMN】 字段名1 字段类型 【DEFAULT 默认值】【FIRST|AFTER 字段名2】 [COMMENT 描述];

-- 示例:
ALTER TABLE dept80
MODIFY last_name VARCHAR(30) default 'AA';

 3.重命名一个列

使用 CHANGE old_column new_column dataType子句重命名列。语法格式如下:

ALTER TABLE 表名 CHANGE 【column】 列名 新列名 新数据类型; [COMMENT 描述];

-- 举例
ALTER TABLE dept80
CHANGE department_name dept_name varchar(15);

  4.删除表中的一个列,语法:

-- 删除表中某个字段的语法格式如下:(谨慎操作)
ALTER TABLE 表名 DROP 【COLUMN】字段名

-- 举例
ALTER TABLE dept80
DROP COLUMN job_id;

   5.重命名表

-- 方式一:使用RENAME
RENAME TABLE 表名 TO 新表名;


--方式二
ALTER table 表名 RENAME [TO] 新表名; -- [TO]可以省略

 2.3.删除表 -- DROP TABLE 

  • 没有与其他任何数据表形成关联关系
  • 数据和结构都被删除
  • 所有正在运行的相关事务被提交
  • 所有相关索引被删除

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

提示: IF EXISTS 的含义为:如果当前数据库中存在相应的数据表,则删除数据表;如果当前数据库中不存
在相应的数据表,则忽略删除语句,不再执行删除数据表的操作。 

注意:DROP TABLE 语句不能回滚

 2.4清空表中的数据 -- TRUNCATE TABLE 或 DELETE TABLE 

  • TRUNCATE语句不能回滚,而使用 DELETE 语句删除数据,可以回滚  
  • TRUNCATE TABLE语句:删除表中所有的数据并 释放表的存储空间

方式一TRUNCATE:语法格式:TRUNCATE TABLE 表名

TRUNCATE TABLE detail_dept;

方式二DELETE:语法格式:DELETE FROM 表名 [WHERE 条件];

DELETE FROM emp2; -- 删除所有数据
或
DELETE FROM emp2 where 条件;

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