更新時間:2019-07-11 10:44:41 來源:動力節(jié)點(diǎn) 瀏覽2548次
進(jìn)了互聯(lián)網(wǎng)公司,整天也就是搬磚,等到了面試的時候,發(fā)現(xiàn)數(shù)據(jù)庫方面,忘得一塌糊涂,抽時間整理了一些Java數(shù)據(jù)庫方面的面試題,希望可以幫助到大家:
1、觸發(fā)器的作用?
觸發(fā)器是一中特殊的存儲過程,主要是通過事件來觸發(fā)而被執(zhí)行的。它可以強(qiáng)化約束,來維護(hù)數(shù)據(jù)的完整性和一致性,可以跟蹤數(shù)據(jù)庫內(nèi)的操作從而不允許未經(jīng)許可的更新和變化。可以聯(lián)級運(yùn)算。如,某表上的觸發(fā)器上包含對另一個表的數(shù)據(jù)操作,而該操作又會導(dǎo)致該表觸發(fā)器被觸發(fā)。
2、什么是存儲過程?用什么來調(diào)用?
存儲過程是一個預(yù)編譯的SQL語句,優(yōu)點(diǎn)是允許模塊化的設(shè)計,就是說只需創(chuàng)建一次,以后在該程序中就可以調(diào)用多次。如果某次操作需要執(zhí)行多次SQL,使用存儲過程比單純SQL語句執(zhí)行要快。調(diào)用:1)可以用一個命令對象來調(diào)用存儲過程。2)可以供外部程序調(diào)用,比如:java程序。
3、存儲過程的優(yōu)缺點(diǎn)?
優(yōu)點(diǎn):1)存儲過程是預(yù)編譯過的,執(zhí)行效率高。2)存儲過程的代碼直接存放于數(shù)據(jù)庫中,通過存儲過程名直接調(diào)用,減少網(wǎng)絡(luò)通訊。3)安全性高,執(zhí)行存儲過程需要有一定權(quán)限的用戶。4)存儲過程可以重復(fù)使用,可減少數(shù)據(jù)庫開發(fā)人員的工作量。缺點(diǎn):移植性差
4、存儲過程與函數(shù)的區(qū)別
5、索引的作用?和它的優(yōu)點(diǎn)缺點(diǎn)是什么?
索引就一種特殊的查詢表,數(shù)據(jù)庫的搜索可以利用它加速對數(shù)據(jù)的檢索。它很類似與現(xiàn)實(shí)生活中書的目錄,不需要查詢整本書內(nèi)容就可以找到想要的數(shù)據(jù)。索引可以是唯一的,創(chuàng)建索引允許指定單個列或者是多個列。缺點(diǎn)是它減慢了數(shù)據(jù)錄入的速度,同時也增加了數(shù)據(jù)庫的尺寸大小。
6、什么是事務(wù)?什么是鎖?
事務(wù)就是被綁定在一起作為一個邏輯工作單元的SQL語句分組,如果任何一個語句操作失敗那么整個操作就被失敗,以后操作就會回滾到操作前狀態(tài),或者是上有個節(jié)點(diǎn)。為了確保要么執(zhí)行,要么不執(zhí)行,就可以使用事務(wù)。要將有組語句作為事務(wù)考慮,就需要通過ACID測試,即原子性,一致性,隔離性和持久性。鎖:在所以的DBMS中,鎖是實(shí)現(xiàn)事務(wù)的關(guān)鍵,鎖可以保證事務(wù)的完整性和并發(fā)性。與現(xiàn)實(shí)生活中鎖一樣,它可以使某些數(shù)據(jù)的擁有者,在某段時間內(nèi)不能使用某些數(shù)據(jù)或數(shù)據(jù)結(jié)構(gòu)。當(dāng)然鎖還分級別的。
7、什么叫視圖?游標(biāo)是什么?
視圖:是一種虛擬的表,具有和物理表相同的功能。可以對視圖進(jìn)行增,改,查,操作,試圖通常是有一個表或者多個表的行或列的子集。對視圖的修改會影響基本表。它使得我們獲取數(shù)據(jù)更容易,相比多表查詢。游標(biāo):是對查詢出來的結(jié)果集作為一個單元來有效的處理。游標(biāo)可以定在該單元中的特定行,從結(jié)果集的當(dāng)前行檢索一行或多行。可以對結(jié)果集當(dāng)前行做修改。一般不使用游標(biāo),但是需要逐條處理數(shù)據(jù)的時候,游標(biāo)顯得十分重要。
8、視圖的優(yōu)缺點(diǎn)
優(yōu)點(diǎn):1)對數(shù)據(jù)庫的訪問,因?yàn)橐晥D可以有選擇性的選取數(shù)據(jù)庫里的一部分。2)用戶通過簡單的查詢可以從復(fù)雜查詢中得到結(jié)果。3)維護(hù)數(shù)據(jù)的獨(dú)立性,試圖可從多個表檢索數(shù)據(jù)。4)對于相同的數(shù)據(jù)可產(chǎn)生不同的視圖。缺點(diǎn):性能:查詢視圖時,必須把視圖的查詢轉(zhuǎn)化成對基本表的查詢,如果這個視圖是由一個復(fù)雜的多表查詢所定義,那么,那么就無法更改數(shù)據(jù)
9、列舉幾種表連接方式,有什么區(qū)別?
內(nèi)連接、自連接、外連接(左、右、全)、交叉連接內(nèi)連接:只有兩個元素表相匹配的才能在結(jié)果集中顯示。外連接:左外連接:左邊為驅(qū)動表,驅(qū)動表的數(shù)據(jù)全部顯示,匹配表的不匹配的不會顯示。右外連接:右邊為驅(qū)動表,驅(qū)動表的數(shù)據(jù)全部顯示,匹配表的不匹配的不會顯示。全外連接:連接的表中不匹配的數(shù)據(jù)全部會顯示出來。交叉連接:笛卡爾效應(yīng),顯示的結(jié)果是鏈接表數(shù)的乘積。
相關(guān)閱讀
初級 202925
初級 203221
初級 202629
初級 203743