百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

mysql常用语句超级详细汇总(mysql常用语法)

nanshan 2025-07-01 22:14 4 浏览 0 评论

1.连接数据库:

连接本地数据库:

mysql -u root -p

连接远程数据库:

mysql -h 192.169.22.199 -u root -p

退出数据库:

exit

2.创建数据库:

create database payment;

使用 mysqladmin 创建数据库

mysqladmin -u root -p create abc_db;

3.显示所有数据库:

show databases;

4.删除数据库:

drop database payment;

使用 mysqladmin 删除数据库

mysqladmin -u root -p drop abc_db

5.选择数据库:

use home_db;

6.数据类型:

数值类型:

TINYINT:
SMALLINT:
MEDIUMINT:
INT(INTEGER):
BIGINT:
FLOAT:
DOUBLE:
DECIMAL:

日期和时间类型:

DATE:
TIEM:
DATETIME:
YEAR:
TIMESTAMP:

字符串类型:

CHAR:
VARCHAR:
TINYBLOB:
TINYTEXT:
BLOB:
TEXT:
MEDIUMBLOB:
MEDIUMTEXT:
LONGBLOB:
LONGTEXT:

7.创建数据表:

CREATE TABLE IF NOT EXISTS `t_order`(
`id` INT(10) UNSIGNED AUTO_INCREMENT,
`title` VARCHAR(100) NOT NULL,
PRIMARY KEY(`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

8.删除数据表:

DROP TABLE t_order;

9.insert 插入:

插入一条数据:

INSERT INTO t_order(title)VALUES('手机');

INSERT 插入多条数据:

INSERT INTO t_order(title)VALUES('笔记本'),('平板电脑');

10.select 查询:

所有字段查询:

SELECT * FROM t_order;

某些字段查询:

SELECT t_order.id, t_order.title FROM t_order;

分页查询:

SELECT t_order.title FROM t_order WHERE id LIMIT 1,10

11.where 条件:

OR,AND的应用:

SELECT * FROM t_order WHERE title ='手机' OR title='笔记本';
SELECT * FROM t_order WHERE title ='手机' AND id=2;

12.update 更新:

UPDATE t_order SET title='苹果手机' WHERE id =2;

13.delete 删除:

DELETE FROM t_order WHERE id=2;

14.like 查询

SELECT * FROM t_order WHERE title LIKE '%手机%';
SELECT * FROM t_order WHERE title LIKE '_机';

14.union 联合查询:

连接两个以上的 SELECT 语句合并成一个结果集合

SELECT * FROM t_order UNION SELECT * FROM t_user;
SELECT * FROM t_order UNION ALL SELECT * FROM t_user;

15.order by 排序:

升序排序:

SELECT * FROM t_order ORDER BY id ASC;

降序排序:

SELECT * FROM t_order ORDER BY id DESC;

16.group by 分组:

SELECT title, count(*) as total FROM t_order GROUP BY title;

17.join 连接:

inner join(内连接) on:
获取两个表中字段匹配关系的记录

SELECT * FROM t_order o INNER JOIN t_user u ON o.id =u.id;

left join(左连接)on:
获取左表所有记录,即使右表没有对应匹配的记录

SELECT * FROM t_order o LEFT JOIN t_user u ON o.id =u.id;

right join(右连接)on:
获取右表所有记录,即使左表没有对应匹配的记录

SELECT * FROM t_order o RIGHT JOIN t_user u ON o.id =u.id;

18.null的处理:

null值的判断:

SELECT * FROM t_user WHERE name IS NULL;

非null值的判断:

SELECT * FROM t_user WHERE name IS NOT NULL;

19.REGEXP 正则表达式:

SELECT * FROM t_order WHERE title REGEXP('手机#39;);
SELECT * FROM t_order WHERE title REGEXP('^笔');

表达式的操作符:
^:匹配字符串的开始位置
$:匹配字符串的结束位置
.:匹配除 "\n" 之外的任何单个字符
[...]:匹配所包含的任意一个字符
[^...]:匹配未包含的任意字符
w1|w2|w3:匹配 w1 或 w2 或 w3
*:匹配零次或多次
+:匹配一次或多次
{n}:匹配 n 次
{n,m}:最少匹配 n 次,并且最多匹配 m 次

20.事务:

BEGIN:开启一个事务
COMMIT:事务确认
ROLLBACK:事务回滚
SAVEPOINT:
RELEASE SAVEPOINT:
ROLLBACK TO:
SET:用来设置事务的隔离级别。InnoDB 存储引擎提供事务的隔离级别:
READ UNCOMMITTED、
READ COMMITTED、
REPEATABLE READ、
SERIALIZABLE。

21.ALTER 修改命令:
添加一个字段:

ALTER TABLE t_user ADD COLUMN `password` VARCHAR(64) NOT NULL;

修改一个字段:

MODIFY:
ALTER TABLE t_user MODIFY COLUMN password CHAR(10) DEFAULT '0' ;
CHANGE:
ALTER TABLE t_user CHANGE `password` `user_password` VARCHAR(10) NOT NULL;

modify和change都是只能修改相同的类型,不同的类型,如char不能改成integer。change可以修改字段名,modify不能修改字段名。

修改字段默认值:

ALTER TABLE t_user ALTER `user_password` SET DEFAULT '0';

删除一个字段:

ALTER TABLE t_user DROP password;

修改字段名称:

ALTER TABLE t_user CHANGE `password` `user_password` VARCHAR(10) NOT NULL;

指定添加字段的位置:
加字段放在某个字段之后:

ALTER TABLE t_sys_user ADD COLUMN `marker` VARCHAR(20) DEFAULT NULL AFTER `name`;

加字段放在第一位:

ALTER TABLE t_sys_user ADD COLUMN `alt` VARCHAR(20) DEFAULT NULL FIRST;

修改表名:

ALTER TABLE t_user RENAME TO `t_sys_user`;
RENAME TABLE t_sys_user TO t_user;

显示表的所有列的信息:

SHOW COLUMNS FROM t_order;
DESC t_order;

显示表的创建语句:

SHOW CREATE TABLE t_order;

修改表的存储引擎:

ALTER TABLE t_sys_user engine=InnoDB;

22.索引:
添加索引:
添加普通索引:

CREATE INDEX nameIndex ON t_user(`name`);
ALTER TABLE t_user ADD INDEX nameIndex(`name`);
CREATE TABLE `t_product`(
`id` INTEGER UNSIGNED NOT NULL AUTO_INCREMENT,
`name` VARCHAR(20) NOT NULL,
`title` VARCHAR(20) NOT NULL,
`description` VARCHAR(100) DEFAULT NULL,
PRIMARY KEY(`id`),
INDEX name_index(`name`)
)

添加唯一索引:

CREATE UNIQUE INDEX nameIndex ON t_user(`name`);
ALTER TABLE t_user ADD UNIQUE INDEX nameIndex(`name`);
CREATE TABLE `t_product`(
`id` INTEGER UNSIGNED NOT NULL AUTO_INCREMENT,
`name` VARCHAR(20) NOT NULL,
`title` VARCHAR(20) NOT NULL,
`description` VARCHAR(100) DEFAULT NULL,
PRIMARY KEY(`id`),
UNIQUE name_index(`name`)
)

删除索引:

DROP INDEX nameIndex ON t_user;
ALTER TABLE t_product DROP INDEX name_index;

显示索引:

SHOW INDEX FROM t_user;

23.临时表:

CREATE TEMPORARY TABLE `t_temporary`(
`id` INTEGER(20) NOT NULL AUTO_INCREMENT,
`name` VARCHAR(20) DEFAULT NULL,
PRIMARY KEY(`id`)
)

从旧表中获取数据生成临时表:

CREATE TEMPORARY TABLE t_tem AS(
SELECT * FROM t_order LIMIT 0,10
)

24.复制表:
查看需要复制表的创建语句:

SHOW CREATE TABLE t_order;

复制创建语句进行新表创建:

CREATE TABLE `t_order_clone` (
`id` int(10) unsigned NOT NULL AUTO_INCREMENT,
`title` varchar(100) NOT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=12 DEFAULT CHARSET=utf8

往新表填充需要复制表的数据:

INSERT INTO `t_order_clone`(id,title) SELECT * FROM t_order;

直接在创建的时候就从旧表拿数据:

CREATE TABLE `t_user_clone` AS (
SELECT * FROM t_user
);

只复制表结构到新表:

CREATE TABLE `t_user_customer` SELECT * FROM t_user WHERE 1=2;

25.数据库元数据:

SELECT VERSION(); //数据库版本
SELECT DATABASE(); //数据库名称
SELECT USER();//数据库当前登录用户
SHOW STATUS;//数据库的状态
SHOW VARIABLES;//数据库的配置变量

26.序列:
使用AUTOINCREMENT 来定义序列
创建表的时候添加AUTOINCREMENT序列

CREATE TABLE `t_user`(
`id` INTEGER UNSIGNED NOT NULL AUTO_INCREMENT,
`name` VARCHAR(20) DEFAULT NULL,
PRIMARY KEY(`id`)
)

重置序列的开始值(只能目前最大的值大,不能比目前最大的值的小):

ALTER TABLE t_user auto_increment=1000;

27.导出数据:

用OUTFILE导出表的数据:

SELECT * FROM t_user INTO OUTFILE 'G:/t_user.txt' FIELDS TERMINATED BY ',' ENCLOSED BY '"' LINES TERMINATED BY '\r\n';

用mysqldump导出表的SQL格式的数据(包含创建语句和插入数据语句):

mysqldump -u root -p payments t_user_clone > t_user_bak.txt
mysqldump -u root -p payments > G:/payments.sql

只导出需要插入的数据(不包含创建的语句):

mysqldump -u root -p payments --no-create-info > G:/payments.txt
mysqldump -u root -p payments --no-create-info > G:/payments.sql

28.导入数据:
source 命令导入
先创数据库 payment,再导入:
mysql -u root -p payment < G:/payment.sql

CREATE DATABASE paymentdb;
use paymentdb;
source G:/payments.sql

29.函数:

字符串函数:

CHAR_LENGTH(s):返回字符串 s 的字符数

SELECT CHAR_LENGTH("abcde") AS `length` //输出 5

CHARACTER_LENGTH(s) :返回字符串 s 的字符数

SELECT CHARACTER_LENGTH("web"); //3

CONCAT(s1,s2...sn):字符串 s1,s2 等多个字符串合并为一个字符串

SELECT CONCAT("wo-","de-","zuguo") //wo-de-zuguo

CONCAT_WS(x, s1,s2...sn): 同 CONCAT(s1,s2,...) 函数,但是每个字符串之间要加上 x,x 可以是分隔符

SELECT CONCAT_WS("@","come","on","baby");
//come@on@baby

FIELD(s,s1,s2...) :返回第一个字符串 s 在字符串列表(s1,s2...)中的位置

SELECT FIELD("you","see", "you", "late"); //2。索引以1开始而不是0.

FINDINSET(s1,s2):返回在字符串s2中与s1匹配的字符串的位置

SELECT FIND_IN_SET("a","i,am,a,worker"); //3

FORMAT(x,n):函数可以将数字 x 进行格式化 "#,###.##", 将 x 保留到小数点后 n 位,最后一位四舍五入。

SELECT FORMAT("1.44",1); //1.4
SELECT FORMAT("1.55",1); //1.6

INSERT(s1,x,len,s2):字符串 s2 替换 s1 的 x 位置开始长度为 len 的字符串

SELECT INSERT("hello word",7,4,"世界");//hello 世界

LOCATE(s1,s):从字符串 s 中获取 s1 的开始位置

SELECT LOCATE("a","this is a student");-- 9

LCASE(s):将字符串 s 的所有字母变成小写字母

SELECT LCASE("ABC");-- abc

LEFT(s,n):返回字符串 s 的前 n 个字符

SELECT LEFT("this is a apple",3);-- thi

LOWER(s):将字符串 s 的所有字母变成小写字母

SELECT LOWER('ABC') -- abc

LPAD(s1,len,s2):在字符串 s1 的开始处填充字符串 s2,使字符串长度达到 len

LTRIM(s) :去掉字符串 s 开始处的空格

MID(s,n,len):从字符串 s 的 n 位置截取长度为 len 的子字符串,同 SUBSTRING(s,n,len)

POSITION(s1 IN s):从字符串 s 中获取 s1 的开始位置

REPEAT(s,n):将字符串 s 重复 n 次
REPLACE(s,s1,s2):将字符串 s2 替代字符串 s 中的字符串 s1

REVERSE(s):将字符串s的顺序反过来

RIGHT(s,n):返回字符串 s 的后 n 个字符

RPAD(s1,len,s2):在字符串 s1 的结尾处添加字符串 s2,使字符串的长度达到 len

RTRIM(s):去掉字符串 s 结尾处的空格

SPACE(n):返回 n 个空格

STRCMP(s1,s2):比较字符串 s1 和 s2,如果 s1 与 s2 相等返回 0 ,如果 s1>s2 返回 1,如果 s1<s2 返回 -1

SUBSTR(s, start, length):从字符串 s 的 start 位置截取长度为 length 的子字符串

SUBSTRING(s, start, length):从字符串 s 的 start 位置截取长度为 length 的子字符串

SUBSTRING_INDEX(s, delimiter, number) :返回从字符串 s 的第 number 个出现的分隔符 delimiter 之后的子串。

TRIM(s):去掉字符串 s 开始和结尾处的空格

UCASE(s):将字符串转换为大写

UPPER(s):将字符串转换为大写

30.总条数:

SELECT COUNT("*") as `total` FROM t_order;

31.求和:

SELECT SUM(saled) as sum FROM t_order;

32.求平均值:

SELECT AVG(saled) AS avg FROM t_order;

33.求最大值:

SELECT MAX(saled) AS maxs FROM t_order;

34.求最小值:

SELECT MIN(saled) AS mins FROM t_order;

相关推荐

爬虫基础之自动化工具 DrissionPage 的使用

概述前三期文章中已经介绍到了Selenium与Playwright、Pyppeteer的使用方法,它们的功能都非常强大。而本期要讲的DrissionPage更为独特,强大,而且使用更为方...

你不得不知的云计算与虚拟化基础知识(下)

1.4KVM日常管理[root@linux-node1opt]#virshstartCentOS-7-x86_64#启动刚才创建的CentOS7KVM虚拟机DomainCentOS-7-x86...

Linux 终端复用神器 Tmux 使用详解

Tmux是TerminalMultiplexer的简称,它是一款优秀的终端复用软件,类似GNUscreen,但比screen更出色。tmux来自于OpenBSD,采用BSD授权。使用它最直...

Java快速开发框架若依(RuoYi)centos7.6部署

RuoYi是一个JavaEE企业级快速开发平台,基于经典技术组合(SpringBoot、SpringSecurity、MyBatis、Jwt、Vue),内置模块如:部门管理、角色用户、菜单...

推荐一款Linux的进程管理利器——Supervisor

一、supervisor简介项目中需要将一些自己开发的服务放到系统进程中在后台运行。一开始使用的是screen工具配合写了一个shell脚本,基本实现了启动、重启、停止操作,但是对于进程守护方面不是太...

读红蓝攻防:技术与策略34日志分析

1.日志分析1.1.要调查安全问题,通常需要查看来自不同供应商和不同设备的多种日志1.2.一旦了解了如何读取日志,在多个供应商产品的日志之间切换就会变得更容1.3.许多工具可以自动执行日志聚合...

Dify存储告急别焦虑!6步迁移教程,系统无缝切换,流畅度暴涨!

小王最近愁坏了--用Dify搭建的公司知识库因频繁导入行业文档,旧服务器硬盘红灯频闪,每次跑模型训练都弹出"存储空间不足"报错,甚至有两次差点弄丢用户对话历史数据!而某初创...

解决CentOS 中显示乱码问题(centos编码)

解决CentOS中显示乱码问题vi/etc/sysconfig/i18nLANG="en_US.UTF-8"SUPPORTED="en_US.UTF-8:en_US:e...

Tmux——超越screen的终端工具(tmux操作)

我们都知道,远程会话如果连接中断了,当前的进程任务也会中断,虽然说可以把任务放在后台,但显示不是很直观。以前linux系统常带的终端工具screen,我们今天介绍比screen更强大的工具...

MySQL如何找到使用的是哪个配置文件?

一个正在运行的MySQL实例,如何查看对应的配置文件用的是哪一个?如果存在多个文件,生效的顺序是怎么样的?1.方法一首先可以先选择查看MySQL进程信息来判断使用了哪个配置文件,例如:ps-au...

MySQL合集-基于MHA搭建高可用架构

MHA架构介绍MHA是MasterHighAvailability的缩写,它是目前MySQL高可用方面的一个相对成熟的解决方案,其核心是使用perl语言编写的一组脚本,是一套优秀的作为MySQL高...

mysql8版本的卸载、安装、升级(mysql8卸载如何彻底删除)

mysql的卸载yumremovemysql-community-client-plugins-8.0.42-1.el7.x86_64yumremovemysql-community-comm...

如何用MySQL设计一个分布式锁?(mysql分布式数据库+分布式存储)

前言分布式锁想必大家都不陌生,可以用来解决在分布式环境下,多个用户在同一时间读取/更新相同的资源带来的问题。比如秒杀场景下的库存问题、rediskey失效情况下请求直接打到MySQL中造成MySQL...

QT 5.12.11 编译MySQL 8 驱动教程- 1.01版

安装编译环境:qt5.12.11mysql8.0.28修改mysql.pro工程文件,编译生成动态库mysql.pro文件位置:D:\Alantop_Dir\alantop_sde\Qt\Qt5....

MySQL中exists和in的区别(exists在sql中的用法)

在MySQL中,EXISTS和IN用于在查询中检查某个值是否存在于某个集合或表中。exists在MySQL中,EXISTS是一个布尔操作符,用于在SELECT查询中检查子查询是否返回任何行。如果子查询...

取消回复欢迎 发表评论: