MySql 中 select 使用
MySql select 多种查询方式
前言
在数据库使用过程中,使用最多的场景就是查询数据,所以今天我们总结一下常用用的查询
- 简单查询
- 带条件查询
- 多条件查询
- 输出指定字段查询
- 分组查询
- 查询结果排序
- 分页查询
- 多表之间查询
准备三张表:订单 orders 商品 commodity 用户 users 内容如下:
orders 表:

users 表:

commodity 表:

简单查询
语法:
select * from 表名
执行查询语句, 查询 commodity 表所有数据
select * from commodite ;

WHERE 带条件查询
- 带条件查询是在select 语句后面添加 where
- 可以使用 and 或者 or 链接一个或多个条件
- and 同时要满足两个或两个以上条件
- or 满足两个或两个以上其中一个条件
操作符: - = 等于 !=,<> 不等于 > 大于 < 小于 >= 大于等于 <=
语法
select * from 表名 where 条件1 and 条件2 or 条件3 ;
列子:查询 commodity 表中 id = 1 的商品信息
select * from commodity where id = 1 ;

多条件查询
查询 commodity 表中 order_id = 1 并且 user_id = 1
select * from commodity where order_id = 1 and user_id = 1 ;

查询 commodity 表中 order_id = 1 或者 user_id = 1
select * from commodity where order_id = 1 or user_id = 1 ;

输出指定字段查询
在查询表数据的时,有时我们只需要其中几个字段,这个是我们指定需要字段即可
语法
select 列1, 列2, ... from 表明 WHERE 条件可选
下面我们查询 commodity 表输出 商品名
select c_name from commodity ;

结果只输出了 c_name 一列数据
下面我们添加条件查询看下效果
select c_name from commodity where order_id = 1 ;

分组查询
在实际使用是,我们还会用到根据其中一列分组查询,下面我们看下语法
select 用于分组的列, 用于运算的列 from commodity group by 用于分组的列
下面我们查询 commodity ,按照 order_id 进行分组
select order_id from commodity group by order_id;

按照 order_id 分组之后我们再看下每一组具体有多少条数据
select order_id, COUNT(order_id) from commodity group by order_id;

- 按照 order_id 分组,计算每一组数量 count(order_id)
查询结果排序
很多时候我们需要对查询结果进行排序这个时候我们会用到 order by
select * from 表名 order by 排序字段 排序规则
排序规则
- DESC 降序
- ASC 升序 默认
现在我们查询一下 commodity 结果按 order_id 排序
select * from commodity order by order_id ASC ;

select * from commodity order by order_id DESC ;

分页查询
在实际业务常常会用到分页查询功能
语法
select * from commodity limit 条数 offset 起始位置;
下面我们查询 commodity 表,从第二条开始查询,结果输出两条数据
select * from commodity limit 2 offset 1;

下面我们把上面的所有语法练习一下
查询 commodity 表,条件是order_id = 1 或者 user_id != 4 按照 order_id 分组 按照user_id 排序 输出 order_id user_id 列 查询结果从第二条开始 只查询两条
select order_id, user_id from commodity where order_id = 1 or user_id != 4 group by order_id, user_id order by user_id DESC limit 4 offset 1;

MySql 中 select 使用的更多相关文章
- MySQL中select * for update锁表的范围
MySQL中select * for update锁表的问题 由于InnoDB预设是Row-Level Lock,所以只有「明确」的指定主键,MySQL才会执行Row lock (只锁住被选取的资料例 ...
- MySQL中select * for update锁表的问题
MySQL中select * for update锁表的问题 由于InnoDB预设是Row-Level Lock,所以只有「明确」的指定主键,MySQL才会执行Row lock (只锁住被选取的资料例 ...
- mysql进阶(四)mysql中select
mysql中select * for update 注: FOR UPDATE 仅适用于InnoDB,且必须在事务区块(BEGIN/COMMIT)中才能生效. 作用 锁定该语句所选择到的对象.防止在 ...
- mysql中select into 和sql中的select into 对比
现在有张表为student,我想将这个表里面的数据复制到一个为dust的新表中去.answer 01: create table dust select * from student;//用于复制前未 ...
- MySQL中select * for update锁表的问题(转)
由于InnoDB预设是Row-Level Lock,所以只有「明确」的指定主键,MySQL才会执行Row lock (只锁住被选取的资料例) ,否则MySQL将会执行Table Lock (将整个资料 ...
- MySQL中SELECT语句简单使用
最近开始复习mysql,查漏补缺吧. 关于mysql 1.MySQL不区分大小写,但是在MySQL 4.1及之前的版本中,数据库名.表名.列名这些标识符默认是区分大小写的:在之后的版本中默认不区分大小 ...
- MySQL中select、insert、update批量操作语句
项目中经常的需要使用批量操作语句对数据进行操作,使用批量语句的时候需要注意MySQL数据库的条件限制,这里主要是数据的大小限制,这里对批量插入.批量查找及批量更新的基础操作进行下简单的汇总. 1.批量 ...
- 【原创】Mysql中select的正确姿势
引言 大家在开发中,还有很多童鞋在写查询语句的时候,习惯写下面这种不规范sql select * from table 而不写成下面的这种规范方式 select col1,col2,...,coln ...
- 数据库:Mysql中“select ... for update”排他锁分析
Mysql InnoDB 排他锁 用法: select … for update; 例如:select * from goods where id = 1 for update; 排他锁的申请前提:没 ...
- Mysql中select的正确姿势
引言 大家在开发中,还有很多童鞋在写查询语句的时候,习惯写下面这种不规范sql select * from table 而不写成下面的这种规范方式 select col1,col2,...,coln ...
随机推荐
- 小米电商 Apache Dubbo-go 微服务实践
简介:2021 年是小米中国区电商部门变动调整较大的一年,小米中国区早期电商.服务体系建立在 Go 语言构建的微服务体系之上,由内部自研的 Go 语言微服务框架 koala 支撑起数以千计的微服务应 ...
- 阿里云CDN产品经理陈章炜:边缘创新技术和落地实践
简介: CDN除了加速外,不断被赋予更多价值.在阿里云CDN推出的<极速奔跑吧 2021>首场直播中,阿里云架构师和产品经理不仅对近期阿里云发布的CDN产品最佳实践图进行了详细解读,还对C ...
- iofsstat:帮你轻松定位 IO 突高,前因后果一目了然 | 龙蜥技术
简介:磁盘被打满到底是真实的业务需求量上来了呢?还是有什么野进程在占用 IO? iofsstat 帮你精准定位. 编者按:sysAK(system analyse kit),是龙蜥社区系统运维 SI ...
- Apsara Stack 技术百科 | 可运营的行业云,让云上资源跑起来
简介:企业级云管理平台,如何打造千人千面的个性化体验,从应用.云资源.硬件等进行全局智能优化,实现资源配置的最佳配比,构建精细化运营能力? 距离第一例新冠疫情病例的发现,不知不觉中已经过去两年, ...
- [PHP] 业务逻辑大内存占用的优化思路, yield 和 chunk
示例: header("content-type:text/html;charset=utf-8"); function readTxt() { $handle = fopen ...
- Windows 对全屏应用的优化
全屏应用对应的是窗口模式应用,全屏应用指的是整个屏幕都是被咱一个应用独占了,屏幕上没有显示其他的应用,此时的应用就叫全屏应用.如希沃白板这个程序.本文主要告诉大家从微软官方的文档以及考古了解到的 Wi ...
- golang之UrlEncode编码/UrlDecode解码
为什么需要编码和解码 1.是因为当字符串数据以url的形式传递给web服务器时,字符串中是不允许出现空格和特殊字符的: 2.因为 url 对字符有限制,比如把一个邮箱放入 url,就需要使用 urle ...
- StarCoder2-Instruct: 完全透明和可自我对齐的代码生成
指令微调 是一种技术,它能让大语言模型 (LLMs) 更好地理解和遵循人类的指令.但是,在编程任务中,大多数模型的微调都是基于人类编写的指令 (这需要很高的成本) 或者是由大型专有 LLMs 生成的指 ...
- 30分钟带你搞定Dokcer部署Kafka集群
docker网络规划 docker network create kafka-net --subnet 172.20.0.0/16 docker network ls zookeeper1(172.2 ...
- pageoffice 6 Vue+Springboot磁盘路径打开文档
本示例关键代码的编写位置 Vue+Springboot 注意 本文中展示的代码均为关键代码,复制粘贴到您的项目中,按照实际的情况,例如文档路径,用户名等做适当修改即可使用. 在正式的项目开发中,用户文 ...