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 小时前
超自动化运维如何重塑IT组织的核心竞争力?
运维·服务器·网络·数据库·人工智能·自动化
m0_716430071 小时前
mysql表锁监控命令_诊断MyISAM表锁定问题的方法
jvm·数据库·python
毅炼1 小时前
MyBatis 常见问题总结
java·数据库·sql·mybatis
qq_334563551 小时前
开发者工具怎么看HTML_Elements面板使用指南【操作】
jvm·数据库·python
m0_716430071 小时前
c++怎么读取安卓系统Assets目录下的资源文件流数据【实战】
jvm·数据库·python
大江东去浪淘尽千古风流人物1 小时前
【DROID-W】WildGS-SLAM
数据库·人工智能·python·oracle·augmented reality
zhangchaoxies1 小时前
C#怎么实现MVVM模式 C#如何在WPF中使用MVVM设计模式分离视图和逻辑【架构】
jvm·数据库·python
吕源林1 小时前
防止SQL注入的应用层过滤_采用成熟的安全过滤中间件
jvm·数据库·python
m0_747854521 小时前
Go语言如何做图算法_Go语言图算法实现教程【对比】
jvm·数据库·python