当前位置: 首页 > news >正文

佛山用户网站建设免费网站开发合同范本

佛山用户网站建设,免费网站开发合同范本,知末设计网官网,莒县做网站的公司文章目录 1. 多表连接(JOIN)功能介绍应用场景示例查询及初始表格customers 表(未查询前)orders 表(未查询前)INNER JOIN 示例LEFT JOIN 示例 2. 子查询(Subquery)功能介绍应用场景示…

文章目录

        • 1. 多表连接(JOIN)
          • 功能介绍
          • 应用场景
          • 示例查询及初始表格
            • `customers` 表(未查询前)
            • `orders` 表(未查询前)
            • INNER JOIN 示例
            • LEFT JOIN 示例
        • 2. 子查询(Subquery)
          • 功能介绍
          • 应用场景
          • 示例查询及初始表格
            • `orders` 表(未查询前)
            • 非相关子查询 示例
            • 相关子查询 示例
        • 3. 聚合函数与分组(GROUP BY)
          • 功能介绍
          • 应用场景
          • 示例查询及初始表格
            • `customers` 表(未查询前)
            • `orders` 表(未查询前)
        • 4. 条件筛选(WHERE)
          • 功能介绍
          • 应用场景
          • 示例查询及初始表格
            • `orders` 表(未查询前)
        • 5. 排序(ORDER BY)
          • 功能介绍
          • 应用场景
          • 示例查询及初始表格
            • `orders` 表(未查询前)
        • 6. 组合使用
          • 功能介绍
          • 应用场景
          • 示例查询及初始表格
            • `customers` 表(未查询前)
            • `orders` 表(未查询前)

1. 多表连接(JOIN)
功能介绍

多表连接是 SQL 中用于从多个表中检索数据的重要操作。它通过指定一个或多个条件来组合来自两个或多个表的数据行。主要类型包括:

  • INNER JOIN:返回两个表中满足连接条件的匹配行。
  • LEFT JOIN (或 LEFT OUTER JOIN):返回左表中的所有记录,即使右表中没有匹配项。对于右表中没有匹配项的情况,结果集中对应的字段将包含 NULL。
  • RIGHT JOIN (或 RIGHT OUTER JOIN):与 LEFT JOIN 相反,返回右表中的所有记录。
  • FULL JOIN (或 FULL OUTER JOIN):返回两个表中的所有记录,当某一方没有匹配时,使用 NULL 填充。
  • CROSS JOIN:返回两个表的笛卡尔积,即每个表的每一行都与其他表的所有行配对。
应用场景

当你需要合并来自多个表的数据时,例如获取客户的订单信息、产品分类详情等,JOIN 是不可或缺的操作。

示例查询及初始表格
customers 表(未查询前)
customer_idcustomer_name
1Alice
2Bob
3Charlie
4Dave
5Eve
orders 表(未查询前)
order_idcustomer_idorder_datetotal_amount
10112024-01-15100.00
10212024-02-20200.00
10322024-03-10150.00
10432024-04-1575.00
10532024-05-22180.00
10612024-06-3090.00
10712024-11-2890.00
10822024-11-30125.00
10932024-12-0175.00
INNER JOIN 示例

查询

SELECT customers.customer_name, orders.order_id, orders.order_date, orders.total_amount
FROM customers
INNER JOIN orders ON customers.customer_id = orders.customer_id;

模拟查询结果

customer_nameorder_idorder_datetotal_amount
Alice1012024-01-15100.00
Alice1022024-02-20200.00
Alice1062024-06-3090.00
Alice1072024-11-2890.00
Bob1032024-03-10150.00
Bob1082024-11-30125.00
Charlie1042024-04-1575.00
Charlie1052024-05-22180.00
Charlie1092024-12-0175.00
LEFT JOIN 示例

查询

SELECT customers.customer_name, orders.order_id, orders.order_date, orders.total_amount
FROM customers
LEFT JOIN orders ON customers.customer_id = orders.customer_id;

模拟查询结果

customer_nameorder_idorder_datetotal_amount
Alice1012024-01-15100.00
Alice1022024-02-20200.00
Alice1062024-06-3090.00
Alice1072024-11-2890.00
Bob1032024-03-10150.00
Bob1082024-11-30125.00
Charlie1042024-04-1575.00
Charlie1052024-05-22180.00
Charlie1092024-12-0175.00
DaveNULLNULLNULL
EveNULLNULLNULL

2. 子查询(Subquery)
功能介绍

子查询是在另一个查询内部执行的查询,它可以出现在 SELECT、FROM、WHERE 或 HAVING 子句中。根据子查询是否依赖于外部查询的结果,可以分为相关子查询和非相关子查询。

  • 非相关子查询:独立于外部查询,通常用于计算聚合值如平均数、最大值等。
  • 相关子查询:依赖于外部查询提供的参数,每次外部查询处理一行时,相关子查询都会重新评估。
应用场景

子查询常用于复杂的条件筛选、查找特定条件下的最值或者进行跨表比较。

示例查询及初始表格
orders 表(未查询前)
order_idcustomer_idorder_datetotal_amount
10112024-01-15100.00
10212024-02-20200.00
10322024-03-10150.00
10432024-04-1575.00
10532024-05-22180.00
10612024-06-3090.00
10712024-11-2890.00
10822024-11-30125.00
10932024-12-0175.00
非相关子查询 示例

查询

SELECT *
FROM orders
WHERE total_amount > (SELECT AVG(total_amount) FROM orders);

模拟查询结果

order_idcustomer_idorder_datetotal_amount
10212024-02-20200.00
10322024-03-10150.00
10532024-05-22180.00
10822024-11-30125.00
相关子查询 示例

查询

SELECT o1.customer_id, o1.order_id, o1.order_date, o1.total_amount
FROM orders o1
WHERE o1.total_amount = (SELECT MAX(o2.total_amount)FROM orders o2WHERE o1.customer_id = o2.customer_id
);

模拟查询结果

customer_idorder_idorder_datetotal_amount
11022024-02-20200.00
21032024-03-10150.00
31052024-05-22180.00

3. 聚合函数与分组(GROUP BY)
功能介绍

聚合函数如 COUNT(), SUM(), AVG(), MIN(), MAX() 等用于执行数值汇总操作。GROUP BY 子句用于将数据按照一个或多个列进行分组,然后对每个组应用聚合函数。

应用场景

当你需要对数据进行分类汇总时,例如计算每个客户的总订单金额、统计不同类别的商品数量等,GROUP BY 结合聚合函数是非常有效的工具。

示例查询及初始表格
customers 表(未查询前)
customer_idcustomer_name
1Alice
2Bob
3Charlie
4Dave
5Eve
orders 表(未查询前)
order_idcustomer_idorder_datetotal_amount
10112024-01-15100.00
10212024-02-20200.00
10322024-03-10150.00
10432024-04-1575.00
10532024-05-22180.00
10612024-06-3090.00
10712024-11-2890.00
10822024-11-30125.00
10932024-12-0175.00

查询

SELECT c.customer_name, SUM(o.total_amount) AS total_spent
FROM customers c
JOIN orders o ON c.customer_id = o.customer_id
GROUP BY c.customer_name
ORDER BY total_spent DESC;

模拟查询结果

customer_nametotal_spent
Alice480.00
Charlie330.00
Bob275.00

4. 条件筛选(WHERE)
功能介绍

WHERE 子句用于过滤记录,只有符合条件的记录才会被包含在最终的结果集中。可以在 WHERE 中使用比较运算符(=, <, >, <=, >=, <>)、逻辑运算符(AND, OR, NOT)以及其他一些特定的运算符(LIKE, IN, BETWEEN…AND…)来进行复杂的条件组合。

应用场景

WHERE 子句广泛应用于数据过滤,比如选择特定日期范围内的记录、查找特定类别或状态的数据等。

示例查询及初始表格
orders 表(未查询前)
order_idcustomer_idorder_datetotal_amount
10112024-01-15100.00
10212024-02-20200.00
10322024-03-10150.00
10432024-04-1575.00
10532024-05-22180.00
10612024-06-3090.00
10712024-11-2890.00
10822024-11-30125.00
10932024-12-0175.00

查询

SELECT *
FROM orders
WHERE YEAR(order_date) = 2024;

模拟查询结果

order_idcustomer_idorder_datetotal_amount
10112024-01-15100.00
10212024-02-20200.00
10322024-03-10150.00
10432024-04-1575.00
10532024-05-22180.00
10612024-06-3090.00
10712024-11-2890.00
10822024-11-30125.00
10932024-12-0175.00

5. 排序(ORDER BY)
功能介绍

ORDER BY 子句用于对查询结果按照一个或多个列进行排序,默认为升序排列(ASC),可以通过指定 DESC 实现降序排列。你还可以对多个列进行排序,优先级从左到右。

应用场景

当你希望按某种顺序展示查询结果时,例如按照时间先后、金额大小等,ORDER BY 是必不可少的。

示例查询及初始表格
orders 表(未查询前)
order_idcustomer_idorder_datetotal_amount
10112024-01-15100.00
10212024-02-20200.00
10322024-03-10150.00
10432024-04-1575.00
10532024-05-22180.00
10612024-06-3090.00
10712024-11-2890.00
10822024-11-30125.00
10932024-12-0175.00

查询

SELECT *
FROM orders
ORDER BY order_date DESC;

模拟查询结果

order_idcustomer_idorder_datetotal_amount
10932024-12-0175.00
10822024-11-30125.00
10712024-11-2890.00
10612024-06-3090.00
10532024-05-22180.00
10432024-04-1575.00
10322024-03-10150.00
10212024-02-20200.00
10112024-01-15100.00

或者根据多个字段排序:

查询

SELECT *
FROM orders
ORDER BY customer_id ASC, order_date DESC;

模拟查询结果

order_idcustomer_idorder_datetotal_amount
10712024-11-2890.00
10612024-06-3090.00
10212024-02-20200.00
10112024-01-15100.00
10822024-11-30125.00
10322024-03-10150.00
10932024-12-0175.00
10532024-05-22180.00
10432024-04-1575.00

6. 组合使用
功能介绍

实际应用中,通常会结合多种 SQL 特性来构建复杂的查询。例如,你可以同时使用 JOIN、子查询、聚合函数、WHERE 过滤、HAVING 筛选以及 ORDER BY 排序,以精确控制查询的结果集。

应用场景

这种组合使用非常普遍,尤其是在需要处理复杂业务逻辑或分析大量数据时。例如,查找特定年份内每个客户的订单总数,并且只显示订单数超过一定阈值的客户,同时按订单数降序排列。

示例查询及初始表格
customers 表(未查询前)
customer_idcustomer_name
1Alice
2Bob
3Charlie
4Dave
5Eve
orders 表(未查询前)
order_idcustomer_idorder_datetotal_amount
10112024-01-15100.00
10212024-02-20200.00
10322024-03-10150.00
10432024-04-1575.00
10532024-05-22180.00
10612024-06-3090.00
10712024-11-2890.00
10822024-11-30125.00
10932024-12-0175.00

查询

SELECT c.customer_name, COUNT(o.order_id) AS order_count
FROM customers c
JOIN orders o ON c.customer_id = o.customer_id
WHERE YEAR(o.order_date) = 2024
GROUP BY c.customer_name
HAVING COUNT(o.order_id) > 5
ORDER BY order_count DESC;

模拟查询结果

customer_nameorder_count
Alice4

示例数据中没有一个客户的订单数量超过5个,所以这里只有Alice满足条件。如果有更多的订单数据,可能会有更多的客户出现在结果中。

http://www.yayakq.cn/news/714854/

相关文章:

  • 建设银行网站登陆不了甘家口网站建设
  • wordpress cdn无作用东莞网站建设seo推广
  • 厦门商城网站开发怎样做网站规划
  • 残疾人无障碍网站怎么做wordpress调用目录下
  • 什么游戏不用登录直接玩石家庄抖音seo
  • 做房产网站在百度推广推广费个人建网站一般多少钱?
  • 莆田市的网站建设公司python免费下载安装
  • 做汽配找哪个网站好网站制作公司浩森宇特
  • 中铁中基建设集团网站烟台手机网站建设费用
  • 电子商务网站建设考试题电子商务网站平台建设
  • cn域名后缀网站注册过哪些网站
  • 一个网站的构建seo就业前景怎么样
  • 风险的网站怎么出现wordpress浮动视频
  • 南阳那里有做网站的小程序开发公司哪家正规
  • 海东企业网站建设公司企业网站页脚信息
  • c 网站开发连接mysql9377网页游戏
  • 东莞阳光网站建设成效郑州技术支持seo
  • 网站建设的成功之处有哪些企业seo是什么意思
  • 帝国怎么做中英文网站提供营销单页网站
  • 一般网站维护需要做什么服装设计手稿设计图
  • 北京建网站的公司公司网站制作步骤流程图
  • 外贸网站多语言wordpress 只显示某分类
  • 外贸网站建设要求找客户信息的软件
  • 宁波网站推广怎么做如何做微信官方网站
  • 天津网站建设网站推广wordpress 页面链接
  • 网站建设要准备些什么以下可以制作二维码的网站为
  • 网站主机空间wordpress应用下载主题
  • 网站建设厘金手指排名二二开发公司是生产经营单位吗
  • 网站到期续费吗免费咨询皮肤科医生在线
  • 营销型网站建设范文免费制作h5页面平台