【技术积累】Mysql中的SQL语言【一】
建表语句
后续所有内容建立在这些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)
);
学习要点
知识点学习
查询单个列的数据
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_count
FROM users
LEFT JOIN orders ON users.id = orders.user_id
GROUP 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_amount
FROM users
LEFT JOIN orders ON users.id = orders.user_id
GROUP BY users.id;
以上SQL语句中,通过左外连接将用户表和订单表关联起来,然后使用GROUP BY子句按用户进行分组,使用MAX聚合函数找到每个用户的最高订单金额。
查询订单数量最多的用户
需要找出订单数量最多的用户,以了解谁是最活跃的用户。
SELECT users.id AS user_id, users.name AS user_name, COUNT(orders.id) AS order_count
FROM users
LEFT JOIN orders ON users.id = orders.user_id
GROUP BY users.id
ORDER BY order_count DESC
LIMIT 1;
以上SQL语句中,通过左外连接将用户表和订单表关联起来,然后使用GROUP BY子句按用户进行分组,并使用COUNT函数统计每个用户的订单数量。最后使用ORDER BY子句将结果按订单数量降序排序,并使用LIMIT限制只返回第一条结果,即订单数量最多的用户。
问题4: 查询最近一个月内的订单数量
需要查询最近一个月内的订单数量,以了解近期的订单情况。
SELECT COUNT(id) AS order_count
FROM orders
WHERE date >= DATE_SUB(CURRENT_DATE(), INTERVAL 1 MONTH);
以上SQL语句中,使用COUNT函数统计最近一个月内的订单数量。通过将当前日期减去一个月的时间间隔来计算出一个月前的日期,并使用WHERE子句筛选出指定日期范围内的订单。
问题5: 查询购买最多的产品
需要查询购买数量最多的产品,以了解最受欢迎的产品。
SELECT product_name, COUNT(id) AS sales_count
FROM orders
GROUP BY product_name
ORDER BY sales_count DESC
LIMIT 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_amount
FROM users
LEFT JOIN orders ON users.id = orders.user_id
GROUP BY users.id;
以上SQL语句中,通过左外连接将用户表和订单表关联起来,然后使用GROUP BY子句按用户进行分组,使用AVG聚合函数找到每个用户的平均订单金额。
问题7: 查询未购买任何产品的用户
需要查询未购买任何产品的用户,以了解哪些用户还没有进行购物。
SELECT users.id, users.name
FROM users
LEFT JOIN orders ON users.id = orders.user_id
WHERE orders.id IS NULL;
以上SQL语句中,通过左外连接将用户表和订单表关联起来,然后使用WHERE子句筛选出未购买任何产品的用户,即订单ID为空的记录。
问题8: 查询订单金额超过平均订单金额的用户
需要查询订单金额超过平均订单金额的用户,以了解哪些用户的消费能力高于平均水平。
SELECT users.id AS user_id, users.name AS user_name, orders.price AS order_amount
FROM users
JOIN orders ON users.id = orders.user_id
WHERE 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_date
FROM users
JOIN orders ON users.id = orders.user_id
GROUP BY users.id;
以上SQL语句中,通过JOIN将用户表和订单表连接起来,然后使用GROUP BY子句按用户进行分组,使用MIN函数找到每个用户的最早购买日期。
问题10: 查询购买过某个产品的用户
需要查询购买过某个产品的用户,以了解对于某个指定的产品,都有哪些用户购买过。
SELECT users.id AS user_id, users.name AS user_name
FROM users
JOIN orders ON users.id = orders.user_id
WHERE orders.product_name = '指定产品名称';
以上SQL语句中,通过JOIN将用户表和订单表连接起来,然后使用WHERE子句筛选出购买过指定产品的用户,即产品名称与指定名称匹配的记录。
【技术积累】Mysql中的SQL语言【一】的更多相关文章
- MySQL中的SQL语言
从功能上划分,SQL 语言可以分为DDL,DML和DCL三大类.1. DDL(Data Definition Language)数据定义语言,用于定义和管理 SQL 数据库中的所有对象的语言 :CRE ...
- MySQL入门——MySQL数据库和SQL语言
MySQL入门——MySQL数据库和SQL语言 摘要:本文主要了解了MySQL关系型数据库和SQL语言的基本知识. MySQL数据库 简介 MySQL是一个关系型数据库管理系统,由瑞典MySQL AB ...
- MySQL中执行sql语句错误 Error Code: 1093. You can't specify target table 'car' for update in FROM clause
MySQL中执行sql语句错误 Error Code: 1093. You can't specify target table 'car' for update in FROM clause 201 ...
- 浅谈MySQL中优化sql语句查询常用的30种方法 - 转载
浅谈MySQL中优化sql语句查询常用的30种方法 1.对查询进行优化,应尽量避免全表扫描,首先应考虑在 where 及 order by 涉及的列上建立索引. 2.应尽量避免在 where 子句中使 ...
- 【原创】6. 在MYSQL++中实现SQL语法中的NULL
这次要说明的是在MYSQL++中为了实现SQL中的NULL而做出的一系列的举措.我的感觉是Null<T, B>类型通常出现在SSQLS和template Query中比较多. 1. 什么是 ...
- Mysql中的sql是如何执行的 --- 极客时间学习笔记
MySQL中的SQL是如何执行的 MySQL是典型的C/S架构,也就是Client/Server架构,服务器端程序使用的mysqld.整体的MySQL流程如下图所示: MySQL是有三层组成: 连接层 ...
- MySQL中的SQL的常见优化策略
MySQL中的SQL的常见优化策略 MySQL中的索引优化 MySQL中的索引简介 1 避免全表扫描对查询进行优化,应尽量避免全表扫描,首先应考虑在 where 及 order by 涉及的列上建立索 ...
- 【MySQL笔记】SQL语言四大类语言
SQL语言共分为四大类:数据查询语言DQL,数据操纵语言DML,数据定义语言DDL,数据控制语言DCL. 1. 数据查询语言DQL 数据查询语言DQL基本结构是由SELECT子句,FROM子句, ...
- mysql数据库基本操作sql语言
mysql的启动与关闭 启动 /etc/init.d/mysql start 多实例使用自建脚本启动 2种关闭数据库方法 mysqladmin -uroot -p密码 shutdown #优雅关闭/e ...
- MySQL: 2、SQL语言
一.SQL的简介: 1.SQL的概念: SQL就是结构化查询语言,是一种特殊目的的编程语言,是一种数据库查询和程序设计语言,用于存取数据以及查询.更新和管理关系数据库系统 2.SQL的作用: - ...
随机推荐
- CentOS8删除boot目录恢复
系统安装完之后,boot分区最好做一个备份,因为这个分区 我们基本不会动它,所以备份一次一劳永逸,以防万一.如果我们不小心 误删除了这个目录,也不用慌,正因为这个分区,我们除了开机 其他时候基本用不到 ...
- Ubuntu2204部署容器引擎Containerd
为什么使用containerd? 使用containerd的原因主要有两点吧,第一个是docker在k8s1.24以后不再支持,如果需要在k8s中继续使用docker作为容器引擎,我们需要额外部署cr ...
- Kubernetes客户端认证——基于CA证书的双向认证方式
1.Kubernetes 认证方式 Kubernetes集群的访问权限控制由API Server负责,API Server的访问权限控制由身份验证(Authentication).授权(Authori ...
- golang 必会之 pprof 监控系列(5) —— cpu 占用率 统计原理
golang pprof 监控系列(5) -- cpu 占用率 统计原理 大家好,我是蓝胖子. 经过前面的几节对pprof的介绍,对pprof统计的原理算是掌握了七八十了,我们对memory,bloc ...
- 【Ubuntu】 Perf工具的使用
一.perf工具的安装 sudo apt-get install linux-tools-common sudo apt-get install linux-tools-"$(uname - ...
- 笔记:linux必备网络基础概念和以太网技术基础
笔记:linux必备网络基础概念和以太网技术基础 由于后面可能需要对交换机进行一些配置,所以也是临时学习一下iptables的相关配置,以及一些基本的网络知识,下面就是我看到一些资料做的一些总结,希望 ...
- [OpenCV-Python] 8 用滑动条做调色板
文章目录 OpenCV-Python:II OpenCV 中的 Gui 特性 8 用滑动条做调色板 8.1 代码示例 练习 OpenCV-Python:II OpenCV 中的 Gui 特性 8 用滑 ...
- KMP算法学习笔记
总算把这个东西搞懂了...... KMP是一个求解字符串匹配问题的算法. 这个东西的核心是一个\(next\)数组,\(next_i\)表示字符串第\(0\sim i\)项的相同的前缀和后缀的最大长度 ...
- Prometheus-Operator使用ServiceMonitor监控配置时遇坑与解决总结
摘要 本文范围: Prometheus-Operator & kube-prometheus 安装:以及在解决使用ServiceMonitor时遇到的坑. Prometheus Operato ...
- Three.js 进阶之旅:页面平滑滚动-王国之泪 💧
声明:本文涉及图文和模型素材仅用于个人学习.研究和欣赏,请勿二次修改.非法传播.转载.出版.商用.及进行其他获利行为. 摘要 浏览网页时,常被一些基于鼠标滚轮控制的页面动画所惊艳到,比如greenso ...