亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

SQL Server使用CROSS APPLY與OUTER APPLY實(shí)現(xiàn)連接查詢

 更新時(shí)間:2022年05月24日 10:02:30   作者:springsnow  
這篇文章介紹了SQL Server使用CROSS APPLY與OUTER APPLY實(shí)現(xiàn)連接查詢的方法,文中通過示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下

概述

CROSS APPLY 與 OUTER APPLY 可以做到:
左表一條關(guān)聯(lián)右表多條記錄時(shí),我需要控制右表的某一條或多條記錄跟左表匹配的情況。

有兩張表:Student(學(xué)生表)和 Score(成績(jī)表),數(shù)據(jù)如下:

一、CROSS APPLY

ROSS APPLY 的意思是“交叉應(yīng)用”,在查詢時(shí)首先查詢左表,,然后右表的每一條記錄跟左表的當(dāng)前記錄進(jìn)行匹配。匹配成功則將左表與右表的記錄合并為一條記錄輸出;匹配失敗則拋棄左表與右表的記錄。(與 INNER JOIN 類似)

查詢每個(gè)學(xué)生最近兩次的考試成績(jī)。

SELECT T1.StudentNo, T1.Name, T2.ExamScore, T2.ExamDate FROM Student AS T1
CROSS APPLY
(
    SELECT TOP 2 * FROM Score AS T
    WHERE T1.StudentNo = T.StudentNo
    ORDER BY T.ExamDate DESC
) AS T2

結(jié)果:

二、OUTER APPLY

OUTER APPLY 的意思是“外部應(yīng)用”,與 CROSS APPLY 的原理一致,只是在匹配失敗時(shí),左表與右表也將合并為一條記錄輸出,不過右表的輸出字段為null。(與 LEFT OUTER JOIN 類似)

查詢每個(gè)學(xué)生最近兩次的考試成績(jī),沒有參加考試的同學(xué)成績(jī)補(bǔ) null

SELECT T1.StudentNo, T1.Name, T2.ExamScore, T2.ExamDate FROM Student AS T1
OUTER APPLY
(
    SELECT TOP 2 * FROM Score AS T
    WHERE T1.StudentNo = T.StudentNo
    ORDER BY T.ExamDate DESC
) AS T2

結(jié)果:

三、應(yīng)用場(chǎng)景

1.結(jié)合表值函數(shù)使用:

有一張表是這樣的:

很簡(jiǎn)單的一張表,就一個(gè)字段num,我想把這個(gè)字段的int型數(shù)字分別轉(zhuǎn)化成二進(jìn)制八進(jìn)制和十六進(jìn)制的數(shù)值,有現(xiàn)成的進(jìn)制轉(zhuǎn)化的表值函數(shù)。

SELECT * FROM #T a CROSS APPLY [dbo].[F_TConversion](a.num)

總結(jié)一下:如果查詢結(jié)果集需要用到表值函數(shù)對(duì)某個(gè)字段的值進(jìn)行處理的話,請(qǐng)使用CROSS APPLY~

2.top子查詢的用法:

有一張學(xué)生表,分別name,學(xué)科,分?jǐn)?shù) 這三個(gè)字段,如下:

我要看語文第一名,數(shù)學(xué)前兩名,英語前三名的name,學(xué)科,分?jǐn)?shù),用cross apply實(shí)現(xiàn)方法如下:

SELECT b.* FROM (
    select Subject='Chiness',num=1 union all
    select 'Math',2 union all
    select 'English',3) a 
cross apply 
    (select top(a.num) * from Students where Subject=a.Subject ) b

到此這篇關(guān)于SQL Server使用CROSS APPLY與OUTER APPLY實(shí)現(xiàn)連接查詢的文章就介紹到這了。希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • SqlServer 垂直分表(減少程序改動(dòng))

    SqlServer 垂直分表(減少程序改動(dòng))

    當(dāng)單表數(shù)據(jù)太多時(shí),我們可以水平劃分,參考 SqlServer 分區(qū)視圖實(shí)現(xiàn)水平分表 ,水平劃分可以提高表的一些性能
    2021-04-04
  • SQL Server創(chuàng)建用戶只能訪問指定數(shù)據(jù)庫(kù)和視圖的操作步驟

    SQL Server創(chuàng)建用戶只能訪問指定數(shù)據(jù)庫(kù)和視圖的操作步驟

    本文介紹了如何在SQLServer中創(chuàng)建用戶并限定其訪問權(quán)限,包括創(chuàng)建用戶、設(shè)置用戶映射、設(shè)置只能訪問指定的數(shù)據(jù)表或視圖、給指定表或視圖賦予具體權(quán)限和檢查權(quán)限等步驟,這種設(shè)置可以防止用戶訪問到過多不必要的過程表和過程視圖,提高數(shù)據(jù)安全性
    2024-10-10
  • SQL字符串處理函數(shù)大全

    SQL字符串處理函數(shù)大全

    這篇文章主要介紹了sqlserver中常用的字符串處理函數(shù),需要的朋友可以參考下
    2013-11-11
  • SQL Server 服務(wù)器優(yōu)化技巧淺談

    SQL Server 服務(wù)器優(yōu)化技巧淺談

    數(shù)據(jù)文件和日志文件的操作會(huì)產(chǎn)生大量的I/O。在可能的條件下,日志文件應(yīng)該存放在一個(gè)與數(shù)據(jù)和索引所在的數(shù)據(jù)文件不同的硬盤上以分散I/O,同時(shí)還有利于數(shù)據(jù)庫(kù)的災(zāi)難恢復(fù)。
    2010-03-03
  • SQL Server Page結(jié)構(gòu)深入分析

    SQL Server Page結(jié)構(gòu)深入分析

    這篇文章主要介紹了SQL Server Page結(jié)構(gòu)的詳細(xì)分析,從概念,原理等方便做了詳細(xì)說明,一起來學(xué)習(xí)下。
    2017-12-12
  • 詳解sqlserver查詢表索引

    詳解sqlserver查詢表索引

    sqlserver查詢表索引,大家都知道嗎
    2015-09-09
  • SQL Server中自動(dòng)抓取阻塞的詳細(xì)流程

    SQL Server中自動(dòng)抓取阻塞的詳細(xì)流程

    當(dāng)來自應(yīng)用程序的第一個(gè)連接控制鎖而第二個(gè)連接需要相沖突的鎖類型時(shí),將發(fā)生阻塞,其結(jié)果是強(qiáng)制第二個(gè)連接等待,而在第一個(gè)連接上阻塞,本文給大家詳細(xì)介紹了SQL Server中如何自動(dòng)抓取阻塞,通過圖文介紹的非常詳細(xì),需要的朋友可以參考下
    2024-08-08
  • T-SQL 查詢語句的執(zhí)行順序解析

    T-SQL 查詢語句的執(zhí)行順序解析

    查詢語句大家用的很多,但是知道語句執(zhí)行的順序和各各階段的作用的人卻很少。這里給大家簡(jiǎn)單介紹一下
    2011-10-10
  • sql 存儲(chǔ)過程分頁代碼 支持億萬龐大數(shù)據(jù)量

    sql 存儲(chǔ)過程分頁代碼 支持億萬龐大數(shù)據(jù)量

    sql 存儲(chǔ)過程分頁代碼 支持億萬龐大數(shù)據(jù)量,需要的朋友可以參考下。
    2011-09-09
  • SQL Server中數(shù)學(xué)函數(shù)的用法

    SQL Server中數(shù)學(xué)函數(shù)的用法

    這篇文章介紹了SQL Server中數(shù)學(xué)函數(shù)的用法,文中通過示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-05-05

最新評(píng)論