MySQL--表的操作

创建表

语法:

复制代码
CREATE TABLE table_name(
    field1 datatype,
    field2 datatype,
    field3 datatype
)character set 字符集 collate 校验规则 engine 存储引擎;

CREATE TABLE: SQL关键字,表示创建表
table_name: 要创建的表的名称
field1, field2, field3: 表中的列(字段)名
**datatype:**每个字段的数据类型(如 INT, VARCHAR(255), DATE 等)

character set: 指定表中文本数据使用的字符编码
常见字符集: utf8, utf8mb4, gbk, latin1等例如 utf8mb4支持完整的Unicode(包括emoji表情)
**collate:**指定字符串比较和排序的规则,例如 utf8mb4_general_ci(不区分大小写,通用规则),例如 utf8mb4_bin(二进制比较,区分大小写),例如 utf8mb4_unicode_ci(基于Unicode标准的排序)

创建表案例

复制代码
create table users(
    id int,
    name varchar(20) comment'用户名',
    password char(32) comment'密码',
    birthday date comment'生日',
   )character set utf8 engine MyISAM;

查看表结构

语法

复制代码
desc 表名;

示例

复制代码
desc users;

修改表

在项目实际开发中,经常修改某个表的结构,比如字段名字,字段大小,字段类型,表的字符集类型, 表的存储引擎等等。我们还有需求,添加字段,删除字段等等。这时我们就需要修改表。

添加列

复制代码
ALTER TABLE users
ADD COLUMN phone VARCHAR(20) AFTER email;

案例

在user表添加两条记录

复制代码
insert into users values(1,'a','b','2006-08-08'),(2,'b','c','2006-05-06');

修改列

复制代码
-- 修改数据类型
ALTER TABLE users
MODIFY COLUMN username VARCHAR(100);

--修改列名
ALTER TABLE users
CHANGE COLUMN email user_email VARCHAR(100);

删除列

复制代码
ALTER TABLE users
DROP COLUMN phone;

删除表

复制代码
--安全删除
DROP TABLE IF EXISTS table_name;

--强制删除
SET FOREIGN_KEY_CHECKS = 0;
DROP TABLE table_name;
SET FOREIGN_KEY_CHECKS = 1;

清空表

复制代码
-- 快速清空(不能回滚)
TRUNCATE TABLE table_name;

-- 与 DELETE 的区别
DELETE FROM table_name;  -- 逐行删除,可回滚
TRUNCATE TABLE table_name;  -- 直接删除数据文件,速度快

重命名表

复制代码
-- 单个表重命名
RENAME TABLE old_name TO new_name;

-- 批量重命名
RENAME TABLE
    table1 TO new_table1,
    table2 TO new_table2;

复制表

复制代码
--仅复制结构
CREATE TABLE new_table LIKE old_table;
--复制结构+数据
CREATE TABLE new_table AS 
SELECT * FROM old_table;
--部分复制
CREATE TABLE active_users AS
SELECT id, username, email
FROM users
WHERE status = 'active';
相关推荐
阿波罗尼亚6 小时前
数据库序列(Sequence)
数据库
Junsir大斗师6 小时前
Nginx服务器代理Postgresql-16后端数据库
数据库·nginx
Je1lyfish6 小时前
CMU15-445 (2025 Fall/2026 Spring) Project#3 - QueryExecution
linux·c语言·开发语言·数据结构·数据库·c++·算法
m0_596749098 小时前
如何防止SQL拼接漏洞_使用PDO对象实现安全的SQL交互
jvm·数据库·python
老纪的技术唠嗑局9 小时前
深度解析 LLM Wiki / Obsidian-Wiki / GBrain:Agent 时代知识的“自组织”与“自进化”
大数据·数据库·人工智能·算法
2301_7950997411 小时前
golang如何在Gin中自定义验证器_golang Gin自定义验证器实现方法
jvm·数据库·python
2301_7662834411 小时前
如何在MongoDB GridFS中进行按文件大小(length)范围的查询
jvm·数据库·python
布吉岛的石头11 小时前
分库分表实战:Sharding-JDBC 快速落地
分布式·mysql
冬天vs不冷12 小时前
面试必知必会(13):MySQL锁机制
mysql·面试·职场和发展
冬天vs不冷12 小时前
面试必知必会(14):MySQL执行计划与SQL优化
sql·mysql·面试