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

MySQL常用语句汇总_mysql常用语句大全

itomcoil 2025-09-14 20:02 3 浏览

一、背景

日常测试开发工作中会用到各类SQL语句,很多时候都是想用的时候才发现语句细节记不清楚了,临时网上搜索SQL语法,挺费时费力的,语法还不一定是对的。

因此汇总整理了一下MySQL最常用的各类语句,以后就不用再到处去搜了。

二、各类SQL语句

假设想要的表结构如下:


1. 创建表:

CREATE TABLE IF NOT EXISTS `mq_info` ( 
	`id` INT(12) UNSIGNED AUTO_INCREMENT COMMENT 'mq信息数据库自增id',
	`topic` VARCHAR ( 255 ) NOT NULL COMMENT 'mq_topic名称', 
  	`message` longtext NOT NULL COMMENT 'mq_message内容', 
	`markinfo` VARCHAR ( 255 ) COMMENT '该MQ的标识字段', 
	PRIMARY KEY ( `id` ) 
) ENGINE = INNODB DEFAULT CHARSET = utf8;

2. 查询表中所有数据:

select * from mq_info;

3. 查询表中前20条数据:

select * from mq_info limit 20;

4. 表中新增一条数据:

insert into mq_info ( topic,message,markinfo) values('mq_test','{"demands":1,"testId":165,"operation":3}','testInfo001')

5. 修改表中某个字段的值:

//将id=1的数据的topic都改为'mqUpdate_test'
update mq_info set topic='mqUpdate_test' where id='1'
//将id=1或topic='mq_test'的数据的topic都改为'mqUpdate_test',markinfo都改为'testInfo_update'
update mq_info set topic='mqUpdate_test',markinfo='testInfo_update' where id='1' or topic='mq_test'

6. 删除表中指定条件的某一条数据:

delete from mq_info where id = 1

7. 删除表中所有的数据:

delete from mq_info

8. 删除表中某一个字段:

//删除mq_info表中的markinfo字段
alter table mq_info drop column markinfo

9. 修改表中某个字段的类型:

//修改mq_info表中的message字段类型为varchar类型
alter table mq_info modify column message varchar(255);

10. 修改表中某个字段的备注信息:

//修改mq_info表中的markinfo字段的备注信息为'自定义该MQ的唯一标识'
alter table mq_info modify markinfo varchar(255) comment '自定义该MQ的唯一标识'

11. 修改表中某个字段的名称:

//把mq_info表中的markinfo字段名改为description_Info,类型是varchar(255)
alter table mq_info change markinfo description_Info varchar(255)

12. 向已有的表中新增新的字段:

//向mq_info表新增insert_time字段,字段类型为datetime,备注信息为'MQ落库时间'
alter table mq_info add insert_time datetime comment 'MQ落库时间'

13. 修改已有表的表名:

alter table mq_info rename to cart_mq_info

14. 修改数据库中字段的顺序:

//将insert_time字段在表中的排列顺序, 修改为显示在create_time字段后面
alter table mq_info modify insert_time tinyint(4) after create_time
//“FIRST”为可选参数,指的是将字段1修改为表的第一个字段,“AFTER 字段名2”是将字段1插入到字段2的后面
ALTER TABLE MODLFY 字段名1 数据类型 FIRST|AFTER 字段名2

15. 复制已有的表结构生成一张新表:

//复制mq_info表结构生成一张新表order_mq_info
create table order_mq_info like mq_info

16. 某个字段模糊查询:

//查询mq_info表中topic字段包含test的所有数据
SELECT * FROM mq_info where topic like '%test%';
//优化写法:locate(‘substr’,str,pos), 提升查询效率
SELECT * FROM mq_info where locate('test', topic)>0

17. 查询条件包含不等于:

//查询mq_info表中topic等于'order_info',并且markinfo不等于'test'的所有数据
select * from mq_info where topic = 'order_info' and (markinfo != 'test' or markinfo is null)
//注意加上条件markinfo is null,不然Markinfo为null的数据不会被查出来
//注意()的作用,加括号是为了提高优先级先执行括号内的查询条件
//在这个基础上再进行topic = 'order_info'的查询

18. 分组+条件查询:

student表数据如下:


//查询每个老师带的学生的平均年龄(group by语法)
//由于是查每个老师,因此要用TeacherID作为分组条件
select TeacherID, avg(Age) as AGE from student group by TeacherID
//查询每个老师带的学生的平均年龄且平均年龄大于12(group by + having语法)
//条件是带函数的,就必须用having,而不能用where
select TeacherID, avg(Age) as AGE from student group by TeacherID having avg(Age) > 12

19. 连表查询,主表所有字段+从表部分字段:

//teacher表中没有存学生姓名,只存了学生id
//需要将teacher表中create_time大于等于2022-10-28 00:00:00的所有数据以及学生的姓名查出来
select teacher.*,
student.studentName,
from teacher_manage replay 
LEFT JOIN student_manage student 
on teacher.student_id=student.id 
where teacher.create_time >= '2022-10-28 00:00:00';

=================================
以上就是本次的全部内容,都看到这里了,如果对你有帮助,麻烦点个赞+收藏+关注,一键三连啦~

欢迎关注我的微信公众号:程序员杨叔,各类文章都会第一时间在上面发布,持续分享全栈测试知识干货,你的支持就是作者更新最大的动力~

相关推荐

MySQL中的MVCC到底能不能解决幻读

在MySQL当中,只有使用了InnoDB存储引擎的数据库表才支持事务。有了事务就可以用来保证数据的完整以及一致性,保证成批的SQL语句要么全部执行,要么全部不执行。事务用来管理insert、updat...

每次写SQL时总忘记语法顺序怎么办,这里一招教你解决

MySQL基础(五)-----表达式&函数和分组查询表达式和函数:表达式就是将数字和运算符连接起来的组合,称之为表达式,比如:1+1;函数就是系统自带已经定义好可以直接使用的函数,例如MAX,MIN;...

在 MySQL 中使用 UUID 作为主键的存在问题及如何优化?

在分布式架构中,UUID(通用唯一标识符)因其能够确保全球唯一性而广泛应用。它不依赖于数据库的自增机制,特别适合于多个系统间的数据同步。然而,尽管UUID提供了很多优势,直接使用它作为MySQL...

SQL入门知识篇_sql入门教程

一、什么是数据库?什么是SQL?1、数据库:存放数据,可以很多人一起使用2、关系数据库:多张表+各表之间的关系3、一张表需要包含列、列名、行4、主键:一列(或一组列),其值能够唯一区分表中的每个行。5...

MySQL索引解析(联合索引/最左前缀/覆盖索引/索引下推)

目录1.索引基础2.索引类型2.1哈希索引2.2有序数组2.3B+树索引(InnoDB)3.联合索引4.最左前缀原则5.覆盖索引6.索引下推总结:1.索引基础索引对查询的速度有着至...

Mysql索引覆盖_mysql索引ref

作者:京东零售孙涛1.什么是覆盖索引通常情况下,我们创建索引的时候只关注where条件,不过这只是索引优化的一个方向。优秀的索引设计应该纵观整个查询,而不仅仅是where条件部分,还应该关注查询所包...

MySQL常用语句汇总_mysql常用语句大全

一、背景日常测试开发工作中会用到各类SQL语句,很多时候都是想用的时候才发现语句细节记不清楚了,临时网上搜索SQL语法,挺费时费力的,语法还不一定是对的。因此汇总整理了一下MySQL最常用的各类语句,...

POI批量生成Word文档表格_poi批量导入excel

  前言  当我们在写设计文档,或者是其他涉及到数据架构、表结构时,可以用POI来批量生成表格,例如下面的表格  代码编写  引入POI依赖<!--引入apachepoi-...

cmd命令操作Mysql数据库,命令行操作Mysql

Mysql数据库是比较流行的数据库之一,维基百科的介绍如下:MySQLisanopen-sourcerelationaldatabasemanagementsystem(RDBMS)....

MySQL大数据表处理策略,原来一直都用错了……

场景当我们业务数据库表中的数据越来越多,如果你也和我遇到了以下类似场景,那让我们一起来解决这个问题。数据的插入,查询时长较长后续业务需求的扩展,在表中新增字段,影响较大表中的数据并不是所有的都为有效数...

SQL点滴(查询篇):数据库基础查询案例实战

本文主要是对微头条SQL小技能的汇总,便于收藏查阅,为数据库初学者提供多快好省又可实际操作的帮助。下面为正文。1.通用*查询在从数据库表中检索所有行与列,若要查询所有数据,通常做法为:select*...

Mysql学习笔记-InnoDB深度解析_mysql innodb底层原理

前言我们在上一篇博客聊了Mysql的整体架构分布,连接层、核心层、存储引擎层和文件系统层,其中存储引擎层作为MysqlServer中最重要的一部分,为我们sql交互提供了数据基础支持。存储引擎和文件...

「MySQL调优」大厂MySQL性能优化实战讲解

WhyPerformance在1990s,人们还使用拨号接入互联网的时候,浏览一个网页或加入一个线上聊天室需要几分钟的时间去加载是一件很正常的事情。而2009年Akamai公司的报告显示,如果一个网...

MySQL数据库性能优化_mysql数据库优化及sql调优

任何软件平台的运行都需要依赖于数据库的存储,数据库存储着业务系统的关键信息,包含基础的组织、人员及业务流程板块信息等。因此在平台运转过程中,数据库的响应速率直接影响平台的回显速度及用户的友好体验。尽管...

面试中的老大难-mysql事务和锁,一次性讲清楚

什么是事务在维基百科中,对事务的定义是:事务是数据库管理系统(DBMS)执行过程中的一个逻辑单位,由一个有限的数据库操作序列构成。事务的四大特性事务包含四大特性,即原子性(Atomicity)、一致性...