❶ 有關sql的面試題。。。
1:
〔車輛〕、〔站台〕、〔行車路線〕最少3個表
〔車輛〕表欄位〔ID〕,〔名稱〕
〔站台〕表欄位〔ID〕,〔名稱〕,〔描述〕
〔行車路線〕表欄位〔ID〕,〔車ID〕,〔站ID〕
查詢:
SELECT 〔車輛〕.〔名稱〕,〔站台〕.〔名稱〕
FROM 〔車輛〕 INNER JOIN 〔行車路線〕
ON 〔車輛〕.〔ID〕=〔行車路線〕.〔車ID〕
INNER JOIN 〔站台〕
ON 〔站台〕.〔ID〕=〔行車路線〕.〔站ID〕
WHERE 〔站台〕.〔名稱〕 = '車站1'
OR 〔站台〕.〔名稱〕 = '車站2'
2:資料庫設計
〔部門〕表:ID,父級ID,名稱
〔員工〕表:ID,父級ID,名稱,許可權
〔員工所屬部門〕表:ID,員工ID,部門ID
〔申請〕表:ID,內容,申請人ID,審核人ID,審核結果,備注
系統設計:
1 員工進入申請頁面時,根據〔員工〕的許可權來判斷是否能進入
2 員工查詢〔申請〕表,通過申請人ID過濾,只有申請許可權
3 經理查詢〔申請〕表,通過〔員工〕表查申請人的父級ID過濾,可以進行審批操作
❷ sql面試題,請大神解答,急!!!
第一題,最高的10-20。
1234select*from(selectcolD,colE,dense_rank()over(orderbycolGdesc)asrkfromtableb)whererkbetween10and20--當然面試的話這里可以註明dense_rank和rank區別等等。
第二題,2樓寫的就可以了
第三題,注意題目是人數之和
12345selectcount(*)ascntfromtableBwherecolAin(=傳入idconnectbypriorcolA=colB)
第四題
--測試數據
withtableAas(select1ascolA,0ascolB,'北京',0ascolB,'上海'fromal),tableBas(select1ascolD,'人員1'ascolE,1ascolA,2000ascolG,0ascolHfromalunionallselect2,'人員2',1,2000,0fromalunionallselect3,'人員3',1,2000,0fromalunionallselect4,'人員4',1,2000,0fromalunionallselect5,'人員5',1,2000,1fromalunionallselect6,'人員6',2,2000,1fromalunionallselect7,'人員7',1,2000,1fromal)--查詢sqlselectdecode(t.colH,0,'女','男')asgender,max(decode(t.colC,'北京',t.cnt,0))as北京,max(decode(t.colC,'上海',t.cnt,0))as上海from(selecta.colC,b.colH,count(*).colA=b.colAgroupbycolC,colH)tgroupbyt.colH
這里可以解釋下本sql的思路:--首先查出每個地區不同性別的人數,在行轉列(由於題目很明顯告訴你固定數據)
❸ 高頻sql面試問題
SQL(結構化查詢語言)是一種設計用於檢索和操作數據的資料庫。它是美國國家標准協會(ANSI)的標准。此語言用於執行選擇,更新,刪除和插入等數據任務。
表是在具有列和行的模型中設計的數據集合。在表中,指定了列數,稱為欄位,但未定義行數,稱為記錄。
DBMS是一個控制數據維護和使用的程序。它被認為是管理數據的文件管理器。有四種類型的DBMS:
最有用的DBMS是Relational DBMS。它為數據提供了一個關系運算符。
SQL命令分為以下類型:
它包含來自一個或多個表的行和列,可以定義為虛擬表。它消耗的內存較少。
句法:
Join用於從相關的行和列中檢索數據。它在兩個或多個表之間工作,並且它從兩個表返回至少一個匹配。
連接類型是:
資料庫查詢是資料庫表中的數據請求。查詢可以是選擇查詢或任何其他類型的查詢。
子查詢是查詢的一部分。外部查詢已知主查詢,內部查詢識別子查詢。始終首先執行子查詢,並將結果傳遞給主查詢。
Autoincrement是一個關鍵字,用於在表中插入新記錄時生成數字。
它可用於設置表中數據類型的限制。在創建或更新表語句時,可以使用約束。一些限制是:
SQL中有不同類型的鍵:
規范化是一種設計技術,它以減少數據依賴性的方式排列表。它將表分成小模塊並按關系鏈接。
非規范化是一種優化方法,我們將多餘的數據增加到表中,並在規范化後應用。
存儲過程是一組SQL語句,用作訪問資料庫的函數。為了減少網路流量並提高性能,我們使用存儲過程。
句法:
索引用於加速查詢的性能。它可以更快地從表中檢索數據。可以在一組列上創建索引。
聚簇索引 - 它有助於輕松檢索數據,並且只有一個聚簇索引與一個表一起分配。它會更改記錄在資料庫中的保存方式。
非聚集索引 - 與聚簇索引相比,非聚簇索引很慢。並且在非集群索引的情況下,該表可以具有多個索引。它為表創建一個對象,該表是搜索後指向表的一個點。
觸發器 被 用來執行對表中的特定動作,諸如插入,更新或刪除 。它是一種 存儲過程 。動作和事件是觸發器的主要組成部分。執行Action時,事件響應該操作而出現。
通常,這些屬性稱為ACID。它們有助於資料庫事務。
A tomicity -在一個事務中連接兩個或更多個單獨的數據塊,或者所有的塊都致力於,或者一個都不。
C onsistency - 事務或者生成新的有效數據狀態,或者如果發生任何失望,則在事務啟動之前將所有數據返回到其狀態。
I solation - 正在進行且尚未提交的事務必須繼續與任何其他操作隔離。
D urability -在此操作中,系統保存提交的數據,每當事件發生故障和系統啟動後,所有的數據是可用的正確的位置。
SQL語句分為幾類:
它被定義為通過為查詢提供條件來設置結果集的限制。他們從整個記錄中過濾掉一些行。
一些SQL CLAUSES是WHERE和HAVING。
它是一個返回單個值的數學函數。
SQL中的聚合函數是:
為了操作字元串,我們使用String Function。其中一些是:
排序規則 是一 組規則,用於確定數據如何通過比較進行排序 。例如使用一組規則存儲的字元數據,這些規則定義了正確字元的序列以及類型,重音和區分大小寫。
在系統內存中執行SQL語句時,會創建一個臨時工作區,稱為Cursor。在select語句中,游標存儲了信息。游標可以使用多行,但一次只能處理一行。這組行稱為活動集。
游標有兩種類型:
SQL伺服器是Microsoft關系資料庫管理系統(RDBMS)的一種類型或示例。它在IT氛圍中提供廣泛的事務處理和商業智能。
運算符是一個保留字,主要用於SQL語句的WHERE子句中以進行操作。
空值是沒有值的欄位。它與Zero不同。假設有一個表,並且在表中有一個欄位,可以在不添加值的情況下將記錄插入欄位,然後該欄位將以NULL值保存。
空白是我們提供的價值。
零隻是一個數字。
數據倉庫被稱為來自多個信息源的中央數據中心。這些數據可用於在線處理和挖掘。
在表中,應該只有一個PRIMARY KEY,但在另一種情況下,UNIQUE KEY可以是任意數量的。
PRIMARY KEYS不允許NULL值,但UNIQUE KEY允許NULL值。
❹ 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行)
❺ SQL語句面試題
SELECT*,
(SELECTCOUNT(*)FROM(SELECTCOUNT(*),b.sidFROMscbLEFTJOINcoursecONb.Cid=c.CidGROUPBYb.sid,c.tid)owWHEREow.sid=a.sid)as'
選課數量',
(SELECTsum(Score)FROMScdWHEREa.sid=d.sid)as'總成績'
FROMstudenta
;
SELECTd.sid,d.snamefromteachera
LEFTJOINcoursebona.tid=b.tid
LEFTJOINscconc.cid=b.cid
leftJOINstudentdONd.sid=c.sid
WHEREa.tname='葉萍';
SELECTsid,sname
FROMstudent
WHEREsidin(selecta.sid
FROMscAleftjoinscbona.sid=b.sid
WHEREa.cid=1andb.cid=2anda.score>b.score)
SELECTsc.Sid,sum(CASEWHENc.Cname='
數學'thensc.Scoreelse0end)數學,SUM(casewhenc.Cname='物理
'THENsc.ScoreELSE0END)物理,AVG(sc.Score)平均分
FROMsc
INNERJOINCourseconsc.Cid=c.Cid
WHEREc.Cnamein('數學','物理')
GROUPBYsc.Sid
ORDERBYAVG(sc.Score)DESC
insertintoSc(Sid,Cid,Score)values(003,3,85);
insertintoSc(Sid,Cid,Score)values(003,3,30);
首先這個不知道是你i寫錯了還是怎麼一個人化學成績有2個所以我在這里按照你這個上做的查詢所以有一個人是選了單個課程
❻ sql語句面試50題@20211219
Student(s_id,s_name,s_birth,s_sex) --學生編號,學生姓名, 出生年月,學生性別
–2.課程表
Course(c_id,c_name,t_id) – --課程編號, 課程名稱, 教師編號
–3.教師表
Teacher(t_id,t_name) --教師編號,教師姓名
–4.成績表
Score(s_id,c_id,s_score) --學生編號,課程編號,分數
1、查詢"01"課程比"02"課程成績高的學生的信息及課程分數
2、查詢"01"課程比"02"課程成績低的學生的信息及課程分數
3、查詢平均成績大於等於60分的同學的學生編號和學生姓名和平均成績
4、查詢平均成績小於60分的同學的學生編號和學生姓名和平均成績
5、查詢所有同學的學生編號、學生姓名、選課總數、所有課程的總成績
6、查詢"李"姓老師的數量
7、查詢學過"張三"老師授課的同學的信息
8、查詢沒學過"張三"老師授課的同學的信息
9、查詢學過編號為"01"並且也學過編號為"02"的課程的同學的信息
10、查詢學過編號為"01"但是沒有學過編號為"02"的課程的同學的信息
11、查詢沒有學全所有課程的同學的信息
*12、查詢至少有一門課與學號為"01"的同學所學相同的同學的信息 **
13、查詢和"01"號的同學學習的課程完全相同的其他同學的信息 (不會)
14、查詢沒學過"張三"老師講授的任一門課程的學生姓名
-- [分析] 方法一:瘋狂子查詢
方法二:子查詢+內聯結
15、查詢兩門及其以上不及格課程的同學的學號,姓名及其平均成績
16、檢索"01"課程分數小於60,按分數降序排列的學生信息
17、按平均成績從高到低顯示所有學生的所有課程的成績以及平均成績(重要!)
-- 18.查詢各科成績最高分、最低分和平均分:以如下形式顯示:課程ID,課程name,最高分,最低分,平均分,及格率,中等率,優良率,優秀率--及格為>=60,中等為:70-80,優良為:80-90,優秀為:>=90(重要!)
19、按各科成績進行排序,並顯示排名(涉及到TopN問題,重要!!!)
20、查詢學生的總成績並進行排名
21、查詢不同老師所教不同課程平均分從高到低顯示
22、查詢所有課程的成績第2名到第3名的學生信息及該課程成績
23、統計各科成績各分數段人數:課程編號,課程名稱,[100-85],[85-70],[70-60],[0-60]及所佔百分比
24、查詢學生平均成績及其名次
25、查詢各科成績前三名的記錄(重要!!!!!)
26、查詢每門課程被選修的學生數
27、查詢出只有兩門課程的全部學生的學號和姓名
28、查詢男生、女生人數
29、查詢名字中含有"風"字的學生信息
-- [分析] 考察字元串模糊查詢,之前我的sql學習筆記中有詳細記錄 https://zhuanlan.hu.com/p/128093194
30、查詢同名同性學生名單,並統計同名人數(重要!!!!!)
31、查詢1990年出生的學生名單
32、查詢每門課程的平均成績,結果按平均成績降序排列,平均成績相同時,按課程編號升序排列
33、查詢平均成績大於等於85的所有學生的學號、姓名和平均成績
34、查詢課程名稱為"數學",且分數低於60的學生姓名和分數
35、查詢所有學生的課程及分數情況;
36、查詢任何一門課程成績在70分以上的姓名、課程名稱和分數;
37、查詢不及格的課程
38、查詢課程編號為01且課程成績在80分以上的學生的學號和姓名;
39、求每門課程的學生人數
40、查詢選修"張三"老師所授課程的學生中,成績最高的學生信息及其成績
41、查詢不同課程成績相同的學生的學生編號、課程編號、學生成績 (重要!!!!)
42、查詢每門功成績最好的前兩名
43、統計每門課程的學生選修人數(超過5人的課程才統計)。要求輸出課程號和選修人數,查詢結果按人數降序排列,若人數相同,按課程號升序排列
44、檢索至少選修兩門課程的學生學號
45、查詢選修了全部課程的學生信息
46、查詢各學生的年齡 按照出生日期來算,當前月日 < 出生年月的月日則,年齡減一
47、查詢本周過生日的學生
48、查詢下周過生日的學生
49、查詢本月過生日的學生
50、查詢下月過生日的學生
❼ sql面試題
1,答
select * into B庫.table_b from A庫.table_a
2,答
select * into A庫.new_table from A庫.table_a left outer join B庫.table_b on A庫.table_a.name=B庫.table_b.name and A庫.table_a.Text=B庫.table_b.text
delete from A庫.table_a left outer join A庫.new_table on A庫.table_a.name=A庫.new_table.name and A庫.table_a.Text=A庫.new_table.text
delete from B庫.table_b left outer join A庫.new_table on b庫.table_b.name=A庫.new_table.name and b庫.table_b.Text=A庫.new_table.text
3 答
select * from (select top 10 * from (select top 100 * from 表 )as a) as b
4 答
select * into 表c from 表A
union all
select * into 表c from 表B
試試如果不對請指正。
❽ 面試常問的資料庫問題及答案
目前在職場中很難找到非常合格的資料庫開發人員。有人說:「SQL開發是一門語言,它很容易學,但是很難掌握。」
在面試應聘的SQL Server資料庫開發人員時,我運用了一套標準的基準技術問題。下面這些問題是我覺得能夠真正有助於淘汰不合格應聘者的問題。它們按照從易到難的順序排列。當你問到關於主鍵和外鍵的問題時,後面的問題都十分有難度,因為答案可能會更難解釋和說明,尤其是在面試的情形下。
你能向我簡要敘述一下SQL Server 2000中使用的一些資料庫對象嗎?
你希望聽到的答案包括這樣一些對象:表格、視圖、用戶定義的函數,以及存儲過程;如果他們還能夠提到像觸發器這樣的對象就更好了。如果應聘者不能回答這個基本的問題,那麼這不是一個好兆頭。
NULL是什麼意思?
NULL(空)這個值是資料庫世界裡一個非常難纏的東西,所以有不少應聘者會在這個問題上跌跟頭您也不要覺得意外。
NULL這個值表示UNKNOWN(未知):它不表示「」(空字元串)。假設您的SQL Server資料庫里有ANSI_NULLS,當然在默認情況下會有,對NULL這個值的任何比較都會生產一個NULL值。您不能把任何值與一個 UNKNOWN值進行比較,並在邏輯上希望獲得一個答案。您必須使用IS NULL操作符。
什麼是索引?SQL Server 2000里有什麼類型的索引?
任何有經驗的資料庫開發人員都應該能夠很輕易地回答這個問題。一些經驗不太多的開發人員能夠回答這個問題,但是有些地方會說不清楚。
簡單地說,索引是一個數據結構,用來快速訪問資料庫表格或者視圖里的數據。在SQL Server里,它們有兩種形式:聚集索引和非聚集索引。聚集索引在索引的葉級保存數據。這意味著不論聚集索引里有表格的哪個(或哪些)欄位,這些欄位都會按順序被保存在表格。由於存在這種排序,所以每個表格只會有一個聚集索引。非聚集索引在索引的葉級有一個行標識符。這個行標識符是一個指向磁碟上數據的指針。它允許每個表格有多個非聚集索引。
什麼是主鍵?什麼是外鍵?
主鍵是表格里的(一個或多個)欄位,只用來定義表格里的行;主鍵里的值總是唯一的。外鍵是一個用來建立兩個表格之間關系的約束。這種關系一般都涉及一個表格里的主鍵欄位與另外一個表格(盡管可能是同一個表格)里的一系列相連的欄位。那麼這些相連的欄位就是外鍵。
什麼是觸發器?SQL Server 2000有什麼不同類型的觸發器?
讓未來的資料庫開發人員知道可用的觸發器類型以及如何實現它們是非常有益的
觸發器是一種專用類型的存儲過程,它被捆綁到SQL Server 2000的表格或者視圖上。在SQL Server 2000里,有INSTEAD-OF和AFTER兩種觸發器。INSTEAD-OF觸發器是替代數據操控語言(Data Manipulation Language,DML)語句對表格執行語句的存儲過程。例如,如果我有一個用於TableA的INSTEAD-OF-UPDATE觸發器,同時對這個表格執行一個更新語句,那麼INSTEAD-OF-UPDATE觸發器里的代碼會執行,而不是我執行的更新語句則不會執行操作。
AFTER觸發器要在DML語句在資料庫里使用之後才執行。這些類型的觸發器對於監視發生在資料庫表格里的數據變化十分好用。
您如何確一個帶有名為Fld1欄位的TableB表格里只具有Fld1欄位里的那些值,而這些值同時在名為TableA的表格的Fld1欄位里?
這個與關系相關的問題有兩個可能的答案。第一個答案(而且是您希望聽到的答案)是使用外鍵限制。外鍵限制用來維護引用的完整性。它被用來確保表格里的欄位只保存有已經在不同的(或者相同的)表格里的另一個欄位里定義了的值。這個欄位就是候選鍵(通常是另外一個表格的主鍵)。
另外一種答案是觸發器。觸發器可以被用來保證以另外一種方式實現與限制相同的作用,但是它非常難設置與維護,而且性能一般都很糟糕。由於這個原因,微軟建議開發人員使用外鍵限制而不是觸發器來維護引用的完整性。
對一個投入使用的在線事務處理表格有過多索引需要有什麼樣的性能考慮?
你正在尋找進行與數據操控有關的應聘人員。對一個表格的索引越多,資料庫引擎用來更新、插入或者刪除數據所需要的時間就越多,因為在數據操控發生的時候索引也必須要維護。
你可以用什麼來確保表格里的欄位只接受特定范圍里的值?
這個問題可以用多種方式來回答,但是只有一個答案是「好」答案。您希望聽到的回答是Check限制,它在資料庫表格里被定義,用來限制輸入該列的值。
觸發器也可以被用來限制資料庫表格里的欄位能夠接受的值,但是這種辦法要求觸發器在表格里被定義,這可能會在某些情況下影響到性能。因此,微軟建議使用Check限制而不是其他的方式來限制域的完整性。
<b?返回參數和output參數之間的區別是什麼?>如果應聘者能夠正確地回答這個問題,那麼他的機會就非常大了,因為這表明他們具有使用存儲過程的經驗。
返回參數總是由存儲過程返回,它用來表示存儲過程是成功還是失敗。返回參數總是INT數據類型。
OUTPUT參數明確要求由開發人員來指定,它可以返回其他類型的數據,例如字元型和數值型的值。(可以用作輸出參數的數據類型是有一些限制的。)您可以在一個存儲過程里使用多個OUTPUT參數,而您只能夠使用一個返回參數。
什麼是相關子查詢?如何使用這些查詢?
經驗更加豐富的開發人員將能夠准確地描述這種類型的查詢。
相關子查詢是一種包含子查詢的特殊類型的查詢。查詢里包含的子查詢會真正請求外部查詢的值,從而形成一個類似於循環的狀況。</b?返回參數和output參數之間的區別是什麼?>
❾ SQL面試題
推薦的學習Java的學習順序如下: 學習Java SE部分的內容,這部分是基礎內容。掌握的越扎實,後面的內容學習起來就越容易。學習SQL和資料庫的內容 ,這個也是非常基礎的內容,舉個例子:程序員的面試題中一定會有SQL部分的考試。學習HTML、css、JavaScript的內容。學習,JSP、Servlet、JavaBean、標記庫、JSTL、MVC、JSP EL等Web編程的部分學習Struts 或者Spring MVC。二者取其一即可,推薦選Struts 學習Java與XML ,重點掌握使用Java技術對XML文件的解析學習Java EE的核心技術 ,例如:JNDI、EJB3等,同時還需要學習使用與配置應用伺服器,例如:webLogic Server,Websphere,JBoss 學習Hibernate 等持久層的技術學習Spring 學習AJAX 學習ANT、Subversion等開發工具,熟悉常見的軟體開發模型,例如:rup、XP 學習OOA與OOD,uml,設計模式學習Web Services、SOA的原理與應用開發 最後,現在很多公司都使用Linux系統做為伺服器系統,並且使用Linux系統進行程序的開發(都是出於使用正版的考慮),所以Linux系統的安裝、使用和簡單管與配置,也是需要學習,這部分內容,跟其他內容沒有關聯,可以在任何時候學。推薦學習完SQL與資料庫之後進行學習。 你要想找到一份不錯的Java程序員工作,最基本的也要把1-12都學習了,當然有的內容需要深入掌握,有的內容可以慢慢的深入掌握的。