首页 > 数据库 >【技术积累】Mysql中的SQL基础【一】

【技术积累】Mysql中的SQL基础【一】

时间:2023-06-29 10:12:15浏览次数:47  
标签:积累 users SQL 用户 orders Mysql id SELECT name

建表语句

后续所有内容建立在这些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子句筛选出购买过指定产品的用户,即产品名称与指定名称匹配的记录。

标签:积累,users,SQL,用户,orders,Mysql,id,SELECT,name
From: https://www.cnblogs.com/yyyyfly1/p/17513296.html

相关文章

  • 离线安装mysql报错解决方法:/usr/sbin/mysqld: error while loading shared libraries:
    Linux:centos7.664位mysql:5.6使用离线方式安装:rpm-ivh--nodepsmysql*,执行systemctlstartmysqld.service发现启动不了,通过vi/var/log/mysql.log看到如下关键字:libraries:libaio.so.1,之前也是按照网上帖子各种修改都没有解决问题,详细报错如下:/usr/sbin/mysqld:error......
  • 10 | MySQL为什么有时候会选错索引?
    以下内容出自《MySQL实战45讲》10|MySQL为什么有时候会选错索引?优化器的逻辑选择索引是优化器的工作。影响优化器选择的判断标准:扫描行数临时表是否排序扫描行数MySQL在真正执行语句之前,会根据统计信息来估算记录数。这个统计信息就是索引的“区分度“。显然,......
  • Docker实战_Mysql数据卷挂载
    Docker实战_Mysql数据卷挂载搜索镜像dockersearchmysql:5.7下载镜像dockerpullmysql:5.7运行镜像dockerrun-d-p3306:3306\-v/opt/mysql/conf:/etc/mysql/conf.d\-v/opt/mysql/data:/var/lib/mysql\-eMYSQL_ROOT_PASSWORD=123456--namemy-mysqlmysql:......
  • Mysql
    下载:官网:http://dev.mysql.com/downloads/mysql/安装教程:https://blog.csdn.net/weixin_39289696/article/details/128850498Mysql目录介绍:#binmysql.exe#这个是mysql自带的客户端mysqld.exe#这个是mysql的服务端#data'''它......
  • Mysql 日期和时间转换
    https://www.php.cn/faq/523569.html一、MySQL中的日期时间类型在MySQL中,日期时间类型包括DATE、TIME、DATETIME以及TIMESTAMP四种类型。其中,DATE类型表示日期,格式为'YYYY-MM-DD';TIME类型表示时间,格式为'HH:MM:SS';DATETIME类型表示日期和时间,格式为'YYYY-MM-DDHH:MM:SS';TIMESTA......
  • SQL exist
     在SQL中,EXISTS是一个逻辑运算符,用于检查子查询中是否存在满足特定条件的记录。它返回一个布尔值,如果子查询返回至少一行,则返回true,否则返回false。EXISTS的作用是判断一个子查询是否返回结果,而不需要实际获取子查询的结果集。这在某些情况下可以提高查询性能,特别是当子查询......
  • 1、MySQL操作命令学习1
    一、对数据库及表的基础操作1、连接数据库服务器                   mysql-hlocalhost-uroot-p1234562、2.退出服务器                           exit3、查看所有的数据库                  ......
  • PL/SQL
       ......
  • mysql随笔
    备份exchangedb库下的systemtable表mysqldump--defaults-extra-file=/etc/my_pass.txt--flush-logs--single-transaction--set-gtid-purged=OFFexchangedbsystemtable>/data/system_config.sql查看binlog执行的具体操作/usr/bin/mysqlbinlog--no-defaults-v-v--bas......
  • MySqlException(0x80004005) Reading from the stream has failed 远程主机强迫关闭了
    不同客户端电脑连接服务器数据库,通过navicat管理工具可以正常连上,但是通过程序连接提示MySqlException(0x80004005)Readingfromthestreamhasfailed远程主机强迫关闭了一个现有的连接(注意:部分电脑通过程序也是可以正常连接服务器数据库的)解决方法:服务器重新安装Micr......