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';
相关推荐
倔强的石头_1 天前
《Kingbase护城河》——数据库存储空间全景探测与精细化瘦身实战
数据库
云技纵横1 天前
唯一索引 INSERT 死锁实战:5 秒复现交叉插入的 S 锁循环等待
sql·mysql
沉默王二1 天前
面试官:RAG 不用向量数据库,用 MySQL 硬扛?我:100 万向量不是很轻松?
mysql·面试·ai编程
冬奇Lab2 天前
每日一个开源项目(第134篇):Zvec - 阿里开源的嵌入式向量数据库,向量搜索界的 SQLite
数据库·人工智能·llm
小猿姐2 天前
MySQL Top 10 热点问题 AI 运维实战:从内核诊断到云原生运维
mysql·云原生·aiops
ClouGence2 天前
Oracle CDC 架构优化:从主库直连到 DataGuard 备库同步
数据库·后端·oracle
云技纵横2 天前
Gap Lock 死锁实战:5 秒在本地复现 MySQL 间隙锁死锁
后端·mysql
无响应de神2 天前
三、用户与权限管理
数据库·mysql
摇滚侠3 天前
Linux CentOS7 rpm 安装 MySQL 5.7
linux·运维·mysql