Sql學(xué)習(xí)第一天——SQL 練習(xí)題(建表/sql語(yǔ)句)
題目:來(lái)自Madrid且訂單數(shù)少于3的消費(fèi)者
建表:
set nocount on --當(dāng) SET NOCOUNT 為 ON 時(shí),不返回計(jì)數(shù)(表示受 Transact-SQL 語(yǔ)句影響的行數(shù))。當(dāng) SET NOCOUNT 為 OFF 時(shí),返回計(jì)數(shù)
use SY
GO
if object_Id('dbo.Orders') is not null
drop table dbo.Orders
GO
if object_Id('dbo.Customers') is not null
drop table dbo.Customers
GO
create table dbo.Customers
(
customerid char(5) not null primary key ,
city varchar(10) not null
);
insert into dbo.Customers values('FISSA','Madrid');
insert into dbo.Customers values('FRNDO','Madrid');
insert into dbo.Customers values('KRLOS','Madrid');
insert into dbo.Customers values('MRPHS','Zion');
create table dbo.Orders
(
orderid int not null primary key ,
customerid char(5) null references customers(customerid)
)
insert into dbo.Orders values(1,'FRNDO');
insert into dbo.Orders values(2,'FRNDO');
insert into dbo.Orders values(3,'KRLOS');
insert into dbo.Orders values(4,'KRLOS');
insert into dbo.Orders values(5,'KRLOS');
insert into dbo.Orders values(6,'MRPHS');
insert into dbo.Orders values(7,null);
------------------------------------------------------------------------------------------------------------------------------
做題分析:
select customerid as 消費(fèi)者,count(customerid) as 訂單數(shù)
from dbo.Orders
where customerid in (
select customerid
from dbo.Customers
where city = 'Madrid')
group by customerid
having count(customerid) < 3
結(jié)果如圖所示:
--第一次想到的答案,突然發(fā)現(xiàn)少了一個(gè)來(lái)自Madrid的FISSA訂單,FISSA訂單數(shù)量為0,所以在Orders表中沒(méi)有出現(xiàn),所以上面的寫(xiě)法會(huì)少一個(gè).
--推翻了上面的答案,又想到了用表的連接,而用內(nèi)連接出現(xiàn)的情況會(huì)和上面的一樣,所以我選擇了左連接,如下:
select C.customerid as 消費(fèi)者,count(O.customerid) as 訂單數(shù)
from dbo.Customers as C left join dbo.Orders as O on C.customerid = O.customerid
where C.city= 'Madrid'
group by C.customerid
having count(C.customerid) < 3
結(jié)果如圖所示:
--查詢發(fā)現(xiàn)是正確的。
--分析查看不帶條件的左連接
select * from dbo.Customers as C left join dbo.Orders as O on C.customerid = O.customerid
select * from dbo.Customers as C left join dbo.Orders as O on C.customerid = O.customerid
結(jié)果如圖所示:
--書(shū)中給的標(biāo)準(zhǔn)答案是:
select C.customerid , count(O.orderid) as numorders
from dbo.Customers as C left join dbo.Orders as O on C.customerid = O.customerid
where C.city= 'Madrid'
group by C.customerid
having count(O.orderid) < 3
order by numorders
結(jié)果如圖所示:
--書(shū)中給的只是多了一個(gè)order by 進(jìn)行定義了排序方式(以numorders這一列的升序進(jìn)行排序)
相關(guān)文章
把excel表格里的數(shù)據(jù)導(dǎo)入sql數(shù)據(jù)庫(kù)的兩種方法
這篇文章介紹了把excel表格里的數(shù)據(jù)導(dǎo)入sql數(shù)據(jù)庫(kù)的兩種方法,有需要的朋友可以參考一下2013-09-09Sql Server2012 使用IP地址登錄服務(wù)器的配置圖文教程
最近在使用NFineBase框架+c#做一個(gè)系統(tǒng)的時(shí)候,在使用sql server 2012 連接數(shù)據(jù)庫(kù)的時(shí)候,在使用過(guò)程中遇到了幾個(gè)問(wèn)題,下面小編給大家分享Sql Server2012 使用IP地址登錄服務(wù)器的配置圖文教程,一起學(xué)習(xí)吧2017-07-07如何遠(yuǎn)程連接SQL Server數(shù)據(jù)庫(kù)的圖文教程
如何遠(yuǎn)程連接SQL Server數(shù)據(jù)庫(kù)的圖文教程...2007-03-03一列保存多個(gè)ID(將多個(gè)用逗號(hào)隔開(kāi)的ID轉(zhuǎn)換成用逗號(hào)隔開(kāi)的名稱)
在做項(xiàng)目時(shí),經(jīng)常會(huì)遇到這樣的表結(jié)構(gòu)在主表的中有一列保存的是用逗號(hào)隔開(kāi)ID2012-07-07SQL SERVER遷移之更換磁盤(pán)文件夾的完整步驟
這篇文章主要給大家介紹了關(guān)于SQL SERVER遷移之更換磁盤(pán)文件夾的完整步驟,文中通過(guò)圖文介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-10-10訪問(wèn)和更改關(guān)系數(shù)據(jù),使用MSSQL外聯(lián)接
訪問(wèn)和更改關(guān)系數(shù)據(jù),使用MSSQL外聯(lián)接...2007-02-02SQL設(shè)置SQL Server最大連接數(shù)及查詢語(yǔ)句
今天遇到了關(guān)于Sql Server最大連接數(shù)(Max Pool Size)的問(wèn)題,后來(lái)通過(guò)查找一些資料解決了,所以想著總結(jié)下關(guān)于SQL Server最大連接數(shù)的內(nèi)容,所以這篇文章主要介紹了SQL設(shè)置SQL Server最大連接數(shù)與查詢語(yǔ)句,有需要的朋友們可以參考借鑒。2016-12-12sqlserver存儲(chǔ)過(guò)程語(yǔ)法詳解
這篇文章主要介紹了sqlserver存儲(chǔ)過(guò)程語(yǔ)法示例,需要的朋友可以參考下2014-04-04比較詳細(xì)的完美解決安裝sql2000時(shí)出現(xiàn)以前的某個(gè)程序安裝已在安裝計(jì)算機(jī)上創(chuàng)建掛起的文件操作。
比較詳細(xì)的完美解決安裝sql2000時(shí)出現(xiàn)以前的某個(gè)程序安裝已在安裝計(jì)算機(jī)上創(chuàng)建掛起的文件操作。...2007-10-10