【技术积累】Mysql中的SQL语言【一】_世界观天下
2023-06-29 10:19:58 来源:博客园
后续所有内容建立在这些SQL语句上,数据根据需要自行补充
(资料图片仅供参考)
CREATE TABLE users ( id INT PRIMARY KEY, name VARCHAR(50), age INT);CREATE TABLE orders ( id INT PRIMARY KEY, user_id INT, product_name VARCHAR(50), price DECIMAL(10,2), FOREIGN KEY (user_id) REFERENCES users(id));
INSERT INTO users (id, name, age) VALUES (1, "Alice", 25);INSERT INTO users (id, name, age) VALUES (2, "Bob", 30);INSERT INTO users (id, name, age) VALUES (3, "Charlie", 35);INSERT INTO orders (id, user_id, product_name, price) VALUES (1, 1, "Product A", 10.99);INSERT INTO orders (id, user_id, product_name, price) VALUES (2, 1, "Product B", 15.99);INSERT INTO orders (id, user_id, product_name, price) VALUES (3, 2, "Product C", 20.99);INSERT INTO orders (id, user_id, product_name, price) VALUES (4, 2, "Product A", 10.99);INSERT INTO orders (id, user_id, product_name, price) VALUES (5, 3, "Product B", 15.99);
学习要点知识点学习查询单个列的数据
SELECT column_name FROM table_name;
查询多个列的数据
SELECT column1, column2 FROM table_name;
带条件查询数据
SELECT column1, column2 FROM table_name WHERE condition;
插入数据
INSERT INTO table_name (column1, column2, ...) VALUES (value1, value2, ...);
更新数据
UPDATE table_name SET column1=value1, column2=value2, ... WHERE condition;
删除数据
DELETE FROM table_name WHERE condition;
根据某列升序排序:
SELECT * FROM table_name ORDER BY column_name ASC;
根据某列降序排序:
SELECT * FROM table_name ORDER BY column_name DESC;
计算某列的总和:
SELECT SUM(column_name) FROM table_name;
计算某列的平均值:
SELECT AVG(column_name) FROM table_name;
按某列分组:
SELECT column_name, COUNT(column_name) FROM table_name GROUP BY column_name;
联结
内连接是一种用于联接两个或多个表的方法。它只返回满足连接条件的行,也就是两个表中具有相同值的行。内连接使用关键字"INNER JOIN"来连接两个或多个表,它可以包含一个或多个连接条件。
例如,假设有两个表A和B,表A中有列a,表B中有列b。通过内连接在表A和表B之间进行连接,只会返回那些同时满足"a = b"条件的行。内连接可以帮助我们从两个或多个相关表中获取相关数据。
SELECT table1.column1, table2.column2 FROM table1 INNER JOIN table2 ON table1.id = table2.id;
左外连接两个表:
左外连接是一种用于联接两个或多个表的方法,在MySQL中使用"LEFT JOIN"关键字来实现。左外连接返回两个表中满足连接条件的所有行,以及左表中不满足连接条件的行。
假设有两个表A和B,通过左外连接在表A和表B之间进行连接,查询将返回满足连接条件的行以及左表A中不满足连接条件的行。右表B中不满足连接条件的行的值将被设置为NULL。
这个查询将返回表A中所有行的a列的值,以及在表B中具有相同值的b列的值。如果在表B中没有具有相同值的行,b列的值将为NULL。
左外连接适用于在两个表中寻找关联数据,即使在右表中没有匹配的行时也可以返回左表的数据。这对于获取主表所有数据以及与之关联的次要表的数据很有用。
SELECT table1.column1, table2.column2 FROM table1 LEFT JOIN table2 ON table1.id = table2.id;
右外连接两个表:
右外连接是一种用于联接两个或多个表的方法,在MySQL中使用"RIGHT JOIN"关键字来实现。右外连接返回右表中满足连接条件的所有行,以及右表中不满足连接条件的行。
假设有两个表A和B,通过右外连接在表A和表B之间进行连接,查询将返回满足连接条件的行以及右表B中不满足连接条件的行。左表A中不满足连接条件的行的值将被设置为NULL。
以下是一个右外连接的示例查询:
SELECT table1.column1, table2.column2 FROM table1 RIGHT JOIN table2 ON table1.id = table2.id;
这个查询将返回表B中所有行的b列的值,以及在表A中具有相同值的a列的值。如果在表A中没有具有相同值的行,a列的值将为NULL。
右外连接适用于在两个表中寻找关联数据,即使在左表中没有匹配的行时也可以返回右表的数据。它可以用于获取右表所有数据以及与之关联的主表的数据。在实际应用中,左外连接更常见,而右外连接往往用左外连接完成同样的任务。
子查询
使用子查询:
SELECT column_name1 FROM table_name WHERE column_name2 IN (SELECT column_name3 FROM table_name2 WHERE condition);
案例列举问题1: 统计每个用户的订单总数
需要统计每个用户的订单总数,以便了解用户的购买情况。
SELECT users.id AS user_id, users.name AS user_name, COUNT(orders.id) AS order_countFROM usersLEFT JOIN orders ON users.id = orders.user_idGROUP BY users.id;
以上SQL语句中,首先通过左外连接将用户表和订单表关联起来,然后使用GROUP BY子句按用户进行分组,使用COUNT聚合函数统计每个用户的订单数量。
问题2: 查询每个用户的最高订单金额
需要查询每个用户的最高订单金额,以了解用户的购买能力。
SELECT users.id AS user_id, users.name AS user_name, MAX(orders.price) AS max_order_amountFROM usersLEFT JOIN orders ON users.id = orders.user_idGROUP BY users.id;
以上SQL语句中,通过左外连接将用户表和订单表关联起来,然后使用GROUP BY子句按用户进行分组,使用MAX聚合函数找到每个用户的最高订单金额。
问题3: 查询订单数量最多的用户
需要找出订单数量最多的用户,以了解谁是最活跃的用户。
SELECT users.id AS user_id, users.name AS user_name, COUNT(orders.id) AS order_countFROM usersLEFT JOIN orders ON users.id = orders.user_idGROUP BY users.idORDER BY order_count DESCLIMIT 1;
以上SQL语句中,通过左外连接将用户表和订单表关联起来,然后使用GROUP BY子句按用户进行分组,并使用COUNT函数统计每个用户的订单数量。最后使用ORDER BY子句将结果按订单数量降序排序,并使用LIMIT限制只返回第一条结果,即订单数量最多的用户。
问题4: 查询最近一个月内的订单数量
需要查询最近一个月内的订单数量,以了解近期的订单情况。
SELECT COUNT(id) AS order_countFROM ordersWHERE date >= DATE_SUB(CURRENT_DATE(), INTERVAL 1 MONTH);
以上SQL语句中,使用COUNT函数统计最近一个月内的订单数量。通过将当前日期减去一个月的时间间隔来计算出一个月前的日期,并使用WHERE子句筛选出指定日期范围内的订单。
问题5: 查询购买最多的产品
需要查询购买数量最多的产品,以了解最受欢迎的产品。
SELECT product_name, COUNT(id) AS sales_countFROM ordersGROUP BY product_nameORDER BY sales_count DESCLIMIT 1;
以上SQL语句中,使用COUNT函数统计每个产品的销售数量,并使用GROUP BY子句按产品名称进行分组。最后使用ORDER BY子句将结果按销售数量降序排序,并使用LIMIT限制只返回第一条结果,即销售数量最多的产品。
问题6: 查询每个用户的平均订单金额
需要查询每个用户的平均订单金额,以了解用户的平均消费水平。
SELECT users.id AS user_id, users.name AS user_name, AVG(orders.price) AS avg_order_amountFROM usersLEFT JOIN orders ON users.id = orders.user_idGROUP BY users.id;
以上SQL语句中,通过左外连接将用户表和订单表关联起来,然后使用GROUP BY子句按用户进行分组,使用AVG聚合函数找到每个用户的平均订单金额。
问题7: 查询未购买任何产品的用户
需要查询未购买任何产品的用户,以了解哪些用户还没有进行购物。
SELECT users.id, users.nameFROM usersLEFT JOIN orders ON users.id = orders.user_idWHERE orders.id IS NULL;
以上SQL语句中,通过左外连接将用户表和订单表关联起来,然后使用WHERE子句筛选出未购买任何产品的用户,即订单ID为空的记录。
问题8: 查询订单金额超过平均订单金额的用户
需要查询订单金额超过平均订单金额的用户,以了解哪些用户的消费能力高于平均水平。
SELECT users.id AS user_id, users.name AS user_name, orders.price AS order_amountFROM usersJOIN orders ON users.id = orders.user_idWHERE orders.price > (SELECT AVG(price) FROM orders);
以上SQL语句中,使用子查询找到订单表中的平均订单金额,然后通过JOIN将用户表和订单表连接起来,使用WHERE子句筛选出订单金额超过平均订单金额的用户。
问题9: 查询每个用户的首次购买日期
需要查询每个用户的首次购买日期,以了解用户的注册后多久开始购物。
SELECT users.id AS user_id, users.name AS user_name, MIN(orders.date) AS first_purchase_dateFROM usersJOIN orders ON users.id = orders.user_idGROUP BY users.id;
以上SQL语句中,通过JOIN将用户表和订单表连接起来,然后使用GROUP BY子句按用户进行分组,使用MIN函数找到每个用户的最早购买日期。
问题10: 查询购买过某个产品的用户
需要查询购买过某个产品的用户,以了解对于某个指定的产品,都有哪些用户购买过。
SELECT users.id AS user_id, users.name AS user_nameFROM usersJOIN orders ON users.id = orders.user_idWHERE orders.product_name = "指定产品名称";
以上SQL语句中,通过JOIN将用户表和订单表连接起来,然后使用WHERE子句筛选出购买过指定产品的用户,即产品名称与指定名称匹配的记录。
关键词:
为你推荐
-
【技术积累】Mysql中的SQL语言【一】_世界观天下
-
宝贝,谢谢你来过_焦点日报
-
方伊琪_关于方伊琪简介|当前简讯
-
中物联:1-5月全国社会物流总额同比增长4.5%
-
戏曲资料名称发源地主要特点(戏曲资料)_天天即时看
-
亚通股份:6月28日融券卖出金额8752.00元,占当日流出金额的0.13%_环球快讯
-
广袤无垠的拼音(广袤无垠)_环球热文
-
今日聚焦!99部新片,暑假档能否重回“百亿时代”?
-
张本美和打服对手!韩国媒体:她是神童,能与中国军团相提并论
-
男子结识开超跑“富婆”,反被骗50余万
-
地下管廊板块6月28日涨0.22%,顾地科技领涨,主力资金净流出1.69亿元|每日快看
-
qq自定义图片怎么弄(qq自定义图片)
-
鸟类扑翼飞行流动控制机理的数值研究_关于鸟类扑翼飞行流动控制机理的数值研究简述|焦点短讯
-
滚动:男子以“刷单”为名诈骗邻居60万余元被判刑
-
田五起义_关于田五起义介绍
-
筑牢防汛“完全网”!-全球信息
-
热门:和评理 | 马克龙的“苦口直言” 美国该听听了
-
热文:夏季达沃斯的声音 | 直面挑战 重启增长
-
中公教育发生2笔大宗交易 合计成交1.01亿元 环球热推荐
-
环球热门:中国银行业协会举办反洗钱线上公益讲堂
推荐内容
- 【技术积累】Mysql中的SQL语言【一】_世界观天下
- 宝贝,谢谢你来过_焦点日报
- 方伊琪_关于方伊琪简介|当前简讯
- 中物联:1-5月全国社会物流总额同比增长4.5%
- 戏曲资料名称发源地主要特点(戏曲资料)_天天即
- 亚通股份:6月28日融券卖出金额8752.00元,占当日
- 广袤无垠的拼音(广袤无垠)_环球热文
- 今日聚焦!99部新片,暑假档能否重回“百亿时代”?
- 张本美和打服对手!韩国媒体:她是神童,能与中国
- 男子结识开超跑“富婆”,反被骗50余万
- 地下管廊板块6月28日涨0.22%,顾地科技领涨,主力
- qq自定义图片怎么弄(qq自定义图片)
- 鸟类扑翼飞行流动控制机理的数值研究_关于鸟类扑
- 滚动:男子以“刷单”为名诈骗邻居60万余元被判刑
- 田五起义_关于田五起义介绍
- 筑牢防汛“完全网”!-全球信息
- 热门:和评理 | 马克龙的“苦口直言” 美国该听听了
- 热文:夏季达沃斯的声音 | 直面挑战 重启增长
- 中公教育发生2笔大宗交易 合计成交1.01亿元 环
- 环球热门:中国银行业协会举办反洗钱线上公益讲堂
- ps蒙版作用举例_ps蒙版作用
- 常德经开区开展生活垃圾分类宣传活动-环球时讯
- 祁文华调研市场发展工作时强调 以创
- 2023年上海五险一金缴费标准一览表 2023年上海五
- 天天最新:估值超30亿美元,多点再度冲击IPO,求
- 当前视讯!明年竣工通车!厂通路潮白河大桥迎重要
- 民航业稳健复苏提振市场信心
- 电动车奔驰EQS SUV试驾,顶级版580 4Matic,超
- 华夏理财发布首批10只天工指数类产品 视点
- 华为很急,等不起赛力斯
- 每日消息!海口发布雷电黄色预警信号
- 成都金牛区保租房城投臻寓青春泉水还有房源吗?_
- 日常有灰指甲要注意什么?怎么区别灰指甲和指甲分
- 祁阳市委办机关一支部联合唐家岭村党支部开展特色
- 世界热议:上海医院门诊出现猴痘传播?最新回应:
- 【全球快播报】6月28日国内BDO部分厂家公布竞拍价格
- 全球热议:晓庄学院杨书记被免职,但身体给力,吃
- 北约秘书长:普里戈任的一些部队可能会驻扎在白俄
- 江海股份:公司产品在新能源车上的配套主要是车载
- “第三支箭”后A股首批上市房企再融资项目落地
油气
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
经济
-
中新网通辽10月18日电 (记者 张林虎)18日,记者从内蒙古自治区通辽市奈曼旗公安局获悉,国家一级保护动物--梅花鹿误入当地村民羊群,
-
中新网杭州10月18日电 (王题题 胡燕婕)云天收夏色,浅秋正渐浓。10月18日,浙江杭州市西湖游船有限公司推出的惠民多站点“西湖环湖游
-
中新网福州10月18日电 (记者 龙敏 王东明)福州市晋安区官方18日晚间通报,18日14时47分,晋安区岳峰镇化工路爱摩轮商业广场项目摩天
-
中新网兰州10月18日电 (闫姣 艾庆龙 吉翔)“红山白土头,黄河向西流。”不少人疑问,天下黄河向东流,为何甘肃永靖县这段黄河却向西
-
中新网北京10月18日电 《清华城市健康设施指数》18日在北京发布。报告成果显示,城市健康设施指数领先城市以中心城市和东部沿海城市