Mysql四:常用查询语句(十种),一般情况够用了
haoteby 2024-11-05 11:09 71 浏览
sql 查询语句:总结一下常用的,只要你不是数据库管理员,一般都够用了。
表一:select * from t_step;
表二:select * from t_case;
说10个知识点,分组查询中有个【字段合并】聚合函数注意一下
1、limit 读取前几条
# 解读:读取前2条
select * from t_step limit 2;
select * from t_step limit 3,2;
# 返回:2条数据 解读:从第3个索引读取2条(索引从0开始,从第4条开始取)
id case_id step----------------
4 case004 步骤4
5 case002 步骤22
# 解读:先where条件,再limit读取
select * from t_step where case_id like 'case%' limit 2;
2、排序 order by
# 以下两条排序 等价,order by 默认是 asc(从小到大排序)
select * from t_step order by case_id
select * from t_step order by case_id asc
# 从大到小排序
select * from t_step order by case_id desc
3、去重复 distinct
# 把 case_id 去重复
select distinct case_id from t_step
4、分组查询 group by
常用聚合函数:
行数count(*),求和sum(score),求平均avg(age),
最小值min(age),最大值max(age)
group_concat(sep) 合并sep字段数据
select case_id,count(*) from t_step group by case_id ;
case_id count(*)--------------
case001 1
case002 2
case003 1
case004 1
select case_id,count(*) from t_step where case_id!='case001' group by case_id ;
case_id count(*)--------------
case002 2
case003 1
case004 1
select case_id,count(*) from t_step where case_id!='case001' group by case_id having count(*)>1;
case_id count(*)--------------
case002 2
select case_id,group_concat(step) from t_step group by case_id;
case_id,group_concat(step)
case001 步骤1
case002 步骤2,步骤22
case003 步骤3
case004 步骤4
5、取交集1:笛卡尔积
select * from t_case as c, t_sep as s where c.case_id = s.case_id;
# 返回:5条 解读:把所有行数取交集
id case_id case_name id(1) case_id(1) step----------------
1 case001 用例1 1 case001 步骤1
2 case002 用例2 2 case002 步骤2
3 case003 用例3 3 case003 步骤3
4 case004 用例4 4 case004 步骤4
2 case002 用例2 5 case002 步骤22
6、取交集2:链接(内链接)join on 等价于 inner join on
select * from t_case join t_step on t_case.case_id = t_step.case_id;
# 返回:5条 解读:把所有行数取交集
id case_id case_name id(1) case_id(1) step----------------
1 case001 用例1 1 case001 步骤1
2 case002 用例2 2 case002 步骤2
3 case003 用例3 3 case003 步骤3
4 case004 用例4 4 case004 步骤4
2 case002 用例2 5 case002 步骤22
7、左链接 left join on
# 以下2条语句输出一样
select * from t_case as c left join t_step as s on c.case_id = s.case_id
# 返回:5条 解读:以左表为基础链接,右表中多,则丢弃,右表中少,则Null补充
select * from t_case left join t_step using(case_id);
# 返回:5条 解读:using(字段) 可以取代 on条件
id case_id case_name id(1) case_id(1) step----------------
1 case001 用例1 1 case001 步骤1
2 case002 用例2 2 case002 步骤2
3 case003 用例3 3 case003 步骤3
4 case004 用例4 4 case004 步骤4
2 case002 用例2 5 case002 步骤22
5 case006 用例6 Null Null Null
8、右链接
右链接和左链接相反,以右表为基础链接,左表中多,则丢弃,左表中少,则Null补充
select * from t_case as c right join t_step as s on c.case_id = s.case_id;
select * from t_case right join t_step using(case_id);
9、全链接(union)可以用左链接 union 右链接
union 去重复;union all 不去重复
select * from t_case as c left join t_step as s on c.case_id = s.case_id
union
select * from t_case as c right join t_step as s on c.case_id = s.case_id;
10、子查询 简单举个例子,新表用()包裹起来
select * from t_case where case_id in (select case_id from t_step)
select * from (select case_id,case_name from t_case) as t where t.case_id = 'case001';
select c.case_id,c.case_name,s.step from
(select case_id,case_name from t_case) as c,
(select case_id,step from t_step) as s
where c.case_id = s.case_id;
下篇文章说一下 sql 语句的 增、删、改。
相关推荐
- 如何为MySQL服务器和客户机启用SSL?
-
用户想要与MySQL服务器建立一条安全连接时,常常依赖VPN隧道或SSH隧道。不过,获得MySQL连接的另一个办法是,启用MySQL服务器上的SSL封装器(SSLwrapper)。这每一种方法各有其...
- k8s 证书问题排查_k8s dashboard 证书
-
从去年开始一些老项目上陆陆续续出现一些列的证书问题,(证书原理这里就不说了,官方文档一堆)多数刚开始的表现就是节点的kubelet服务起不来,节点状态NotReady表现日志如下failed...
- 企业级网络互通方案:云端OpenVPN+爱快路由器+Win11互联实战
-
企业级网络互通方案:OpenVPN搭建公有云+爱快路由器+Win11三地互联实战指南「安全高效」三地局域网秒变局域网实施环境说明...
- OpenV** Server/Client配置文件详解
-
Server配置详解...
- 接口基础认知:关键信息与合规前提
-
1.核心技术参数(必记)...
- S交换机通过SSH登录设备配置示例(RADIUS认证+本地认证独立)
-
说明:●本示例只介绍设备的认证相关配置,请同时确保已在RADIUS服务器上做了相关配置,如设备地址、共享密钥、创建用户等配置。●通过不同的管理域来实现RADIUS认证与本地认证两种方式同时使用,两...
- SSL证书如何去除私钥密码保护_ssl证书怎么取消
-
有时候我们在生成证书的时候可以加入了密码保护。然后申请到证书安装到了web服务器。但是这样可能会带来麻烦。每次重启apache或者nginx的时候,都需要输入密码。那么SSL证书如何去除私钥密码保护。...
- SSL证书基础知识与自签名证书生成指南
-
一、证书文件类型解析...
- S交换机通过SSH登录设备配置示例(RADIUS认证)
-
说明:本示例只介绍设备的认证相关配置,请同时确保已在RADIUS服务器上做了相关配置,如设备地址、共享密钥、创建用户等配置。假设已在RADIUS服务器上创建了用户名yc123,密码test#123。对...
- HTTPS是什么?加密原理和证书。SSL/TLS握手过程
-
秘钥的产生过程非对称加密...
- HTTPS TLS握手流程_进行tls握手
-
1.客户端向服务器发送`ClientHello`消息,包括支持的TLS版本、加密套件、随机数等信息。2.服务器收到`ClientHello`消息后,解析其中的信息,并根据配置选择一个加密套件。3....
- Spring Boot 单点登录(SSO)实现_spring boot 单点登录jwt
-
SpringBoot单点登录(SSO)实现全指南单点登录(SingleSign-On,SSO)是一种身份验证机制,允许用户使用一组凭证登录多个相关但独立的系统。在微服务架构和企业级系统中,SS...
- 源码分享:在pdf上加盖电子签章_pdf如何加盖电子公章
-
在pdf上加盖电子签章,并不是只是加个印章图片,。而是要使用一对密钥中的私钥对文件进行签字。为啥要用私钥呢?很简单,因为公钥是公开的,其他人才可以用公钥为你证明,这个文件是你签的。这就是我们常说的:私...
- 微信支付商户API证书到期 怎么更换
-
微信支付商户API证书到期更换是一个非常重要的操作,需要仔细按照流程进行。如果证书过期,所有通过API的支付、退款等操作都会失败,将直接影响您的业务。请按照以下详细步骤进行操作:重要前提:分清...