當前位置:首頁 » 編程語言 » 訂單sql面試題
擴展閱讀
webinf下怎麼引入js 2023-08-31 21:54:13
堡壘機怎麼打開web 2023-08-31 21:54:11

訂單sql面試題

發布時間: 2023-01-17 03:45:28

1. 求高手解答一道關於sqlService 的面試題

1
不能刪除
select * from 表2 where ProctId in (select ProctId from 表1 where ProctName='PName2')
因為上邊結果有記錄,所以外鍵在生效中,無法直接刪除,除非表1和表2有級聯刪除

2
第二個,是把銷售計劃表中m客戶的產品名為Pname2的銷售單價更改為200吧?,雖然里邊沒有對應的數據
update 銷售計劃表 set SalePrice=200 where Customer='m' and ProctId in (select ProctId from 表1 where ProctName='PName2')

3
第三個是這個意思嗎?沒太理解
select Customer,SalePrice from 銷售計劃表

4
select top 1 customer,sum(saleprice) from 銷售計劃表 group by customer order by sum(saleprice) desc

2. 軟體測試SQL面試題

資料庫,無外乎增刪改查:

增:

insert into A表 values (value1,value2,value3......)向A表中新增數據

刪:

delete from A表 ( where id=1) 刪除A表(刪除A表id=1的數據)如果刪除某個測試數據,記得加where條件,否則整張表的數據都被刪除,防止誤操作!不過,數據可以回滾找回。

truncate A表:清除表數據,數據無法回滾。

drop A表:整表結構刪除,即,這張表不存在了。

改:

update A表 set name='test' where id=1 修改id為1的name值為test

查:

1:左關聯和右關聯的區別?

答:左關聯( left join )左表為主,左表數據全部顯示,右表顯示關聯數據,無關聯顯示null,右關聯( right join )相反。

2:模糊查詢?

select * from A表 where name like ' %a% ' (name包含a字母)

查詢結果: a , a bc,b a c,bc a

select * from A表 where name like ' a% ' (name值以a字母開頭)

查詢結果: a , a bc

select * from A表 where name like ' %a ' (name值以a字母結尾)

查詢結果: a ,bc a

3:統計:count和sum

count統計表的 記錄數 ,sum統計某列數值 總和 。

select count(*) from A表

select count(1) from A表

select count(列名) from A表

區別:

count( * ): 所有記錄,包括null值

count( 1 ):所有記錄,包括null值

count( 列名 ):列名有值得記錄, 不包括null值

執行效率:

以前是count(1)比count(*)快,但現在count(*)底層演算法優化,查詢更快,所以推薦count(*)

統計有效數據的記錄,count(列名)

select sum(列名) from A表 計算列名數值總和。

舉例:

查詢A表中,姓王的用戶量

select count(*) from A where name like '王%'

Plus版

1:去重distinct,查詢不重復記錄的數據

必須放開頭

select distinct 列名 from 表名(查詢所有列名數據,去掉重復數據)

舉例:

表A,查詢考核等級grade,有哪些值

select distinct grade from A

2:分組group by,根據某個欄位分組

select 列名 from 表名 group by 列名,一般會配合聚合函數一起使用

舉例:

表A中,查詢考核等級grade欄位,不同值各多少人

select grade,count(*) from A group by grade

3:limit,查詢結果返回的數量,多用於分頁查詢

select * from 表名 limit i,n i代表查詢結果的索引值,默認從0開始,n返回查詢的結果數。

舉例:

訂單表A,查詢第21條到30條數據

select * from A limit 20,10

可能會問為什麼不能直接用id查詢?因為id不準確,可能存在id不連續的情況。如果某條數據被物理刪除了呢?

何為物理刪除和邏輯刪除?

物理 刪除 ,直接將某條數據,從表中刪除。

邏輯 刪除,僅通過某個欄位標記刪除,實際表中還存在。(比如:is_delete=1代表已刪除,is_delete=0未刪除)

4:排序order by 列名 asc(列名值升序排列)和order by 列名 desc(列名值降序排列)

舉例:

用戶表A,按照用戶id升序(select查詢默認根據主鍵升序,所以升序,不加order by也可以)

select * from A order by id asc同select *from A

用戶表A,按照新建時間倒序

select * from A order by create_time desc

5:in和between查詢某個范圍的數值

舉例:

in:查詢指定數值的數據

between:查詢某個范圍內的數據

舉例:

查詢表A中,id=1和id=10的數據

select * from A where id in(1,10)

查詢表A中,1月份新增的數據

select * from A where create_time between '2022-01-01' and '2022-01-31 23:59:59'

已知有如下4張表:

學生表:student(學號,學生姓名,出生年月,性別)

成績表:score(學號,課程號,成績)

課程表:course(課程號,課程名稱,教師號)

教師表:teacher(教師號,教師姓名)

准備練習數據

1)創建學生表(student)

2)創建成績表(score)

3)創建課程表(course)

4)教師表(teacher)

1)學生表添加數據

2)成績表添加數據

3)課程表添加數據

4)教師表添加數據

簡單查詢

查詢姓「猴」的學生名單

查詢姓名中最後一個字是「猴」字的學生名單

查詢姓名中帶「猴」字的學生名單

查詢姓「孟」老師的個數

匯總分析

1.匯總分析

查詢課程編號為「0002」的總成績

查詢選了課程的學生人數

2.分組

查詢各科成績的最高分和最低分, 以如下的形式顯示:課程號,最高分,最低分

查詢每門課程選修的學生數

3.分組結果的條件

查詢至少選修兩門課程的學生學號

查詢同名同姓學生名單並統計同名人數

分析:條件:怎麼算姓名相同?按姓名分組後人數大於等於2,因為同名的人數大於等於2,分析出這一點很重要

查詢不及格的課程並按課程號從大到小排列

查詢每門課程的平均成績,結果按平均成績升序排序,平均成績相同時,按課程號降序排列

檢索課程編號為「0004」且分數小於60的學生學號,結果按按分數降序排列

統計每門課程的學生選修人數(超過2人的課程才統計),要求輸出課程號和選修人數,查詢結果按人數降序排序,若人數相同,按課程號升序排序

查詢兩門以上不及格課程的同學的學號及其平均成績

第2步:再加上限制條件:

1)不及格課程

2)兩門以上[不及格課程]

4.查詢結構排序,分組的指定條件

查詢學生的總成績並進行排名

查詢平均成績大於60分的學生的學號和平均成績

復雜查詢

查詢課程成績小於60分學生的學號、姓名

【知識點】子查詢

1.翻譯成大白話

1)查詢結果:學生學號,姓名

2)查詢條件:所有課程成績 < 60 的學生,需要從成績表裡查找,用到子查詢

第1步,寫子查詢(所有課程成績 < 60 的學生)

第2步,查詢結果:學生學號,姓名,條件是前面1步查到的學號

查詢沒有學全所有課的學生的學號、姓名

查詢出只選修了兩門課程的全部學生的學號和姓名

查找1990年出生的學生名單

查詢本月過生日的學生

工作中會經常遇到這樣的業務問題:

如何找到每個類別下用戶最喜歡的產品是哪個?

如果找到每個類別下用戶點擊最多的5個商品是什麼?

這類問題其實就是常見的:分組取每組最大值、最小值,每組最大的N條(top N)記錄。

分組取每組最大值,按課程號分組取成績最大值所在行的數據

分組取每組最小值,按課程號分組取成績最小值所在行的數據

每組最大的N條記錄,查詢各科成績前兩名的記錄

第1步,查出有哪些組

我們可以按課程號分組,查詢出有哪些組,對應這個問題里就是有哪些課程號

第2步:先使用order by子句按成績降序排序(desc),然後使用limt子句返回topN(對應這個問題返回的成績前兩名)

第3步,使用union all 將每組選出的數據合並到一起

多表查詢

查詢所有學生的學號、姓名、選課數、總成績

查詢平均成績大於85的所有學生的學號、姓名和平均成績

查詢學生的選課情況:學號,姓名,課程號,課程名稱

3. sql面試題 不會做 都進來看看吧

才兩張表,隨便寫寫就出來了 你是沒見過該死的bom 那才傷腦筋

--先建立測試用例:
create table users(Id Int,Name varchar(20),regDate date);
alter table users add constraint users_pk primary key(Id);
create table UploadInfo(Id Int,UserId Int,FileName varchar(20),foreign key(UserId) references users(Id));
insert into users values(1,'A',sysdate-1);
insert into users values(2,'B',sysdate-2);
insert into users values(3,'C',sysdate-3);
insert into users values(4,'D',sysdate-4);
insert into users values(5,'E',sysdate-5);
select*from users;

--隨機插入上傳數據的存儲過程
create or replace procere InsertUploadInfoData is
i int:=0;
begin
for i in 1..100 loop
insert into UploadInfo values(i,trunc(DBMS_RANDOM.value(1,5)),'FileName '||trunc(DBMS_RANDOM.value(1,1000)));
end loop;
commit;
end ;

begin
InsertUploadInfoData;
end;

select*from UploadInfo;

--開始了

--第一題
select UserUploadRecord.Id,UserUploadRecord.UploadCount
from
(
select users.Id,count(UploadInfo.Id) as UploadCount from users
inner join UploadInfo on users.Id=UploadInfo.UserId --內聯結
where users.regDate>=sysdate-3 and users.regDate<=sysdate --三天內
group by users.Id
order by UploadCount desc
) UserUploadRecord
where rownum=1 --取第一條記錄
;

--創建用戶名重復的測試用例
insert into users values(6,'A',sysdate-4);

--由於有外鍵約束,所以需先刪除子表記錄
delete from UploadInfo where UploadInfo.Userid
in
(
select users.id from users where (users.name,users.regdate) in
(
select users.name,max(users.regdate) from users group by users.name having count(users.id)>1 --取重復用戶名的最大注冊時間
)
)

--再刪除父表,做法差不多
delete from users where (users.name,users.regdate) in
(
select users.name,max(users.regdate) from users group by users.name having count(users.id)>1
)

————————————————————
建表語法 測試用例都寫給你了 還說運行不了?直接復制進去就行了

4. sql面試題,牛人幫做下謝謝

(1) F_OrderID 欄位後面的PK是代表什麼?
Varchar(50)與Char(50)、Nvarchar(50)有什麼區別?

PK 意思是 主鍵. 也就是 一個 主鍵,在這個表裡面, 最多隻能找到 一行數據.
Varchar(50) 可變長字元串, 長度為 50位元組。
Char(50) 固定長度字元串, 長度為 50位元組。 假如內容不足50,會自動補空格
Nvarchar(50) 可變長字元串, 長度為 50字 == 100位元組。

(2)請編寫一條Sql語句,列出所有F_OrderName以abc開頭的並且F_CategoryName以xyz結尾的所有訂單,並以F_CategoryName升序F_OrderName降序排列。
在這兩個欄位上建立索引是不是會加快查詢速度?
SELECT
*
FROM
tblOrder
WHERE
F_OrderName LIKE 'abc%'
AND F_CategoryName LIKE '%xyz'
ORDER BY
F_CategoryName ASC,
F_OrderName DESC
對於 普通的索引,在 F_OrderName 上面建索引,可加快。
在 F_CategoryName 上面建, 無效果。 (Oracle 的一種特殊的反向索引,可以加快)

(3) 請編寫一條Sql語句,列出tblOrder表第31到第40條記錄,F_OrderID為主鍵,註:F_OrderID可能是不連續的。寫出兩種以上你認為性能最好的sql語句。

SELECT TOP 10
*
FROM
(
SELECT TOP 40 * FROM tblOrder ORDER BY F_OrderID
) subQuery
ORDER BY
F_OrderID DESC

SELECT
*
FROM
(
SELECT TOP 40 * ,
ROW_NUMBER() OVER(ORDER BY F_OrderID ) AS no
) FROM tblOrder ORDER BY F_OrderID
) subQuery
WHERE
no between 31 and 40

(4) sql語句里inner join,left join,right join的區別?
以 A JOIN B 為例子

A inner join B 意思是, A 與 B 表, 大家都有的數據, 才檢索出來。
A left join B 意思是, A 與 B 表, 大家都有的數據, 以及 A 有 B沒有的, 都檢索出來。
A right join B 意思是, A 與 B 表, 大家都有的數據, 以及 A沒有 B有的, 都檢索出來。

A full join B 意思是, A 與 B 表, 大家都有的數據, 以及 A 有 B沒有的,A沒有 B有的, 都檢索出來。

5. SQL資料庫面試題 急急急

a)select pname as '商品名',avg(qty) as 平均銷售量 from s,p,m where m.city='上海' and s.mno=m.mno and p.pno=s.pno,select p.Pno,p.pname,sum(s.qty)
from s left join p on s.pno=p.pno left join m on p.Mno=m.Mno
where m.city='上海市'
group by p.Pno,p.pname,p.city,p.color
b)、先刪除Sale表的外鍵PNO,再刪除gds表。

c)聯系:視圖(view)是在基本表之上建立的表,它的結構(即所定義的列)和內容(即所有數據行)都來自基本表,它依據基本表存在而存在。一個視圖可以對應一個基本表,也可以對應多個基本表。視圖是基本表的抽象和在邏輯意義上建立的新關系
區別:1、視圖是已經編譯好的sql語句。而表不是
2、視圖沒有實際的物理記錄。而表有。
3、表是內容,視圖是窗口
4、表只用物理空間而視圖不佔用物理空間,視圖只是邏輯概念的存在,表可以及時四對它進行修改,但視圖只能有創建的語句來修改
5、表是內模式,視圖是外模式
6、視圖是查看數據表的一種方法,可以查詢數據表中某些欄位構成的數據,只是一些SQL語句的集合。從安全的角度說,視圖可以不給用戶接觸數據表,從而不知道表結構。
7、表屬於全局模式中的表,是實表;視圖屬於局部模式的表,是虛表。
8、視圖的建立和刪除隻影響視圖本身,不影響對應的基本表。

6. 一道很有技術含量的SQL面試題,多方法全方位完美解答

1. 審題(需要用到的SQL語句)

「衣服、褲子、帽子、鞋子這些類別」:進行分組    group by 

「點擊量最高」:復合函數  Max()

「降序排列」:排序關鍵字 order by       降序  desc

需要顯示出來的欄位:proctID,proctName,最高 clickNum

2.  SQL語句分解

方法1:

首先,�查詢出點擊量最高的parentID,並將查詢結果取別名為b表

select parentid, max(clicknum) clicknum   FROM proctinfo GROUP BY parentid 

查詢結果如圖:b 表

查詢出表中的proctid, proctname, clicknum相關數據,取別名為a表:

ELECT proctid, proctname, clicknum FROM proctinfo as  a ;

從a、b表中查找parentid & clicknum 都相等的數據:

SELECT a.proctid, a.proctname, a.clicknum FROM proctinfo a, b WHERE a.parentid = b.parentid AND a.clicknum = b.clicknum;

具體SQL圖& SQL語句如下:

方法1 SQL如下

方法2 SQL如下:

新建表a1:   select  *  from proctinfo  a1

找出proctinfo表中 parentid與a表中相等,clicknum比a表中大的數據:

select 1 from proctinfo where a1.parentid = parentid and a1.clicknum < clicknum  查找出來的結果相當於又新建了一張表,即下面的 c 表。

為方便理解,將兩表放一起(數據都是一樣的):

得到的結果如下,相當於又一個新表,為方便理解起名為 c 表:

從proctinfo表中找c表中沒有的數據:

select  *  from proctinfo  a where not exists  c

方法3 SQL如下:

當新增一條特殊記錄

insert into proctInfo (proctID, proctName, parentID, clickNum) values (10,'女士鞋子1',10,30);

再次查詢

select * from proctinfo where clicknum in (select max(clickNum) from proctinfo group by parentid) order by clicknum desc;

結果

使用in貪婪匹配,再次查詢

這樣就去除了 parentID的 Max clickNum與另一種parentID 非 Max clickNum相同的特殊情況

7. sql面試題1

【1】騰訊面試題

table_A ( 用戶userid和登錄時間time)求連續登錄3天的用戶數

https://www.cnblogs.com/ikww/p/12012831.html

【SQL】查詢連續登陸7天以上的用戶

查詢7天連續登陸用戶這個問題很經典,解決方法也有很多,這里我講一下筆者的方法,希望對大家有幫助。

具體思路:

1、因為每天用戶登錄次數可能不止一次,所以需要先將用戶每天的登錄日期去重。

2、再用row_number() over(partition by _ order by _)函數將用戶id分組,按照登陸時間進行排序。

3、計算登錄日期減去第二步驟得到的結果值,用戶連續登陸情況下,每次相減的結果都相同。

4、按照id和日期分組並求和,篩選大於等於7的即為連續7天登陸的用戶。

表信息如下圖

第一步:用戶登錄日期去重

1select DISTINCT date(date) as 日期,id from orde;

結果為:

第二步:用row_number() over()函數計數

1select *,row_number() over(PARTITION by id order by 日期) as cum from (select DISTINCT date(date) as 日期,id from orde)a;

結果為:

第三步:日期減去計數值得到結果

1select *,date(日期)-cum as 結果 from (select *,row_number() over(PARTITION by id order by 日期) as cum from (select DISTINCT date(date) as 日期,id from orde)a)b;

結果:

第四步:根據id和結果分組並計算總和,大於等於7的即為連續登陸7天的用戶

1select id,count(*) from (select *,date(日期)-cum as 結果 from (select *,row_number() over(PARTITION by id order by 日期) as cum from (select DISTINCT date(date) as 日期,id from orde)a)b)c GROUP BY id,結果 having count(*)>=7;

結果為:

用了多次嵌套查詢,最終得到我們需要的結果。

01

01.還原題目場景 - 建表

select*fromtmp.tmp_last_3_day;

02

02.解決問題關鍵 - 分析

03

03.見證奇跡的時刻 - 實現

  連續3天登錄的用戶id ­­ sql如下:

我們再來看下結果:

04

04.面試反思總結 - 升華

現在看來,其實也不難嘛!思路很重要,有了思路,問題自然迎刃而解(此處有掌聲)。。ps:六師妹說今晚的加雞腿~哈哈

05

05.條條大路通羅馬

其實,方法有很多,上面只是選了一種技巧性比較強的一種。下面也是一種不錯的方法,大佬們肯定還有其他實現方式,歡迎小夥伴們右下角點[在看]評論留言,一起討論,一起進步 ~ go go go ...

【2】滴滴面試題

學生表:tb_student(name:學生姓名,id:學號,class:班級,in_time:入學時間,age:年齡,sex:性別,major:專業)

學生成績表:tb_score(id:學號,course:課程,score:分數)

(1)篩選出2017年入學的「計算機」專業年齡最小的10位同學名單(姓名、學號、班級、年齡)

(2)統計每個班同學各科成績平均分大於80分的人數和人數佔比

select a.class,

count(case when a.avg_score>80 then 1 else null end) as '人數'

count(case when a.avg_score>80 then 1 else null end)/count(a.id) as '人數佔比'

from

(select st.class,sc.id,avg(sc.score) as avg_score

from tb_student st

inner join tb_score sc

on st.id=sc.id

group by 1)a

(1)select st.name,st.id,st.class,st.age

from tb_student st

inner join tb_score sc

on st.id=sc.id

where year(st.in_time)='2017'

and major='計算機'

order by age asc

limit 0,9

(2)

鏈接:https://zhuanlan.hu.com/p/110924684

(1)

selectname,id,class,agefromtb_studentwhereyear(in_time)=2017andmajor='計算機'ORDERBYageASClimit10;

(2)

SELECTa.class,sum(casewhenaaa.x>80then1else0end)asnum_80,(sum(casewhenaaa.x>80then1else0end)/count(*))asproportionfromtb_studentaINNERJOIN(SELECTid,avg(score)asxfromtb_scoreGROUPBYid)asaaaona.id=aaa.idGROUPBYclass;

解析:寫一個子查詢,從score表中得到以學號分組的學生各科平均分。命名為aaa,將其與學生表內聯結。再以class分組,得到以class分組的各班學生的平均分,最後通過case語句,sum聚合函數得到平均分>80分的計數,和所佔各班總人數比例。

case語句也可以用if語句來代替

寫法2:

SELECTa.class,count(if(aaa.avg>80,true,null))asnumover80,count(if(aaa.avg>80,true,null))/count(a.id)astotalfromtb_studentaINNERJOIN(SELECTid,avg(score)asxfromtb_scoreGROUPBYid)asaaaona.id=aaa.idGROUPBYclass;

8. sql面試題

1.
select
s.title,
count(p.id)
from
書表
s
left
join
評論
p
on
s.id=p.書表中的id
group
by
s.title
(注意:左外連接的作用是將評價數為0的書顯示出來.count(p.id)和count(*)的區別是count(p.id)不計入p.id為null的行)
2.
select
top
1
s.title,
count(p.id)
from
書表
s
left
join
評論
p
on
s.id=p.書表中的id
group
by
s.title
order
by
2
desc
(以第2列倒序排序,取第1行)

9. SQL查詢面試題與答案

SQL查詢面試題與答案

SQL語言是一種資料庫查詢和程序設計語言,用於存取數據以及查詢、更新和管理關系資料庫系統;同時也是資料庫腳本文件的擴展名。下面是我搜集的SQL查詢面試題與答案,歡迎大家閱讀。

SQL查詢面試題與答案一

1.一道SQL語句面試題,關於group by表內容:

2005-05-09 勝

2005-05-09 勝

2005-05-09 負

2005-05-09 負

2005-05-10 勝

2005-05-10 負

2005-05-10 負

如果要生成下列結果, 該如何寫sql語句?

勝 負

2005-05-09 2 2

2005-05-10 1 2

------------------------------------------

create table #tmp(rq varchar(10),shengfu nchar(1))

insert into #tmp values('2005-05-09','勝')

insert into #tmp values('2005-05-09','勝')

insert into #tmp values('2005-05-09','負')

insert into #tmp values('2005-05-09','負')

insert into #tmp values('2005-05-10','勝')

insert into #tmp values('2005-05-10','負')

insert into #tmp values('2005-05-10','負')

1)select rq, sum(case when shengfu='勝' then 1 else 0 end)'勝',sum(case when shengfu='負' then 1 else 0 end)'負' from #tmp group by rq

2) select N.rq,N.勝,M.負 from (

select rq,勝=count(*) from #tmp where shengfu='勝'group by rq)N inner join

(select rq,負=count(*) from #tmp where shengfu='負'group by rq)M on N.rq=M.rq

3)select a.col001,a.a1 勝,b.b1 負 from

(select col001,count(col001) a1 from temp1 where col002='勝' group by col001) a,

(select col001,count(col001) b1 from temp1 where col002='負' group by col001) b

where a.col001=b.col001

2.請教一個面試中遇到的SQL語句的查詢問題

表中有A B C三列,用SQL語句實現:當A列大於B列時選擇A列否則選擇B列,當B列大於C列時選擇B列否則選擇C列。

------------------------------------------

select (case when a>b then a else b end ),

(case when b>c then b esle c end)

from table_name

3.面試題:一個日期判斷的sql語句?

請取出tb_send表中日期(SendTime欄位)為當天的所有記錄?(SendTime欄位為datetime型,包含日期與時間)

------------------------------------------

select * from tb where datediff(dd,SendTime,getdate())=0

4.有一張表,裡面有3個欄位:語文,數學,英語。其中有3條記錄分別表示語文70分,數學80分,英語58分,請用一條sql語句查詢出這三條記錄並按以下條件顯示出來(並寫出您的思路):

大於或等於80表示優秀,大於或等於60表示及格,小於60分表示不及格。

顯示格式:

語文 數學 英語

及格 優秀 不及格

------------------------------------------

select

(case when 語文>=80 then '優秀'

when 語文>=60 then '及格'

else '不及格') as 語文,

(case when 數學>=80 then '優秀'

when 數學>=60 then '及格'

else '不及格') as 數學,

(case when 英語>=80 then '優秀'

when 英語>=60 then '及格'

else '不及格') as 英語,

from table

5.在sqlserver2000中請用sql創建一張用戶臨時表和系統臨時表,裡麵包含兩個欄位ID和IDValues,類型都是int型,並解釋下兩者的區別?

------------------------------------------

用戶臨時表:create table #xx(ID int, IDValues int)

系統臨時表:create table ##xx(ID int, IDValues int)

區別:

用戶臨時表只對創建這個表的用戶的Session可見,對其他進程是不可見的.

當創建它的進程消失時這個臨時表就自動刪除.

全局臨時表對整個SQL Server實例都可見,但是所有訪問它的Session都消失的時候,它也自動刪除.

6.sqlserver2000是一種大型資料庫,他的`存儲容量只受存儲介質的限制,請問它是通過什麼方式實現這種無限容量機制的。

------------------------------------------

它的所有數據都存儲在數據文件中(*.dbf),所以只要文件夠大,SQL Server的存儲容量是可以擴大的.

SQL Server 2000 資料庫有三種類型的文件:

主要數據文件

主要數據文件是資料庫的起點,指向資料庫中文件的其它部分。每個資料庫都有一個主要數據文件。主要數據文件的推薦文件擴展名是 .mdf。

次要數據文件

次要數據文件包含除主要數據文件外的所有數據文件。有些資料庫可能沒有次要數據文件,而有些資料庫則有多個次要數據文件。次要數據文件的推薦文件擴展名是 .ndf。

日誌文件

日誌文件包含恢復資料庫所需的所有日誌信息。每個資料庫必須至少有一個日誌文件,但可以不止一個。日誌文件的推薦文件擴展名是 .ldf。

7.請用一個sql語句得出結果

從table1,table2中取出如table3所列格式數據,注意提供的數據及結果不準確,只是作為一個格式向大家請教。

如使用存儲過程也可以。

table1

月份mon 部門dep 業績yj

-------------------------------

一月份 01 10

一月份 02 10

一月份 03 5

二月份 02 8

二月份 04 9

三月份 03 8

table2

部門dep 部門名稱dname

--------------------------------

01 國內業務一部

02 國內業務二部

03 國內業務三部

04 國際業務部

table3 (result)

部門dep 一月份 二月份 三月份

--------------------------------------

01 10 null null

02 10 8 null

03 null 5 8

04 null null 9

------------------------------------------

1)

select a.部門名稱dname,b.業績yj as '一月份',c.業績yj as '二月份',d.業績yj as '三月份'

from table1 a,table2 b,table2 c,table2 d

where a.部門dep = b.部門dep and b.月份mon = '一月份' and

a.部門dep = c.部門dep and c.月份mon = '二月份' and

a.部門dep = d.部門dep and d.月份mon = '三月份' and

2)

select a.dep,

sum(case when b.mon=1 then b.yj else 0 end) as '一月份',

sum(case when b.mon=2 then b.yj else 0 end) as '二月份',

sum(case when b.mon=3 then b.yj else 0 end) as '三月份',

sum(case when b.mon=4 then b.yj else 0 end) as '四月份',

sum(case when b.mon=5 then b.yj else 0 end) as '五月份',

sum(case when b.mon=6 then b.yj else 0 end) as '六月份',

sum(case when b.mon=7 then b.yj else 0 end) as '七月份',

sum(case when b.mon=8 then b.yj else 0 end) as '八月份',

sum(case when b.mon=9 then b.yj else 0 end) as '九月份',

sum(case when b.mon=10 then b.yj else 0 end) as '十月份',

sum(case when b.mon=11 then b.yj else 0 end) as '十一月份',

sum(case when b.mon=12 then b.yj else 0 end) as '十二月份',

from table2 a left join table1 b on a.dep=b.dep

8.華為一道面試題

一個表中的Id有多個記錄,把所有這個id的記錄查出來,並顯示共有多少條記錄數。

------------------------------------------

select id, Count(*) from tb group by id having count(*)>1

select * from(select count(ID) as count from table group by ID)T where T.count>1

SQL查詢面試題與答案二

1、查詢不同老師所教不同課程平均分從高到低顯示

SELECT max(Z.T#) AS 教師ID,MAX(Z.Tname) AS 教師姓名,C.C# AS 課程ID,MAX(C.Cname) AS 課程名稱,AVG(Score) AS 平均成績

FROM SC AS T,Course AS C ,Teacher AS Z

where T.C#=C.C# and C.T#=Z.T#

GROUP BY C.C#

ORDER BY AVG(Score) DESC

2、查詢如下課程成績第 3 名到第 6 名的學生成績單:企業管理(001),馬克思(002),UML (003),資料庫(004)

[學生ID],[學生姓名],企業管理,馬克思,UML,資料庫,平均成績

SELECT DISTINCT top 3

SC.S# As 學生學號,

Student.Sname AS 學生姓名 ,

T1.score AS 企業管理,

T2.score AS 馬克思,

T3.score AS UML,

T4.score AS 資料庫,

ISNULL(T1.score,0) + ISNULL(T2.score,0) + ISNULL(T3.score,0) + ISNULL(T4.score,0) as 總分

FROM Student,SC LEFT JOIN SC AS T1

ON SC.S# = T1.S# AND T1.C# = '001'

LEFT JOIN SC AS T2

ON SC.S# = T2.S# AND T2.C# = '002'

LEFT JOIN SC AS T3

ON SC.S# = T3.S# AND T3.C# = '003'

LEFT JOIN SC AS T4

ON SC.S# = T4.S# AND T4.C# = '004'

WHERE student.S#=SC.S# and

ISNULL(T1.score,0) + ISNULL(T2.score,0) + ISNULL(T3.score,0) + ISNULL(T4.score,0)

NOT IN

(SELECT

DISTINCT

TOP 15 WITH TIES

ISNULL(T1.score,0) + ISNULL(T2.score,0) + ISNULL(T3.score,0) + ISNULL(T4.score,0)

FROM sc

LEFT JOIN sc AS T1

ON sc.S# = T1.S# AND T1.C# = 'k1'

LEFT JOIN sc AS T2

ON sc.S# = T2.S# AND T2.C# = 'k2'

LEFT JOIN sc AS T3

ON sc.S# = T3.S# AND T3.C# = 'k3'

LEFT JOIN sc AS T4

ON sc.S# = T4.S# AND T4.C# = 'k4'

ORDER BY ISNULL(T1.score,0) + ISNULL(T2.score,0) + ISNULL(T3.score,0) + ISNULL(T4.score,0) DESC);

3、統計列印各科成績,各分數段人數:課程ID,課程名稱,[100-85],[85-70],[70-60],[ <60]

SELECT SC.C# as 課程ID, Cname as 課程名稱

,SUM(CASE WHEN score BETWEEN 85 AND 100 THEN 1 ELSE 0 END) AS [100 - 85]

,SUM(CASE WHEN score BETWEEN 70 AND 85 THEN 1 ELSE 0 END) AS [85 - 70]

,SUM(CASE WHEN score BETWEEN 60 AND 70 THEN 1 ELSE 0 END) AS [70 - 60]

,SUM(CASE WHEN score < 60 THEN 1 ELSE 0 END) AS [60 -]

FROM SC,Course

where SC.C#=Course.C#

GROUP BY SC.C#,Cname;

4、查詢學生平均成績及其名次

SELECT 1+(SELECT COUNT( distinct 平均成績)

FROM (SELECT S#,AVG(score) AS 平均成績

FROM SC

GROUP BY S#

) AS T1

WHERE 平均成績 > T2.平均成績) as 名次,

S# as 學生學號,平均成績

FROM (SELECT S#,AVG(score) 平均成績

FROM SC

GROUP BY S#

) AS T2

ORDER BY 平均成績 desc;

5、查詢各科成績前三名的記錄:(不考慮成績並列情況)

SELECT t1.S# as 學生ID,t1.C# as 課程ID,Score as 分數

FROM SC t1

WHERE score IN (SELECT TOP 3 score

FROM SC

WHERE t1.C#= C#

ORDER BY score DESC

)

ORDER BY t1.C#;

6、查詢每門課程被選修的學生數

select c#,count(S#) from sc group by C#;

7、查詢出只選修了一門課程的全部學生的學號和姓名

select SC.S#,Student.Sname,count(C#) AS 選課數

from SC ,Student

where SC.S#=Student.S# group by SC.S# ,Student.Sname having count(C#)=1;

8、查詢課程編號“002”的成績比課程編號“001”課程低的所有同學的學號、姓名;

Select S#,Sname from (select Student.S#,Student.Sname,score ,(select score from SC SC_2 where SC_2.S#=Student.S# and SC_2.C#='002') score2

from Student,SC where Student.S#=SC.S# and C#='001') S_2 where score2

9、查詢所有課程成績小於60分的同學的學號、姓名;

select S#,Sname

from Student

where S# not in (select Student.S# from Student,SC where S.S#=SC.S# and score>60);

10、查詢沒有學全所有課的同學的學號、姓名;

select Student.S#,Student.Sname

from Student,SC

where Student.S#=SC.S# group by Student.S#,Student.Sname having count(C#) <(select count(C#) from Course);

11、查詢至少有一門課與學號為“1001”的同學所學相同的同學的學號和姓名;

select S#,Sname from Student,SC where Student.S#=SC.S# and C# in select C# from SC where S#='1001';

12、查詢至少學過學號為“001”同學所有一門課的其他同學學號和姓名;

select distinct SC.S#,Sname

from Student,SC

where Student.S#=SC.S# and C# in (select C# from SC where S#='001');

13、把“SC”表中“葉平”老師教的課的成績都更改為此課程的平均成績;

update SC set score=(select avg(SC_2.score)

from SC SC_2

where SC_2.C#=SC.C# ) from Course,Teacher where Course.C#=SC.C# and Course.T#=Teacher.T# and Teacher.Tname='葉平');

14、查詢和“1002”號的同學學習的課程完全相同的其他同學學號和姓名;

select S# from SC where C# in (select C# from SC where S#='1002')

group by S# having count(*)=(select count(*) from SC where S#='1002');

15、刪除學習“葉平”老師課的SC表記錄;

Delect SC

from course ,Teacher

where Course.C#=SC.C# and Course.T#= Teacher.T# and Tname='葉平';

16、向SC表中插入一些記錄,這些記錄要求符合以下條件:沒有上過編號“003”課程的同學學號、2、

號課的平均成績;

Insert SC select S#,'002',(Select avg(score)

from SC where C#='002') from Student where S# not in (Select S# from SC where C#='002');

17、按平均成績從高到低顯示所有學生的“資料庫”、“企業管理”、“英語”三門的課程成績,按如下形式顯示: 學生ID,,資料庫,企業管理,英語,有效課程數,有效平均分

SELECT S# as 學生ID

,(SELECT score FROM SC WHERE SC.S#=t.S# AND C#='004') AS 資料庫

,(SELECT score FROM SC WHERE SC.S#=t.S# AND C#='001') AS 企業管理

,(SELECT score FROM SC WHERE SC.S#=t.S# AND C#='006') AS 英語

,COUNT(*) AS 有效課程數, AVG(t.score) AS 平均成績

FROM SC AS t

GROUP BY S#

ORDER BY avg(t.score)

18、查詢各科成績最高和最低的分:以如下形式顯示:課程ID,最高分,最低分

SELECT L.C# As 課程ID,L.score AS 最高分,R.score AS 最低分

FROM SC L ,SC AS R

WHERE L.C# = R.C# and

L.score = (SELECT MAX(IL.score)

FROM SC AS IL,Student AS IM

WHERE L.C# = IL.C# and IM.S#=IL.S#

GROUP BY IL.C#)

AND

R.Score = (SELECT MIN(IR.score)

FROM SC AS IR

WHERE R.C# = IR.C#

GROUP BY IR.C#

);

19、按各科平均成績從低到高和及格率的百分數從高到低順序

SELECT t.C# AS 課程號,max(course.Cname)AS 課程名,isnull(AVG(score),0) AS 平均成績

,100 * SUM(CASE WHEN isnull(score,0)>=60 THEN 1 ELSE 0 END)/COUNT(*) AS 及格百分數

FROM SC T,Course

where t.C#=course.C#

GROUP BY t.C#

ORDER BY 100 * SUM(CASE WHEN isnull(score,0)>=60 THEN 1 ELSE 0 END)/COUNT(*) DESC

20、查詢如下課程平均成績和及格率的百分數(用"1行"顯示): 企業管理(001),馬克思(002),OO&UML (003),資料庫(004)

SELECT SUM(CASE WHEN C# ='001' THEN score ELSE 0 END)/SUM(CASE C# WHEN '001' THEN 1 ELSE 0 END) AS 企業管理平均分

,100 * SUM(CASE WHEN C# = '001' AND score >= 60 THEN 1 ELSE 0 END)/SUM(CASE WHEN C# = '001' THEN 1 ELSE 0 END) AS 企業管理及格百分數

,SUM(CASE WHEN C# = '002' THEN score ELSE 0 END)/SUM(CASE C# WHEN '002' THEN 1 ELSE 0 END) AS 馬克思平均分

,100 * SUM(CASE WHEN C# = '002' AND score >= 60 THEN 1 ELSE 0 END)/SUM(CASE WHEN C# = '002' THEN 1 ELSE 0 END) AS 馬克思及格百分數

,SUM(CASE WHEN C# = '003' THEN score ELSE 0 END)/SUM(CASE C# WHEN '003' THEN 1 ELSE 0 END) AS UML平均分

,100 * SUM(CASE WHEN C# = '003' AND score >= 60 THEN 1 ELSE 0 END)/SUM(CASE WHEN C# = '003' THEN 1 ELSE 0 END) AS UML及格百分數

,SUM(CASE WHEN C# = '004' THEN score ELSE 0 END)/SUM(CASE C# WHEN '004' THEN 1 ELSE 0 END) AS 資料庫平均分

,100 * SUM(CASE WHEN C# = '004' AND score >= 60 THEN 1 ELSE 0 END)/SUM(CASE WHEN C# = '004' THEN 1 ELSE 0 END) AS 資料庫及格百分數

FROM SC

;

10. 這幾個SQL語句面試題該怎麼寫

第一題:

selecta.name
fromemployeealeftjoin
(selectt.dptid,avg(t.salary)avgsal
fromemployeet
groupbyt.dptid)bona.dptid=b.dptid
wherea.salary>b.avgsal

第二題

selectcount(a.name),a.dptid
fromemployeealeftjoin
(selectt.dptid,avg(t.salary)avgsal
fromemployeet
groupbyt.dptid)bona.dptid=b.dptid
wherea.salary>b.avgsal
groupbya.dptid

第三題:

selectavg(t.salary)
fromemployeet
wheret.salary>6000