MySQL数据库与表的创建、修改与删除
一、数据库的创建、修改、删除操作
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 表名
使用示例如下图:
- 数据库中表的创建语法格式 方式二:
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语句不仅可以查看表创建时的详细语句,还可以查看存储引擎和字符编码。如下图:
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
- 在MySQL中,当一张数据表 没有与其他任何数据表形成关联关系 时,可以将当前数据表直接删除。
- 数据和结构都被删除
- 所有正在运行的相关事务被提交
- 所有相关索引被删除
语法格式: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 语句相同。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?