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