收藏版Java初級面試題數(shù)據(jù)庫

收藏版Java初級面試題數(shù)據(jù)庫

長沙中公優(yōu)就業(yè)      2022-04-22 21:21:01     8

收藏版Java初級面試題數(shù)據(jù)庫,  數(shù)據(jù)庫的知識,對于開發(fā)工程師來講,也是同樣重要,是開發(fā)過程中的重中之重,很多的業(yè)務(wù)邏輯,比如:報表模塊等,只要sql語

課程價格 請咨詢

上課時段: 授課校區(qū):

詳細介紹


  數(shù)據(jù)庫的知識,對于開發(fā)工程師來講,也是同樣重要,是開發(fā)過程中的重中之重,很多的業(yè)務(wù)邏輯,比如:報表模塊等,只要sql語句能寫出來,就相當于完成大部分的功能了,以下為關(guān)于數(shù)據(jù)庫在面試過程中常見的10道題,供參考。



  1:觸發(fā)器的作用?


  ·觸發(fā)器是一種特殊的存儲過程,主要是通過事件來觸發(fā)而被執(zhí)行的。


  ·它可以強化約束,來維護數(shù)據(jù)的完整性和一致性。


  ·可在寫入數(shù)據(jù)表前,強制檢驗或轉(zhuǎn)換數(shù)據(jù)。


  ·觸發(fā)器發(fā)生錯誤時,異動的結(jié)果會被撤銷。


  ·部分數(shù)據(jù)庫管理系統(tǒng)可以針對數(shù)據(jù)定義語言(DDL)使用觸發(fā)器,稱為DDL觸發(fā)器。


  ·可依照特定的情況,替換異動的指令(INSTEADOF)。


  2:觸發(fā)器的限制有哪些?


  ·一個表最多只能有三個觸發(fā)器,insert、update、delete


  ·每個觸發(fā)器只能用于一個表


  ·不能對視圖、臨時表創(chuàng)建觸發(fā)器


  ·Truncatetable能刪除表,但不能觸發(fā)觸發(fā)器


  3:什么是存儲過程?用什么來調(diào)用?


  ·存儲過程存在于大型數(shù)據(jù)庫系統(tǒng)中,是一個預(yù)編譯的SQL語句(為了完成特定功能的SQL語句集),經(jīng)過第一次編譯后再次調(diào)用不需要再次編譯。


  -優(yōu)點是:


  -允許模塊化的設(shè)計,就是說只需創(chuàng)建一次,以后在該程序中就可以調(diào)用多次。


  -如果某次操作需要執(zhí)行多次SQL,使用存儲過程比單純SQL語句執(zhí)行要快。


  -減少網(wǎng)絡(luò)流量。存儲過程位于服務(wù)器上,調(diào)用的時候只需要傳遞存儲過程的名稱以及參數(shù)就可以了,因此降低了網(wǎng)絡(luò)傳輸?shù)臄?shù)據(jù)量。


  -安全性。參數(shù)化的存儲過程可以防止SQL注入式攻擊,而且可以將Grant、Deny以及Revoke權(quán)限應(yīng)用于存儲過程。


  -調(diào)用:


  -1)可以用一個命令對象來調(diào)用存儲過程。


  -2)可以供外部程序調(diào)用,比如:java程序。


  4:索引的作用?它的優(yōu)缺點是什么?


  ·索引就一種特殊的查詢表,數(shù)據(jù)庫的搜索可以利用它加速對數(shù)據(jù)的檢索。


  ·它很類似與現(xiàn)實生活中書的目錄,不需要查詢整本書內(nèi)容就可以找到想要的數(shù)據(jù)。


  ·索引可以是唯一的,創(chuàng)建索引允許指定單個列或者是多個列。


  ·缺點是它減慢了數(shù)據(jù)錄入的速度,同時也增加了數(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ù)就是被綁定在一起作為一個邏輯工作單元的SQL語句分組


  如果任何一個語句操作失敗那么整個操作就被失敗,以后操作就會回滾到操作前狀態(tài),或者是上有個節(jié)點。


  為了確保要么執(zhí)行,要么不執(zhí)行,就可以使用事務(wù)。


  要將有組語句作為事務(wù)考慮,就需要通過ACID測試:


  即原子性,一致性,隔離性和持久性。


  -鎖:鎖是實現(xiàn)事務(wù)的關(guān)鍵,鎖可以保證事務(wù)的完整性和并發(fā)性。


  與現(xiàn)實生活中鎖一樣,它可以使某些數(shù)據(jù)的擁有者,在某段時間內(nèi)不能使用某些數(shù)據(jù)或數(shù)據(jù)結(jié)構(gòu)。


  當然鎖還分級別的,比如頁級鎖、行級鎖等。


  8:什么叫視圖?游標是什么?


  -視圖:是一種虛擬的表,具有和物理表相同的功能。


  可以對視圖進行增,改,查,操作,試圖通常是有一個表或者多個表的行或列的子集。


  對視圖的修改會影響基本表。它使得我們獲取數(shù)據(jù)更容易,相比多表查詢。


  -游標:是對查詢出來的結(jié)果集作為一個單元來有效的處理。


  游標可以定在該單元中的特定行,從結(jié)果集的當前行檢索一行或多行。


  可以對結(jié)果集當前行做修改。


  一般不使用游標,但是需要逐條處理數(shù)據(jù)的時候,游標顯得十分重要。


  9:視圖的優(yōu)缺點?


  -優(yōu)點:


  -對數(shù)據(jù)庫的訪問,因為視圖可以有選擇性的選取數(shù)據(jù)庫里的一部分。


  -用戶通過簡單的查詢可以從復(fù)雜查詢中得到結(jié)果。


  -維護數(shù)據(jù)的獨立性,試圖可從多個表檢索數(shù)據(jù)。


  -對于相同的數(shù)據(jù)可產(chǎn)生不同的視圖。


  -缺點:


  -性能:查詢視圖時,必須把視圖的查詢轉(zhuǎn)化成對基本表的查詢,如果這個視圖是由一個復(fù)雜的多表查詢所定義,那么,那么就無法更改數(shù)據(jù)


  10:列舉幾種表連接方式,有什么區(qū)別?


  -內(nèi)連接、自連接、外連接(左、右、全)、交叉連接


  -內(nèi)連接:只有兩個元素表相匹配的才能在結(jié)果集中顯示。


  -外連接:


  -左外連接:左邊為驅(qū)動表,驅(qū)動表的數(shù)據(jù)全部顯示,匹配表的不匹配的不會顯示。


  -右外連接:右邊為驅(qū)動表,驅(qū)動表的數(shù)據(jù)全部顯示,匹配表的不匹配的不會顯示。


  -全外連接:連接的表中不匹配的數(shù)據(jù)全部會顯示出來。


  -交叉連接:笛卡爾效應(yīng),顯示的結(jié)果是鏈接表數(shù)的乘積。



      以上就是長沙中公優(yōu)就業(yè)Java培訓(xùn)機構(gòu)小編介紹的“收藏版Java初級面試題數(shù)據(jù)庫”的內(nèi)容,希望對大家有幫助,如有疑問,請在線咨詢,有專業(yè)老師隨時為你服務(wù)。


相關(guān)推薦


最新最全java面試題及答案(初級到高級)


史上最全的中高級JAVA工程師面試題及答案匯總


Java高級開發(fā)工程師面試題


2019史上最全java面試題題庫大全800題


哪有資深java工程師面試題


培訓(xùn)啦提醒您:交易時請核實對方資質(zhì),對于過大宣傳或承諾需謹慎!任何要求預(yù)付定金、匯款等方式均存在風(fēng)險,謹防上當。