mysql常用语句超级详细汇总
wptr33 2025-01-04 23:28 13 浏览
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;
相关推荐
- 每天一个编程技巧!掌握这7个神技,代码效率飙升200%
-
“同事6点下班,你却为改BUG加班到凌晨?不是你不努力,而是没掌握‘偷懒’的艺术!本文揭秘谷歌工程师私藏的7个编程神技,每天1分钟,让你的代码从‘能用’变‘逆天’。文末附《Python高效代码模板》,...
- Git重置到某个历史节点(Sourcetree工具)
-
前言Sourcetree回滚提交和重置当前分支到此次提交的区别?回滚提交是指将改动的代码提交到本地仓库,但未推送到远端仓库的时候。...
- git工作区、暂存区、本地仓库、远程仓库的区别和联系
-
很多程序员天天写代码,提交代码,拉取代码,对git操作非常熟练,但是对git的原理并不甚了解,借助豆包AI,写个文章总结一下。Git的四个核心区域(工作区、暂存区、本地仓库、远程仓库)是版本控制的核...
- 解锁人生新剧本的密钥:学会让往事退场
-
开篇:敦煌莫高窟的千年启示在莫高窟321窟的《降魔变》壁画前,讲解员指着斑驳色彩说:"画师刻意保留了历代修补痕迹,因为真正的传承不是定格,而是流动。"就像我们的人生剧本,精彩章节永远...
- Reset local repository branch to be just like remote repository HEAD
-
技术背景在使用Git进行版本控制时,有时会遇到本地分支与远程分支不一致的情况。可能是因为误操作、多人协作时远程分支被更新等原因。这时就需要将本地分支重置为与远程分支的...
- Git恢复至之前版本(git恢复到pull之前的版本)
-
让程序回到提交前的样子:两种解决方法:回退(reset)、反做(revert)方法一:gitreset...
- 如何将文件重置或回退到特定版本(怎么让文件回到初始状态)
-
技术背景在使用Git进行版本控制时,经常会遇到需要将文件回退到特定版本的情况。可能是因为当前版本出现了错误,或者想要恢复到之前某个稳定的版本。Git提供了多种方式来实现这一需求。...
- git如何正确回滚代码(git命令回滚代码)
-
方法一,删除远程分支再提交①首先两步保证当前工作区是干净的,并且和远程分支代码一致$gitcocurrentBranch$gitpullorigincurrentBranch$gi...
- [git]撤销的相关命令:reset、revert、checkout
-
基本概念如果不清晰上面的四个概念,请查看廖老师的git教程这里我多说几句:最开始我使用git的时候,我并不明白我为什么写完代码要用git的一些列指令把我的修改存起来。后来用多了,也就明白了为什么。gi...
- 利用shell脚本将Mysql错误日志保存到数据库中
-
说明:利用shell脚本将MYSQL的错误日志提取并保存到数据库中步骤:1)创建数据库,创建表CreatedatabaseMysqlCenter;UseMysqlCenter;CREATET...
- MySQL 9.3 引入增强的JavaScript支持
-
MySQL,这一广泛采用的开源关系型数据库管理系统(RDBMS),发布了其9.x系列的第三个更新版本——9.3版,带来了多项新功能。...
- python 连接 mysql 数据库(python连接MySQL数据库案例)
-
用PyMySQL包来连接Python和MySQL。在使用前需要先通过pip来安装PyMySQL包:在windows系统中打开cmd,输入pipinstallPyMySQL ...
- mysql导入导出命令(mysql 导入命令)
-
mysql导入导出命令mysqldump命令的输入是在bin目录下.1.导出整个数据库 mysqldump-u用户名-p数据库名>导出的文件名 mysqldump-uw...
- MySQL-SQL介绍(mysql sqlyog)
-
介绍结构化查询语言是高级的非过程化编程语言,允许用户在高层数据结构上工作。它不要求用户指定对数据的存放方法,也不需要用户了解具体的数据存放方式,所以具有完全不同底层结构的不同数据库系统,可以使用相同...
- MySQL 误删除数据恢复全攻略:基于 Binlog 的实战指南
-
在MySQL的世界里,二进制日志(Binlog)就是我们的"时光机"。它默默记录着数据库的每一个重要变更,就像一位忠实的史官,为我们在数据灾难中提供最后的救命稻草。本文将带您深入掌握如...
- 一周热门
-
-
C# 13 和 .NET 9 全知道 :13 使用 ASP.NET Core 构建网站 (1)
-
因果推断Matching方式实现代码 因果推断模型
-
git pull命令使用实例 git pull--rebase
-
面试官:git pull是哪两个指令的组合?
-
git 执行pull错误如何撤销 git pull fail
-
git pull 和git fetch 命令分别有什么作用?二者有什么区别?
-
git fetch 和git pull 的异同 git中fetch和pull的区别
-
git pull 之后本地代码被覆盖 解决方案
-
还可以这样玩?Git基本原理及各种骚操作,涨知识了
-
git命令之pull git.pull
-
- 最近发表
-
- 每天一个编程技巧!掌握这7个神技,代码效率飙升200%
- Git重置到某个历史节点(Sourcetree工具)
- git工作区、暂存区、本地仓库、远程仓库的区别和联系
- 解锁人生新剧本的密钥:学会让往事退场
- Reset local repository branch to be just like remote repository HEAD
- Git恢复至之前版本(git恢复到pull之前的版本)
- 如何将文件重置或回退到特定版本(怎么让文件回到初始状态)
- git如何正确回滚代码(git命令回滚代码)
- [git]撤销的相关命令:reset、revert、checkout
- 利用shell脚本将Mysql错误日志保存到数据库中
- 标签列表
-
- git pull (33)
- git fetch (35)
- mysql insert (35)
- mysql distinct (37)
- concat_ws (36)
- java continue (36)
- jenkins官网 (37)
- mysql 子查询 (37)
- python元组 (33)
- mybatis 分页 (35)
- vba split (37)
- redis watch (34)
- python list sort (37)
- nvarchar2 (34)
- mysql not null (36)
- hmset (35)
- python telnet (35)
- python readlines() 方法 (36)
- munmap (35)
- docker network create (35)
- redis 集合 (37)
- python sftp (37)
- setpriority (34)
- c语言 switch (34)
- git commit (34)