SQL?Server數(shù)據(jù)庫(kù)入門教程之多表查詢
SQL_Server的前情介紹
??大家好呀,今天是我第三次寫sql_server,也是最近才學(xué)習(xí)sql_server,也想著記錄一下自己的學(xué)習(xí)過(guò)程,并且分享給大家尼!
一、sql_server技術(shù)介紹
SQL Server 是由微軟公司(Microsoft)開發(fā)的關(guān)系型數(shù)(RDBMS)。RDBMS 是 SQL 以及所有現(xiàn)代數(shù)據(jù)庫(kù)系統(tǒng)的基礎(chǔ),比如 MS SQL Server,IBM DB2,Oracle,MySQL 以及微軟的 Microsoft Access。
二、學(xué)習(xí)前的準(zhǔn)備工作
編程軟件:SQL Server Management Studio 2012
帶好你的小板凳,我們一起揚(yáng)帆起航!

SQL_Server之多表查詢
笛卡爾乘積的講解
在數(shù)據(jù)庫(kù)中有一種叫笛卡爾乘積其語(yǔ)法如下:
select * from People,Department
此查詢結(jié)果會(huì)將People表的所有數(shù)據(jù)和Department表的所有數(shù)據(jù)進(jìn)行依次排列組合形成新的記錄。例如People表有10條記錄,Department表有3條記錄,則排列組合之后查詢結(jié)果會(huì)有10*3=30條記錄.
多表查詢
接下來(lái)我們來(lái)看幾個(gè)例子吧!
1.查詢員工信息,顯示部門信息
select * from People,department where People.DepartmentId = department.DepartmentId

2.查詢員工信息,顯示職級(jí)名稱
select * from People,s_rank where People.RankId = s_rank.RankId

3.查詢員工信息,顯示部門名稱,顯示職級(jí)名稱
select * from People,department,s_rank where People.departmentId = department.DepartmentId and People.RankId = s_rank.RankId

內(nèi)連接查詢
在數(shù)據(jù)庫(kù)的查詢過(guò)程中,存在有內(nèi)連接查詢,這個(gè)時(shí)候,我們就需要用到inner這個(gè)關(guān)鍵字,下面我們來(lái)看幾個(gè)例子吧!
1.查詢員工信息,顯示部門信息
select * from People inner join department on People.departmentId = department.DepartmentId

2.查詢員工信息,顯示職級(jí)名稱
select * from People inner join s_rank on People.RankId = s_rank.RankId

3.查詢員工信息,顯示部門名稱,顯示職級(jí)名稱
select * from People inner join department on People.departmentId = department.DepartmentId inner join s_rank on People.RankId = s_rank.RankId

外連接查詢(左外連,右外連,全外連)
1.查詢員工信息,顯示部門信息(左外連)
select * from People left join department on People.departmentId = department.DepartmentId

2.查詢員工信息,顯示職級(jí)名稱(左外接)
select * from People left join s_rank on People.RankId = s_rank.RankId

3.查詢員工信息,顯示部門名稱,顯示職級(jí)名稱(左外連)
select * from People left join department on People.departmentId = department.DepartmentId inner join s_rank on People.RankId = s_rank.RankId

4.右外連
A left join B = B right join A
select * from People right join department on People.departmentId = department.DepartmentId

全外連查詢(無(wú)論是否符合關(guān)系,都要顯示數(shù)據(jù))
1.select * from People full join department on People.departmentId = department.DepartmentId

多表查詢的主要例子
1.查詢出武漢地區(qū)所有的員工信息,要求顯示部門名稱,以及員工的詳細(xì)資料(顯示中文別名)
select PeopleId 員工編號(hào),DepartmentName 部門名稱,PeopleName 員工姓名,PeopleSex 員工性別, PeopleBirth 員工生日,PeoPleSalary 月薪,PeoplePhone 電話,PeopleAddress 地址 from People,department where People.departmentId = department.DepartmentId

2.查詢出武漢地區(qū)所有員工的信息,要求顯示部門名稱,職級(jí)名稱以及員工的詳細(xì)資料
select PeopleId 員工編號(hào),DepartmentName 部門名稱,RankName 職級(jí)名稱, PeopleName 員工姓名,PeopleSex 員工性別, PeopleBirth 員工生日,PeoPleSalary 月薪,PeoplePhone 電話,PeopleAddress 地址 from People,department,s_rank where People.departmentId = department.DepartmentId and People.RankId = s_rank.RankId and PeopleAddress = '武漢'

3.根據(jù)部門分組統(tǒng)計(jì)員工人數(shù),員工工資總和,平均工資,最高工資和最低工資
select DepartmentName 部門名稱, count(*) 員工人數(shù),sum(PeopleSalary) 工資總和,avg(PeopleSalary) 平均工資,max(PeopleSalary) 最高工資,min(PeopleSalary) 最低工資 from People,department where People.departmentId = department.DepartmentId group by department.DepartmentId,DepartmentName

4.根據(jù)部門分組統(tǒng)計(jì)員工人數(shù),員工工資總和,平均工資,最高工資和最低工資平均工資在10000元以下的不參與排序。根據(jù)平均工資降序排序
select DepartmentName 部門名稱, count(*) 員工人數(shù),sum(PeopleSalary) 工資總和,avg(PeopleSalary) 平均工資,max(PeopleSalary) 最高工資,min(PeopleSalary) 最低工資 from People,department where People.departmentId = department.DepartmentId group by department.DepartmentId,DepartmentName having avg(PeopleSalary) >= 15000 order by avg(PeopleSalary) desc

5.根據(jù)部門名稱,然后根據(jù)職位名稱分組,統(tǒng)計(jì)員工人數(shù),員工工資總和
平均工資,最高工資,和最低工資
select DepartmentName 部門名稱,RankName 職級(jí)名稱, count(*) 員工人數(shù),sum(PeopleSalary) 工資總和,avg(PeopleSalary) 平均工資,max(PeopleSalary) 最高工資,min(PeopleSalary) 最低工資 from People,department,s_rank where People.departmentId = department.DepartmentId and People.RankId = s_rank.RankId group by department.DepartmentId,DepartmentName,s_rank.RankId,s_rank.RankName

如何鞏固學(xué)習(xí)
提示:在學(xué)習(xí)的過(guò)程中,我們需要先自行進(jìn)行思考,而不是一遇到不會(huì)的就放棄思考直接看答案,如果最后遇到真的不會(huì)的題目,我們可以適當(dāng)?shù)倪M(jìn)行觀看答案,看自己的思路是否正確,在作出正確的判斷
總結(jié)
到此這篇關(guān)于SQL Server數(shù)據(jù)庫(kù)入門教程之多表查詢的文章就介紹到這了,更多相關(guān)SQLServer多表查詢內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- MySQL數(shù)據(jù)庫(kù)查詢之多表查詢總結(jié)
- MySQL數(shù)據(jù)庫(kù)設(shè)計(jì)概念及多表查詢和事物操作
- MySQL數(shù)據(jù)庫(kù)查詢進(jìn)階之多表查詢?cè)斀?/a>
- MySQL數(shù)據(jù)庫(kù)高級(jí)查詢和多表查詢
- 詳解MySQL數(shù)據(jù)庫(kù)--多表查詢--內(nèi)連接,外連接,子查詢,相關(guān)子查詢
- Android Room數(shù)據(jù)庫(kù)多表查詢的使用實(shí)例
- sqlserver 多表查詢不同數(shù)據(jù)庫(kù)服務(wù)器上的表
- 數(shù)據(jù)庫(kù)librarydb多表查詢的操作方法
相關(guān)文章
sqlserver 中ntext字段的批量替換(updatetext的用法)
在Sql Server 中,ntext/text/image 字段不允許應(yīng)用replace函數(shù)替換內(nèi)容2009-09-09
SQL Server數(shù)據(jù)庫(kù)刪除數(shù)據(jù)集中重復(fù)數(shù)據(jù)實(shí)例講解
本文通過(guò)一個(gè)例子介紹了SQL Server數(shù)據(jù)庫(kù)中刪除數(shù)據(jù)集中的重復(fù)數(shù)據(jù)的操作過(guò)程,需要的朋友可以參考下2015-08-08
sqlserver下將數(shù)據(jù)庫(kù)記錄的列記錄轉(zhuǎn)換成行記錄的方法
sqlserver下將數(shù)據(jù)庫(kù)記錄的列記錄轉(zhuǎn)換成行記錄的方法分享,需要的朋友可以參考下。2011-07-07
圖書管理系統(tǒng)的sqlserver數(shù)據(jù)庫(kù)設(shè)計(jì)示例
這篇文章主要介紹了圖書管理系統(tǒng)的sqlserver數(shù)據(jù)庫(kù)設(shè)計(jì)示例,文中通過(guò)E_R圖、數(shù)據(jù)字典、數(shù)據(jù)庫(kù)腳本代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-08-08
SQLServer中master數(shù)據(jù)庫(kù)分析
sql下master數(shù)據(jù)庫(kù)分析,了解下master數(shù)據(jù)庫(kù)主要是做什么用的2008-04-04
SQLSERVER的排序問(wèn)題結(jié)果不是想要的
同一個(gè)查詢的結(jié)果集為什麼有時(shí)候是按他想要的順序排列,有時(shí)候又不是,接下來(lái)將為你詳細(xì)解答,感興趣的你可以參考下哈,希望對(duì)你有所幫助2013-03-03
sql server動(dòng)態(tài)存儲(chǔ)過(guò)程按日期保存數(shù)據(jù)示例
,在sql server存儲(chǔ)過(guò)程中進(jìn)行日期計(jì)算,按日期建表效率最高,下面就公司項(xiàng)目的部分動(dòng)態(tài)存儲(chǔ)過(guò)程粘貼出來(lái)2014-08-08

