更新時(shí)間:2020-02-03 17:14:44 來源:動(dòng)力節(jié)點(diǎn) 瀏覽2699次
數(shù)據(jù)庫的知識(shí),對(duì)于開發(fā)工程師來講,也是同樣重要,是開發(fā)過程中的重中之重,很多的業(yè)務(wù)邏輯,比如:報(bào)表模塊等,只要sql語句能寫出來,就相當(dāng)于完成大部分的功能了,以下為關(guān)于數(shù)據(jù)庫在面試過程中常見的10道題,供參考。
1:觸發(fā)器的作用?
·觸發(fā)器是一種特殊的存儲(chǔ)過程,主要是通過事件來觸發(fā)而被執(zhí)行的。
·它可以強(qiáng)化約束,來維護(hù)數(shù)據(jù)的完整性和一致性。
·可在寫入數(shù)據(jù)表前,強(qiáng)制檢驗(yàn)或轉(zhuǎn)換數(shù)據(jù)。
·觸發(fā)器發(fā)生錯(cuò)誤時(shí),異動(dòng)的結(jié)果會(huì)被撤銷。
·部分?jǐn)?shù)據(jù)庫管理系統(tǒng)可以針對(duì)數(shù)據(jù)定義語言(DDL)使用觸發(fā)器,稱為DDL觸發(fā)器。
·可依照特定的情況,替換異動(dòng)的指令(INSTEADOF)。
2:觸發(fā)器的限制有哪些?
·一個(gè)表最多只能有三個(gè)觸發(fā)器,insert、update、delete
·每個(gè)觸發(fā)器只能用于一個(gè)表
·不能對(duì)視圖、臨時(shí)表創(chuàng)建觸發(fā)器
·Truncatetable能刪除表,但不能觸發(fā)觸發(fā)器
3:什么是存儲(chǔ)過程?用什么來調(diào)用?
·存儲(chǔ)過程存在于大型數(shù)據(jù)庫系統(tǒng)中,是一個(gè)預(yù)編譯的SQL語句(為了完成特定功能的SQL語句集),經(jīng)過第一次編譯后再次調(diào)用不需要再次編譯。
-優(yōu)點(diǎn)是:
-允許模塊化的設(shè)計(jì),就是說只需創(chuàng)建一次,以后在該程序中就可以調(diào)用多次。
-如果某次操作需要執(zhí)行多次SQL,使用存儲(chǔ)過程比單純SQL語句執(zhí)行要快。
-減少網(wǎng)絡(luò)流量。存儲(chǔ)過程位于服務(wù)器上,調(diào)用的時(shí)候只需要傳遞存儲(chǔ)過程的名稱以及參數(shù)就可以了,因此降低了網(wǎng)絡(luò)傳輸?shù)臄?shù)據(jù)量。
-安全性。參數(shù)化的存儲(chǔ)過程可以防止SQL注入式攻擊,而且可以將Grant、Deny以及Revoke權(quán)限應(yīng)用于存儲(chǔ)過程。
-調(diào)用:
-1)可以用一個(gè)命令對(duì)象來調(diào)用存儲(chǔ)過程。
-2)可以供外部程序調(diào)用,比如:java程序。
4:索引的作用?它的優(yōu)缺點(diǎn)是什么?
·索引就一種特殊的查詢表,數(shù)據(jù)庫的搜索可以利用它加速對(duì)數(shù)據(jù)的檢索。
·它很類似與現(xiàn)實(shí)生活中書的目錄,不需要查詢整本書內(nèi)容就可以找到想要的數(shù)據(jù)。
·索引可以是唯一的,創(chuàng)建索引允許指定單個(gè)列或者是多個(gè)列。
·缺點(diǎn)是它減慢了數(shù)據(jù)錄入的速度,同時(shí)也增加了數(shù)據(jù)庫的尺寸大小。
5:什么樣的字段適合建索引?
·唯一
·主、外鍵
·不為空
·表之間的關(guān)聯(lián)字段
·查詢比較頻繁的字段
6:索引類型有哪些?
Singlecolumn單行索引
Concatenated多行索引
Unique唯一索引
NonUnique非唯一索引
Function-based函數(shù)索引
Domain域索引物理上:
Partitioned分區(qū)索引
NonPartitioned非分區(qū)索引
B-tree:
Normal正常型B樹
ReverKey反轉(zhuǎn)型B樹
Bitmap位圖索引
7:什么是事務(wù)?什么是鎖?
-事務(wù)就是被綁定在一起作為一個(gè)邏輯工作單元的SQL語句分組
如果任何一個(gè)語句操作失敗那么整個(gè)操作就被失敗,以后操作就會(huì)回滾到操作前狀態(tài),或者是上有個(gè)節(jié)點(diǎn)。
為了確保要么執(zhí)行,要么不執(zhí)行,就可以使用事務(wù)。
要將有組語句作為事務(wù)考慮,就需要通過ACID測試:
即原子性,一致性,隔離性和持久性。
-鎖:鎖是實(shí)現(xiàn)事務(wù)的關(guān)鍵,鎖可以保證事務(wù)的完整性和并發(fā)性。
與現(xiàn)實(shí)生活中鎖一樣,它可以使某些數(shù)據(jù)的擁有者,在某段時(shí)間內(nèi)不能使用某些數(shù)據(jù)或數(shù)據(jù)結(jié)構(gòu)。
當(dāng)然鎖還分級(jí)別的,比如頁級(jí)鎖、行級(jí)鎖等。
8:什么叫視圖?游標(biāo)是什么?
-視圖:是一種虛擬的表,具有和物理表相同的功能。
可以對(duì)視圖進(jìn)行增,改,查,操作,試圖通常是有一個(gè)表或者多個(gè)表的行或列的子集。
對(duì)視圖的修改會(huì)影響基本表。它使得我們獲取數(shù)據(jù)更容易,相比多表查詢。
-游標(biāo):是對(duì)查詢出來的結(jié)果集作為一個(gè)單元來有效的處理。
游標(biāo)可以定在該單元中的特定行,從結(jié)果集的當(dāng)前行檢索一行或多行。
可以對(duì)結(jié)果集當(dāng)前行做修改。
一般不使用游標(biāo),但是需要逐條處理數(shù)據(jù)的時(shí)候,游標(biāo)顯得十分重要。
9:視圖的優(yōu)缺點(diǎn)?
-優(yōu)點(diǎn):
-對(duì)數(shù)據(jù)庫的訪問,因?yàn)橐晥D可以有選擇性的選取數(shù)據(jù)庫里的一部分。
-用戶通過簡單的查詢可以從復(fù)雜查詢中得到結(jié)果。
-維護(hù)數(shù)據(jù)的獨(dú)立性,試圖可從多個(gè)表檢索數(shù)據(jù)。
-對(duì)于相同的數(shù)據(jù)可產(chǎn)生不同的視圖。
-缺點(diǎn):
-性能:查詢視圖時(shí),必須把視圖的查詢轉(zhuǎn)化成對(duì)基本表的查詢,如果這個(gè)視圖是由一個(gè)復(fù)雜的多表查詢所定義,那么,那么就無法更改數(shù)據(jù)
10:列舉幾種表連接方式,有什么區(qū)別?
-內(nèi)連接、自連接、外連接(左、右、全)、交叉連接
-內(nèi)連接:只有兩個(gè)元素表相匹配的才能在結(jié)果集中顯示。
-外連接:
-左外連接:左邊為驅(qū)動(dòng)表,驅(qū)動(dòng)表的數(shù)據(jù)全部顯示,匹配表的不匹配的不會(huì)顯示。
-右外連接:右邊為驅(qū)動(dòng)表,驅(qū)動(dòng)表的數(shù)據(jù)全部顯示,匹配表的不匹配的不會(huì)顯示。
-全外連接:連接的表中不匹配的數(shù)據(jù)全部會(huì)顯示出來。
-交叉連接:笛卡爾效應(yīng),顯示的結(jié)果是鏈接表數(shù)的乘積。
以上就是動(dòng)力節(jié)點(diǎn)Java培訓(xùn)機(jī)構(gòu)小編介紹的“收藏版Java初級(jí)面試題數(shù)據(jù)庫”的內(nèi)容,希望對(duì)大家有幫助,如有疑問,請(qǐng)?jiān)诰€咨詢,有專業(yè)老師隨時(shí)為你服務(wù)。
相關(guān)推薦
相關(guān)閱讀
0基礎(chǔ) 0學(xué)費(fèi) 15天面授
有基礎(chǔ) 直達(dá)就業(yè)
業(yè)余時(shí)間 高薪轉(zhuǎn)行
工作1~3年,加薪神器
工作3~5年,晉升架構(gòu)
提交申請(qǐng)后,顧問老師會(huì)電話與您溝通安排學(xué)習(xí)
初級(jí) 202925
初級(jí) 203221
初級(jí) 202629
初級(jí) 203743