创建表
语法:
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';