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