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

SQL server 中 CROSS APPLY的使用

        CROSS APPLY 是 SQL Server 中的一个操作符,用于将一个表表达式(如子查询、函数等)与外部表进行连接。CROSS APPLY 类似于 INNER JOIN,但它允许你在一个查询中多次引用外部表的行,并且可以动态地生成结果集。

基本语法

SELECT ...
FROM table1
CROSS APPLY (table_expression) AS alias

用途

1. 多行结果:当子查询或表表达式返回多行结果时,CROSS APPLY 可以将这些结果与外部表的每一行进行组合。

2. 动态生成结果:CROSS APPLY 可以根据外部表的每一行动态生成结果集。

3. 复杂计算:在需要对每个外部行进行复杂计算或处理时,CROSS APPLY 非常有用。

示例

假设我们有一个 Employees 表和一个 Orders 表,我们希望获取每个员工的最新订单信息。

表结构

CREATE TABLE Employees (
    EmployeeID INT PRIMARY KEY,
    Name VARCHAR(50)
);

CREATE TABLE Orders (
    OrderID INT PRIMARY KEY,
    EmployeeID INT,
    OrderDate DATE,
    Amount DECIMAL(10, 2)
);

INSERT INTO Employees (EmployeeID, Name)
VALUES (1, '张三'), (2, '李四');

INSERT INTO Orders (OrderID, EmployeeID, OrderDate, Amount)
VALUES 
(1, 1, '2024-01-01', 100.00),
(2, 1, '2024-01-15', 150.00),
(3, 2, '2024-02-01', 200.00),
(4, 2, '2024-02-10', 250.00);

 使用 CROSS APPLY 获取每个员工的最新订单

SELECT e.EmployeeID, e.Name, o.OrderID, o.OrderDate, o.Amount
FROM Employees e
CROSS APPLY (
    SELECT TOP 1 *
    FROM Orders o
    WHERE o.EmployeeID = e.EmployeeID
    ORDER BY o.OrderDate DESC
) AS o;

结果

执行上述查询后,结果将会是:

1. 外部表:Employees 表是外部表。

2. 表表达式:CROSS APPLY 后面的子查询是一个表表达式,它为每个员工返回最新的订单。

3. 连接条件:子查询中的 WHERE o.EmployeeID = e.EmployeeID 确保了子查询只处理当前员工的订单。

4. TOP 1:TOP 1 和 ORDER BY o.OrderDate DESC 确保了子查询返回每个员工的最新订单。 

与其他操作符的区别

•CROSS APPLY:类似于 INNER JOIN,但允许子查询引用外部表的每一行。

•OUTER APPLY:类似于 LEFT JOIN,即使子查询没有返回任何结果,外部表的行也会保留。

示例:

使用 OUTER APPLY假设我们希望即使某些员工没有订单,也能显示他们的信息。 

SELECT e.EmployeeID, e.Name, o.OrderID, o.OrderDate, o.Amount
FROM Employees e
OUTER APPLY (
    SELECT TOP 1 *
    FROM Orders o
    WHERE o.EmployeeID = e.EmployeeID
    ORDER BY o.OrderDate DESC
) AS o;

 结果

如果某个员工没有订单,结果集中对应的部分将显示为 NULL。

总结

CROSS APPLY 和 OUTER APPLY 是 SQL Server 中非常强大的操作符,特别适用于需要对每个外部行进行复杂处理或动态生成结果集的场景。希望这些示例能帮助你更好地理解和使用这些操作符。 


http://www.kler.cn/a/381007.html

相关文章:

  • 【YashanDB知识库】jdbc查询st_geometry类型的数据时抛出YAS-00101错误
  • 浅谈算法交易
  • C语言扫雷游戏教学(有图形界面)(提供源码+实验报告)(计时+排行榜+难度选择+登录注册+背景音乐)(涉及easyX库)
  • docker 容器的基本使用
  • python使用pip进行库的下载
  • 左神算法基础巩固--1
  • SpringBoot+Shiro权限管理
  • 【机器学习】24. 聚类-层次式 Hierarchical Clustering
  • Android Studio 多工程公用module引用
  • 【专属情侣空间】不懂技术,不懂代码,你也可以拥有专属的情侣空间了
  • 各主流编程语言的常见问题点(不定时更新)
  • FrankenPHP实践
  • spring-boot(更换数据源)
  • clickhouse运维篇(二):多机器手动部署ck集群
  • 一篇文章帮你彻底解决gradle、gradle插件、jdk版本兼容性问题
  • 洗衣小程序/洗鞋小程序 洗衣店系统,洗衣系统源码
  • 面试题:JVM(六)
  • 接口/泛型
  • 界面控件DevExpress WPF中文教程:Data Grid——卡片视图概述
  • 阿里云高并发测试-Redis缓存机制
  • pdf文件预览和导出
  • 鉴源实验室·加密技术在汽车系统中的应用
  • 力扣438——找到字符串中的所有字母异位词
  • stack和queue --->容器适配器
  • Oracle Sql查询和性能优化(持续更新)
  • 掌握 Jest 中的模块模拟:提升单元测试的灵活性与可靠性