欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

詳解SQL Server數(shù)據(jù)庫鏈接查詢的方式

 更新時間:2015年08月14日 14:17:31   投稿:lijiao  
本文我們主要介紹了SQL Server數(shù)據(jù)庫鏈接查詢的方式,包括內(nèi)連接、外連接和交叉連接等的內(nèi)容,需要的朋友可以參考下

SQL Server數(shù)據(jù)庫鏈接查詢的方式的相關知識是本文我們主要要介紹的內(nèi)容,我們知道,通過連接運算符可以實現(xiàn)多個表查詢。連接是關系數(shù)據(jù)庫模型的主要特點,也是它區(qū)別于其它類型數(shù)據(jù)庫管理系統(tǒng)的一個標志。多表連接查詢是使用Sql的基本操作,但連接的方式卻有多種,熟練使用這些連接方式能夠簡化Sql語句,提高數(shù)據(jù)庫運行效率。

在關系數(shù)據(jù)庫管理系統(tǒng)中,表建立時各數(shù)據(jù)之間的關系不必確定,常把一個實體的所有信息存放在一個表中。當檢索數(shù)據(jù)時,通過連接操作查詢出存放在多個表中的不同實體的信息。連接操作給用戶帶來很大的靈活性,他們可以在任何時候增加新的數(shù)據(jù)類型。為不同實體創(chuàng)建新的表,然后通過連接進行查詢。

連接可以在SELECT 語句的FROM子句或WHERE子句中建立,似是而非在FROM子句中指出連接時有助于將連接操作與WHERE子句中的搜索條件區(qū)分開來。所以,在Transact-SQL中推薦使用這種方法。

基本語法與方法

SQL-92標準所定義的FROM子句的連接語法格式為:

FROM join_table join_type join_table  
[ON (join_condition)] 

其中join_table指出參與連接操作的表名,連接可以對同一個表操作,也可以對多表操作,對同一個表操作的連接又稱做自連接。

join_type 指出連接類型,可分為三種:內(nèi)連接、外連接和交叉連接。內(nèi)連接(INNER JOIN)使用比較運算符進行表間某(些)列數(shù)據(jù)的比較操作,并列出這些表中與連接條件相匹配的數(shù)據(jù)行。根據(jù)所使用的比較方式不同。

1、內(nèi)連接又分為等值連接、自然連接和不等連接三種.

2、外連接分為左外連接(LEFT OUTER JOIN或LEFT JOIN)、右外連接(RIGHT OUTER JOIN或RIGHT JOIN)和全外連接(FULL OUTER JOIN或FULL JOIN)三種。與內(nèi)連接不同的是,外連接不只列出與連接條件相匹配的行,而是列出左表(左外連接時)、右表(右外連接時)或兩個表(全外連接時)中所有符合搜索條件的數(shù)據(jù)行。

3、交叉連接(CROSS JOIN)沒有WHERE 子句,它返回連接表中所有數(shù)據(jù)行的笛卡爾積,其結果集合中的數(shù)據(jù)行數(shù)等于第一個表中符合查詢條件的數(shù)據(jù)行數(shù)乘以第二個表中符合查詢條件的數(shù)據(jù)行數(shù)。

連接操作中的ON (join_condition) 子句指出連接條件,它由被連接表中的列和比較運算符、邏輯運算符等構成.

無論哪種連接都不能對text、ntext和image數(shù)據(jù)類型列進行直接連接,但可以對這三種列進行間接連接。例如:

SELECT p1.pub_id,p2.pub_id,p1.pr_info  
 
FROM pub_info AS p1 INNER JOIN pub_info AS p2  
 
ON DATALENGTH(p1.pr_info)=DATALENGTH(p2.pr_info) 

(一)內(nèi)連接

內(nèi)連接查詢操作列出與連接條件匹配的數(shù)據(jù)行,它使用比較運算符比較被連接列的列值。內(nèi)連接分三種:

1、等值連接:在連接條件中使用等于號(=)運算符比較被連接列的列值,其查詢結果中列出被連接表中的所有列,包括其中的重復列.

2、不等連接: 在連接條件使用除等于運算符以外的其它比較運算符比較被連接的列的列值。這些運算符包括>、>=、<=、<、!>、!<和<>。

3、自然連接:在連接條件中使用等于(=)運算符比較被連接列的列值,但它使用選擇列表指出查詢結果集合中所包括的列,并刪除連接表中的重復列.

例,下面使用等值連接列出authors和publishers表中位于同一城市的作者和出版社:

SELECT *  
FROM authors AS a INNER JOIN publishers AS p  
ON a.city=p.city  
SELECT a.*,p.pub_id,p.pub_name,p.country  
FROM authors AS a INNER JOIN publishers AS p  
ON a.city=p.city 

又如使用自然連接,在選擇列表中刪除authors 和publishers 表中重復列(city和state):

(二)外連接

內(nèi)連接時,返回查詢結果集合中的僅是符合查詢條件( WHERE 搜索條件或 HAVING 條件)和連接條件的行。而采用外連接時,它返回到查詢結果集合中的不僅包含符合連接條件的行,而且還包括左表(左外連接時)、右表(右外連接時)或兩個邊接表(全外連接)中的所有數(shù)據(jù)行。

1、left join或left outer join(左外連接)

左外連接:(也叫左外連接,給出兩個表的配匹行,并且以左邊的表為準,如果左邊表有而右邊表沒有的行,則在右邊表的相應行選擇的列顯示為NULL,允許左邊的基準表對應右邊表多條滿足條件的記錄)左連接就是返回左邊的匹配行,不考慮右邊的表是否有相應的行

select field1,field2 from table1 left join table2 
on field1=field2(基準字段,可以多個) 
where table1.field3=table2.field3 

2、right join或right outer join(右外連接)

右連接:(也叫右外連接,給出兩個表的配匹行,并且以右邊的表為準,如果右邊表有而左邊表沒有的行,則在右邊表的相應行選擇的列顯示為NULL,允許右邊的基準表對應左邊表多條滿足條件的記錄)

語法與做鏈接差不多!

(三)交叉連接

交叉連接不帶WHERE 子句,它返回被連接的兩個表所有數(shù)據(jù)行的笛卡爾積,返回到結果集合中的數(shù)據(jù)行數(shù)等于第一個表中符合查詢條件的數(shù)據(jù)行數(shù)乘以第二個表中符合查詢條件的數(shù)據(jù)行數(shù)。

例,titles表中有6類圖書,而publishers表中有8家出版社,則下列交叉連接檢索到的記錄數(shù)將等于6*8=48行。

SELECT type,pub_name  
FROM titles CROSS JOIN publishers  
ORDER BY type 

關于SQL Server數(shù)據(jù)庫鏈接查詢的方式的相關知識就介紹到這里了,希望本次的介紹能夠對您有所收獲!

相關文章

  • 獲取SQL Server2014的安裝時間

    獲取SQL Server2014的安裝時間

    最近安裝SQL Server 2014時,還沒有正式的License,只能試用3個月。想知道什么時候到期,就要知道SQL Server 2014是什么時候安裝的。
    2014-07-07
  • SqlServer查詢和Kill進程死鎖的語句

    SqlServer查詢和Kill進程死鎖的語句

    這篇文章主要介紹了SqlServer查詢和Kill進程死鎖的語句,非常不錯,具有參考借鑒價值,需要的朋友可以參考下
    2016-08-08
  • MySql刪除和更新操作對性能有影響嗎

    MySql刪除和更新操作對性能有影響嗎

    做編程的同胞都知道,所有的項目都是離不開數(shù)據(jù)庫,數(shù)據(jù)庫離不開增刪改查操作,那么刪除和更新操作對性能有影響嗎?下面小編給大家詳細介紹MySql刪除和更新對性能的影響,需要的朋友可以參考下
    2015-08-08
  • Spark SQL 2.4.8 操作 Dataframe的兩種方式

    Spark SQL 2.4.8 操作 Dataframe的兩種方式

    這篇文章主要介紹了Spark SQL 2.4.8 操作 Dataframe的兩種方式,方式一是通過dsl操作,方式二是利用sql方式操作,每種方式通過實例代碼給大家介紹的非常詳細,需要的朋友可以參考下
    2021-10-10
  • .net+mssql制作抽獎程序思路及源碼

    .net+mssql制作抽獎程序思路及源碼

    近期一直在研究數(shù)據(jù)庫,剛好有個項目要做抽獎程序,恩,拿來練練手吧。
    2014-06-06
  • sql編程工具Sql Prompt下載及安裝破解圖文教程

    sql編程工具Sql Prompt下載及安裝破解圖文教程

    SQL Prompt是一款擁有SQL智能提示功能的SQL Server和VS插件。SQL Prompt能根據(jù)數(shù)據(jù)庫的對象名稱,語法和用戶編寫的代碼片段自動進行檢索,智能的為用戶提供唯一合適的代碼選擇。自動腳本設置為用戶提供了簡單的代碼易讀性--這在開發(fā)者使用的是不大熟悉的腳本時尤其有用
    2014-08-08
  • SQL 查詢和刪除重復字段數(shù)據(jù)的方法

    SQL 查詢和刪除重復字段數(shù)據(jù)的方法

    這篇文章介紹了SQL 查詢和刪除重復字段數(shù)據(jù)的方法,有需要的朋友可以參考一下
    2013-08-08
  • T-SQL篇如何防止SQL注入的解決方法

    T-SQL篇如何防止SQL注入的解決方法

    所謂SQL注入式攻擊,就是攻擊者把SQL命令插入到Web表單的輸入域或頁面請求的查詢字符串,欺騙服務器執(zhí)行惡意的SQL命令,對于這種行為,我們應該如何制止呢?本文將介紹一種方法,希望可以幫助有需要的朋友
    2012-11-11
  • 常用SQL語句查詢分享

    常用SQL語句查詢分享

    本文通過幾個小例子,給大家分享一下常用SQL常用的語句,非常的簡單實用,有需要的小伙伴可以參考下。
    2016-01-01
  • 自動化收集SQLSERVER診斷信息的工具選擇及使用介紹

    自動化收集SQLSERVER診斷信息的工具選擇及使用介紹

    相信很多人都遇到過當SQLSERVER出現(xiàn)問題的時候,如果想解決的話一般需要你收集一些系統(tǒng)信息和SQLSERVER診斷信息;接下來將介紹下工具的選擇及使用,感興趣的你可不要錯過了哈,或許本文的知識點可以幫助到你
    2013-02-02

最新評論