前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >MySQL必知必会的查询

MySQL必知必会的查询

作者头像
云海谷天
发布2022-08-09 14:13:35
3200
发布2022-08-09 14:13:35
举报
文章被收录于专栏:技术一点点成长

前言:

  据身边不少朋友反映,SQL长时间不用的话难免会生疏!本文的几个查询示例可以让你5分钟内快速回忆起MySQL中常用的基础查询语法!

------------

如何用MySQL解决一些常见问题的例子

  在一些例子中,使用数据库表“shop”来储存某个商人(经销商)的每件物品(物品号)的价格。假定每个商人对每项物品有一个固定价格,那么(物品,商人)即为该记录的主关键字。

启动命令行工具mysql并选择数据库:

shell> use test

你可以使用以下语句创建示例表:

mysql> CREATE TABLE shop ( -> article INT(4) UNSIGNED ZEROFILL DEFAULT '0000' NOT NULL, -> dealer CHAR(20) DEFAULT '' NOT NULL, -> price DOUBLE(16,2) DEFAULT '0.00' NOT NULL, -> PRIMARY KEY(article, dealer)); mysql> INSERT INTO shop VALUES -> (1,'A',3.45),(1,'B',3.99),(2,'A',10.99),(3,'B',1.45), -> (3,'C',1.69),(3,'D',1.25),(4,'D',19.95); 执行语句后,表应包含以下内容:

mysql> SELECT * FROM shop; +---------+--------+-------+ | article | dealer | price | +---------+--------+-------+ | 0001 | A | 3.45 | | 0001 | B | 3.99 | | 0002 | A | 10.99 | | 0003 | B | 1.45 | | 0003 | C | 1.69 | | 0003 | D | 1.25 | | 0004 | D | 19.95 | +---------+--------+-------+ 1. 列的最大值 “最大的物品号是什么?”

代码语言:javascript
复制
SELECT MAX(article) AS article FROM shop;

+---------+ | article | +---------+ | 4 | +---------+

2. 拥有某个列的最大值的行 任务:找出最贵物品的编号、销售商和价格。 这很容易用一个子查询做到:

代码语言:javascript
复制
SELECT article, dealer, price
FROM shop
WHERE price=(SELECT MAX(price) FROM shop);

另一个解决方案是按价格降序排序所有行并用MySQL特定LIMIT子句只得到第一行:

代码语言:javascript
复制
SELECT article, dealer, price
FROM shop
ORDER BY price DESC
LIMIT 1;

注:如果有多项最贵的物品( 例如每个的价格为19.95),LIMIT解决方案仅仅显示其中一个!

3. 列的最大值:按组 任务:每项物品的的最高价格是多少?

代码语言:javascript
复制
SELECT article, MAX(price) AS price
FROM shop
GROUP BY article

+---------+-------+ | article | price | +---------+-------+ | 0001 | 3.99 | | 0002 | 10.99 | | 0003 | 1.69 | | 0004 | 19.95 | +---------+-------+

4. 拥有某个字段的组间最大值的行 任务:对每项物品,找出最贵价格的物品的经销商。

可以用这样一个子查询解决该问题:

代码语言:javascript
复制
SELECT article, dealer, price
FROM shop s1
WHERE price=(SELECT MAX(s2.price)
FROM shop s2
WHERE s1.article = s2.article);

5. 使用用户变量 你可以清空MySQL用户变量以记录结果,不必将它们保存到客户端的临时变量中。 例如,要找出价格最高或最低的物品的,其方法是:

mysql> SELECT @min_price:=MIN(price),@max_price:=MAX(price) FROM shop; mysql> SELECT * FROM shop WHERE price=@min_price OR price=@max_price; +---------+--------+-------+ | article | dealer | price | +---------+--------+-------+ | 0003 | D | 1.25 | | 0004 | D | 19.95 | +---------+--------+-------+

补充:单表最长的MySQL查询语句   如何查询出售商品中,自2001-01-01到2014-01-01期间出售的数量不少于2的排名前三的商品类别及对应销售数量?

代码语言:javascript
复制
mysql> select goodsid,gtype,gdate from goodsmessage;

实验数据:

+---------+-------+------------+ | goodsid | gtype | gdate | +---------+-------+------------+ | 1 | 教材 | 2001-10-02 | | 2 | 零食 | 2015-06-23 | | 4 | 图书 | 2015-06-23 | | 6 | 教材 | 2008-10-03 | | 7 | 教材 | 2001-10-03 | | 8 | 报刊 | 2001-04-01 | | 9 | 报刊 | 2001-01-01 | | 10 | 教材 | 2001-10-01 | | 11 | 教材 | 2001-10-01 | | 12 | 教材 | 2001-10-01 | | 13 | 教材 | 2001-10-01 | | 14 | 教材 | 2001-10-01 | | 15 | 教材 | 2001-10-01 | | 16 | 教材 | 2001-10-01 | | 17 | 教材 | 2001-10-01 | | 18 | 教材 | 2015-06-11 | | 19 | 教材 | 2015-06-11 | | 20 | 零食 | 2015-06-23 | | 21 | 零食 | 2015-06-23 | | 23 | 图书 | 2012-01-02 | | 24 | 图书 | 2012-01-02 | | 25 | 图书 | 2012-01-02 | | 26 | 饮品 | 2015-06-23 | | 27 | 饮品 | 2015-06-23 | +---------+-------+------------+ 24 rows in set (0.00 sec) ---------------------------------

代码语言:javascript
复制
mysql> Select gtype,COUNT(*) AS total From goodsmessage Where gdate between '2001-01-01' AND '2014-01-01' Group By gtype Having total >= 2 Order By total DESC Limit 3;

查询输出结果:

+-------+-------+ | gtype | total | +-------+-------+ | 教材 | 11 | | 图书 | 3 | | 报刊 | 2 | +-------+-------+

================================

(注:以上部分内容直接参考自“MySQL参考手册”的翻译版本)

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2015-08-18,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
云数据库 SQL Server
腾讯云数据库 SQL Server (TencentDB for SQL Server)是业界最常用的商用数据库之一,对基于 Windows 架构的应用程序具有完美的支持。TencentDB for SQL Server 拥有微软正版授权,可持续为用户提供最新的功能,避免未授权使用软件的风险。具有即开即用、稳定可靠、安全运行、弹性扩缩等特点。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档