Ⅰ sql 中 exists 是怎麼回事啊 怎麼用啊 老師沒講懂 呵呵 高手都來幫忙啊
exists 是指:是否存在 的意思
例如你要新建一個新的資料庫 但是不知道以前SQLSERVER里是否已經存在該資料庫了 則可以使用如下語句
IF EXISTS (SELECT * FROM SYSDATABASES WHERE NAME = 'TEST')
DROP DATABASE 'TEST'
該句意思為:在資料庫總記錄中查找是否已存在名為『TEST』的資料庫,
如果存在(IF EXISTS) 則執行DROP操作,呵呵 能理解了吧
按照LZ發的題目來解答的話WHERE NOT EXISTS的意思就是為,「不存在於」子查詢返回的記錄中
Ⅱ 資料庫問題exists 和not exists如何使用
exists和not exists我認為最大的特點就是可以使sql語句變得簡單,一句話完成很復雜的操作,因為它本身具有循環的特點。
比如(b2是兩個表的主鍵):
update tab1 as a set a.a1=b.a1 where exit(select b.a1 from tab2 as b where b.b2=a.b2);
上面的語句實現的功能是,根據b.b2=a.b2條件循環檢索tab2表當檢索出一個b.a1的值時,根據a.b2這個主鍵更新tab1表中相應的記錄,當循環到exit後面沒有結果產生時sql結束。
not exists 和exists 恰好相反。
※一定記住他和in、not in 是不一樣的,他們是資料庫內置的循環檢索。
我知道的就這些希望對你有幫助。
Ⅲ sql中exists是什麼意思,怎麼講解
SQL EXISTS:
EXISTS 運算符用於判斷查詢子句是否有記錄,如果有一條或多條記錄存在返回 True,否則返回 False。
具體語法參考:
-from shulanxt
回答不易,望樓主採納哦~
Ⅳ 資料庫sql語句中為什麼exists關鍵字 要比 in 關鍵字執行效率高
exists是根據子查詢有無記錄返回確定條件是否成立,如果有記錄返回,條件成立,如果子查詢未返回記錄,條件不成立,不對子查詢結果進行匹配,所以速度較快;in要對子查詢返回的結果用in關鍵字前面的值逐個進行匹配,如果匹配成功條件成立,匹配不成功條件不成立,所以速度較慢。
Ⅳ 資料庫的exists用法啊,我真的難以拐過彎來啊,怎麼理解比如下面的例子:
exists語法可以這樣理解,執行查詢areas表,並且逐條調用exists語句去匹配,如果在deals表中有匹配項則返回1(true),沒有匹配項則返回0(false),返回1的話就顯示記錄,返回0的話不顯示該行記錄(這里顯示的是areas表的記錄,要理解,你現在只是查詢areas表,deals表只是拿過來用一下而已),然後進行下一條記錄的匹配。
關鍵是你要想像成他是一條一條記錄去匹配的,也就是說areas表中每一行記錄都會在deals全表中搜索匹配項,只要存在匹配(可以是一對一也可以是一對多匹配)立即返回1;如果搜索到deals表尾依然沒有匹配項,這時候才返回0。
如果懂了請採納,不懂的話繼續追問。
Ⅵ 資料庫sql的exists
這么記,兩個not exists就是 兩個exists
你這句話意思就是從student中拿出一個記錄(假設a)再從course拿出一個(假設b),然後和sc表比較,如果a的學號與表sc中某一記錄(這個記錄假設為c)相等且同時b的課程號與該記錄(c)中的學號相等的話,則該記錄(a)就是一個結果記錄,然後再與sc其他記錄比較,知道sc記錄掃描完,之後從course中再拿一條記錄(假設為d),此時就是記錄a和d和sc中每條記錄比較,滿足條件的就輸出,等course記錄掃描完畢後從最外層表student拿出一條然後在從頭掃描course表盒sc表。以此類推。這個是順序由外到內再到外的。
Ⅶ 資料庫中select語句的存在量詞exists怎麼使用
select*fromstudentawhereexists(select1fromstudentbwhereb.name='張三'andb.college=a.college)
Ⅷ 資料庫中IN 和EXISTS有什麼區別
沒有什麼區別,兩者都是包含的意思,但是esists的效率比in要高。建議別用in,影響效率 ,如果只有兩三個條件,就用or代替 ,如果值 比較多,就用exists.例如 select * from table where ( name = '1' or name ='2') 別寫成name in ('1','2')如果數據量比較大select * from table where name exists (select name from table2);
Ⅸ sql中in和exist語句的區別
兩者都能實現表功能查詢,主要區別如下:
1、適用表的類型不同。
in是子查詢為驅動表,外面的表為被驅動表,故適用於子查詢結果集小而外面的表結果集大的情況。
exists是外面的表位驅動表,子查詢裡面的表為被驅動表,故適用於外面的表結果集小而子查詢結果集大的情況。
2、子查詢關聯不同。
exists一般都是關聯子查詢。對於關聯子查詢,必須先執行外層查詢,接著對所有通過過濾條件的記錄,執行內層查詢。外層查詢和內層查詢相互依賴,因為外層查詢會把數據傳遞給內層查詢。
in則一般都是非關聯子查詢,非關聯子查詢則必須先完成內層查詢之後,外層查詢才能介入。
3、執行次數不同。
IN 語句:只執行一次,確定給定的值是否與子查詢或列表中的值相匹配。in在查詢的時候,首先查詢子查詢的表,然後將內表和外表做一個笛卡爾積,然後按照條件進行篩選。所以相對內表比較小的時候,in的速度較快。
EXISTS語句:執行次數根據表的長度而定。指定一個子查詢,檢測行的存在。遍歷循環外表,然後看外表中的記錄有沒有和內表的數據一樣的。匹配上就將結果放入結果集中。
Ⅹ SQL中EXISTS怎麼用
EXISTS在SQL中的作用是:檢驗查詢是否返回數據。
select a.* from tb a where exists(select 1 from tb where name =a.name)返回真假,當 where 後面的條件成立,則列出數據,否則為空。
exists強調的是是否返回結果集,不要求知道返回什麼。比如:select name from student where sex = 'm' and mark exists(select 1 from grade where ...)
只要exists引導的子句有結果集返回,那麼exists這個條件就算成立了,大家注意返回的欄位始終為1
如果改成「select 2 from grade where ...」,那麼返回的欄位就是2,這個數字沒有意義。所以exists子句不在乎返回什麼,而是在乎是不是有結果集返回。
(10)資料庫esists擴展閱讀:
Exists 方法描述如果在 Dictionary對象中指定的關鍵字存在,返回True,若不存在,返回False。
語法object.Exists(key)Exists 方法語法有如下幾部分:部分描述Object必需的。始終是一個 Dictionary對象的名字。Key必需的,在 Dictionary對象中搜索的Key值。
exist相當於存在量詞:表示集合存在,也就是集合不為空只作用一個集合.
例如 exist P表示P不空時為真; not exist P表示p為空時為真in表示一個標量和一元關系的關系。
例如:s in P表示當s與P中的某個值相等時為真; s not in P 表示s與P中的每一個值都不相等時為真。
exits與not exits
exists(sql 返回結果集為真)
not exists(sql 不返回結果集為真)
如果not exists子查詢只有自己本身的查詢條件,這樣只要子查詢中有數據返回,就證明是false,結果在整體執行就無返回值;一旦跟外面的查詢關聯上,就能准確查出數據。