日韩无码专区无码一级三级片|91人人爱网站中日韩无码电影|厨房大战丰满熟妇|AV高清无码在线免费观看|另类AV日韩少妇熟女|中文日本大黄一级黄色片|色情在线视频免费|亚洲成人特黄a片|黄片wwwav色图欧美|欧亚乱色一区二区三区

RELATEED CONSULTING
相關咨詢
選擇下列產品馬上在線溝通
服務時間:8:30-17:00
你可能遇到了下面的問題
關閉右側工具欄

新聞中心

這里有您想知道的互聯(lián)網營銷解決方案
如何巧妙利用SQLServer的EXISTS結構

EXISTS結構

EXISTS結構是一個TSQL函數(shù),這個函數(shù)會就圓括號中的子查詢返回一個布爾變量。如果子查詢返回了任意行的話,這個結構就返回真;否則,它就返回假。這個結構特別適用于查詢表中是否存在某些記錄。它也非常適合來決定是否在表中運行更新或者插入語句(在這篇文章中,隨后我將向大家介紹)。

Listing A中創(chuàng)建了一個表并插入了一些數(shù)據,這樣你就可以利用這張表來看看EXISTS結構是如何工作的了。Listing B中的腳本使用EXISTS結構在SalesHistory表中檢查每一行,并根據已存在的行得到一個變量。這個腳本將返回1(真),這意味著SalesHistory表包含你所要查詢的行。

在這種情況下,一旦在SalesHistory表中找到了一條記錄,EXISTS結構就不會繼續(xù)查找,并馬上返回1。使用EXISTS結構額外的好處就是,一旦它找到滿足條件的記錄,就會立即返回。

Listing C與上面的腳本類似,但是它的返回值是0,因為在這個條件下,EXISTS條件不滿足。

由于EXISTS結構的工作原理,所以下面的語句所實現(xiàn)的功能是一樣的。

SELECT * FROM SalesHistory

WHERE EXISTS(SELECT NULL)

SELECT * FROM SalesHistory

WHERE 1 = 1

SELECT * FROM SalesHistory

WHERE EXISTS(SELECT 1)

在剛才的腳本中,你可能會對下面的語句感到迷惑:

SELECT * FROM SalesHistory

WHERE EXISTS(SELECT NULL)
 

因為NULL在數(shù)據庫中是一個值(它是一個未知的值),在出現(xiàn)NULL值的地方EXISTS結構都將返回真。

開發(fā)者很少使用EXISTS對子查詢進行操作。下面的查詢將返回同樣的結果集,雖然它們的結構不同。第一個查詢使用了EXISTS的相關子查詢,第二查詢在SalesHistory表中,將SalePrice字段與該字段的總平均值進行比較。

SELECT * FROM SalesHistory sh

WHERE EXISTS

(
SELECT AVG(SalePrice)

FROM SalesHistory shi

HAVING AVG(SalePrice) > sh.SalePrice
)
SELECT * FROM SalesHistory sh

WHERE SalePrice <

(
SELECT AVG(SalePrice)

FROM SalesHistory shi
)

你可以使用EXISTS操作來決定,是否對某一個單獨的記錄使用UPDATE或者INSERT語句,就像下面的例子一樣:

IF EXISTS

(

SELECT * FROM SalesHistory

WHERE SaleDate = '1/1/2001' AND

Product = 'Computer' AND

SalePrice = 1000

)

UPDATE TOP(1) SalesHistory

SET SalePrice = 1100

WHERE SaleDate = '1/1/2001' AND

Product = 'Computer' AND

SalePrice = 1000
ELSE
INSERT INTO SalesHistory

(Product, SaleDate, SalePrice)

VALUES

('Computer', '1/1/2001', 1100)
 

雖然在實際的環(huán)境中,你可能不會用到這里所介紹的例子,但是它們給你演示了如何利用EXISTS結構來決定使用哪種DML類型。

相信通過上文的學習,現(xiàn)在大家對EXISTS結構也已經有了大體的了解,EXISTS結構的很多好處大家也是都能夠看的見的,下次,當你寫查詢語句的時候,請記住要使用EXISTS結構。它很容易掌握,使用也很方便,并且能在程序中給你提供很多便利。

【編輯推薦】

  1. SQL Server數(shù)據庫服務器高性能設置
  2. 測試SQL Server業(yè)務規(guī)則鏈接方法
  3. 對SQL Server聚集索引的指示綜合描述

 


當前標題:如何巧妙利用SQLServer的EXISTS結構
標題路徑:http://www.5511xx.com/article/cochsij.html