MySQL常用SQL语句(持续更新中)

文章目录

收录一些经常用到的sql

数据库相关

建数据库

sql 复制代码
CREATE DATABASE [IF NOT EXISTS] <数据库名> [[DEFAULT] CHARACTER SET <字符集名>] [[DEFAULT] COLLATE <校对规则名>];

例如:

CREATE DATABASE IF NOT EXISTS test_db DEFAULT CHARACTER SET utf8mb4 DEFAULT COLLATE utf8mb4_general_ci;

表相关

建表

sql 复制代码
DROP TABLE IF EXISTS `test_table`;
CREATE TABLE `test_table`(
    id int(11) AUTO_INCREMENT PRIMARY KEY NOT NULL,
    name varchar(50),
    length decimal(5, 2),
    UNIQUE INDEX length(id ASC)
) ENGINE = InnoDB DEFAULT CHARSET=utf8;

索引相关

添加索引

添加PRIMARY KEY主键索引

sql 复制代码
ALTER TABLE `table_name` ADD PRIMARY KEY ( `column` ) 

添加UNIQUE唯一索引

sql 复制代码
ALTER TABLE `table_name` ADD UNIQUE (`column` ) 

添加普通索引

sql 复制代码
ALTER TABLE `table_name` ADD INDEX index_name ( `column` ) 

添加FULLTEXT全文索引

sql 复制代码
ALTER TABLE `table_name` ADD FULLTEXT ( `column`) 

添加多列索引

sql 复制代码
ALTER TABLE `table_name` ADD INDEX index_name ( `column1`, `column2`, `column3` )

编码相关

查看数据库编码。

sql 复制代码
SHOW variables LIKE '%char%';

查看表编码

sql 复制代码
SHOW CREATE TABLE <表名>;

查看字段编码

sql 复制代码
mysql> SHOW FULL COLUMNS FROM t_user;
+--------+-------------+-----------------+------+-----+---------+----------------+---------------------------------+-----------+
| Field  | Type        | Collation       | Null | Key | Default | Extra          | Privileges                      | Comment   |
+--------+-------------+-----------------+------+-----+---------+----------------+---------------------------------+-----------+
| ID     | int         | NULL            | NO   | PRI | NULL    | auto_increment | select,insert,update,references | 主键      |
| NAME   | varchar(64) | utf8_general_ci | YES  |     | NULL    |                | select,insert,update,references | 名字      |
| GENDER | varchar(5)  | utf8_general_ci | YES  | MUL | NULL    |                | select,insert,update,references | 性别      |
| MOBILE | varchar(11) | utf8_general_ci | YES  | MUL | NULL    |                | select,insert,update,references | 手机号    |
+--------+-------------+-----------------+------+-----+---------+----------------+---------------------------------+-----------+
4 rows in set (0.00 sec)

修改编码格式

修改数据库编码格式

alter database <数据库名> character set utf8mb4;

例:alter database db_user character set utf8mb4;

修改表编码

alter table <表名> character set utf8mb4;

例:alter table user character set utf8mb4;

修改字段编码

sql 复制代码
ALTER TABLE <表名> MODIFY COLUMN <字段名> <字段类型> CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;
例:ALTER TABLE comment MODIFY COLUMN content VARCHAR(512) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;

系统变量相关

查询数据目录:SHOW VARIABLES LIKE 'datadir';

相关推荐
骄马之死12 分钟前
缓存与数据库一致性的核心方案
mysql·缓存
我叫张小白。23 分钟前
基于Redis的缓存架构与一致性保障体系
数据库·redis·缓存·架构
Omics Pro27 分钟前
基因泰克:检测级虚拟细胞基准!大语言模型+智能体
大数据·数据库·人工智能·机器学习·语言模型·自然语言处理·r语言
Quincy_Freak29 分钟前
工具分享|基于 SQLiteGo 的国产系统离线数据处理方案
大数据·数据库·数据分析·arm·国产系统·银河麒麟·aarch64
我是一颗柠檬41 分钟前
【Redis】数据类型详解Day2(2026年)
数据库·redis·后端·缓存
Trouvaille ~1 小时前
【Redis篇】List 列表:双端队列与消息队列的完美实现
数据库·redis·list·双端队列·后端开发·quicklist·zoplist
Cloud_Shy6181 小时前
解读《Effective Python 3rd Edition》:从练气到老魔(第一章 Item 4 - 6)
android·数据库·论文阅读·python
土狗TuGou1 小时前
SQL内功笔记 · 第7篇:CTE&临时表&递归
数据库·笔记·后端·sql·mysql
XiYang-DING1 小时前
【Spring】日志
java·数据库·spring
我是唐青枫1 小时前
MySQL EXISTS 详解:存在性判断、NOT EXISTS 与实战示例
数据库·mysql