Java程序員面試數(shù)據(jù)庫(kù)面試題總結(jié)

Java程序員面試數(shù)據(jù)庫(kù)面試題總結(jié)

北大青鳥(niǎo)長(zhǎng)沙麓谷校區(qū)      2022-04-08 04:00:01     4

Java程序員面試數(shù)據(jù)庫(kù)面試題總結(jié),什么是事務(wù)?什么是鎖?事務(wù)就是被綁定在一起作為一個(gè)邏輯工作單元的SQL語(yǔ)句分組,如果任何一個(gè)語(yǔ)句操作失敗那么整個(gè)操作就被失

課程價(jià)格 請(qǐng)咨詢(xún)

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

詳細(xì)介紹

    什么是事務(wù)?什么是鎖?

    事務(wù)就是被綁定在一起作為一個(gè)邏輯工作單元的SQL語(yǔ)句分組,如果任何一個(gè)語(yǔ)句操作失敗那么整個(gè)操作就被失敗,以后操作就會(huì)回滾到操作前狀態(tài),或者是上有個(gè)節(jié)點(diǎn)。為了確保要么執(zhí)行,要么不執(zhí)行,就可以使用事務(wù)。要將有組語(yǔ)句作為事務(wù)考慮,就需要通過(guò)ACID測(cè)試,即原子性,一致性,隔離性和持久性。鎖:在所以的DBMS中,鎖是實(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í)別的。

    什么叫視圖?游標(biāo)是什么?

    視圖:是一種虛擬的表,具有和物理表相同的功能??梢詫?duì)視圖進(jìn)行增,改,查,操作,試圖通常是有一個(gè)表或者多個(gè)表的行或列的子集。對(duì)視圖的修改會(huì)影響基本表。它使得我們獲取數(shù)據(jù)更容易,相比多表查詢(xún)。游標(biāo):是對(duì)查詢(xún)出來(lái)的結(jié)果集作為一個(gè)單元來(lái)有效的處理。游標(biāo)可以定在該單元中的特定行,從結(jié)果集的當(dāng)前行檢索一行或多行??梢詫?duì)結(jié)果集當(dāng)前行做修改。一般不使用游標(biāo),但是需要逐條處理數(shù)據(jù)的時(shí)候,游標(biāo)顯得十分重要。

    視圖的優(yōu)缺點(diǎn)

    優(yōu)點(diǎn):1)對(duì)數(shù)據(jù)庫(kù)的訪問(wèn),因?yàn)橐晥D可以有選擇性的選取數(shù)據(jù)庫(kù)里的一部分。2)用戶(hù)通過(guò)簡(jiǎn)單的查詢(xún)可以從復(fù)雜查詢(xún)中得到結(jié)果。3)維護(hù)數(shù)據(jù)的獨(dú)立性,試圖可從多個(gè)表檢索數(shù)據(jù)。4)對(duì)于相同的數(shù)據(jù)可產(chǎn)生不同的視圖。缺點(diǎn):性能:查詢(xún)視圖時(shí),必須把視圖的查詢(xún)轉(zhuǎn)化成對(duì)基本表的查詢(xún),如果這個(gè)視圖是由一個(gè)復(fù)雜的多表查詢(xún)所定義,那么,那么就無(wú)法更改數(shù)據(jù)

    列舉幾種表連接方式,有什么區(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ì)顯示出來(lái)。交叉連接:笛卡爾效應(yīng),顯示的結(jié)果是鏈接表數(shù)的乘積。

    主鍵和外鍵的區(qū)別?

    主鍵在本表中是唯一的、不可唯空的,外鍵可以重復(fù)可以唯空;外鍵和另一張表的主鍵關(guān)聯(lián),不能創(chuàng)建對(duì)應(yīng)表中不存在的外鍵。

    在數(shù)據(jù)庫(kù)中查詢(xún)語(yǔ)句速度很慢,如何優(yōu)化?

    1.建索引2.減少表之間的關(guān)聯(lián)3.優(yōu)化sql,盡量讓sql很快定位數(shù)據(jù),不要讓sql做全表查詢(xún),應(yīng)該走索引,把數(shù)據(jù)量大的表排在前面4.簡(jiǎn)化查詢(xún)字段,沒(méi)用的字段不要,已經(jīng)對(duì)返回結(jié)果的控制,盡量返回少量數(shù)據(jù)5.盡量用PreparedStatement來(lái)查詢(xún),不要用Statement

    數(shù)據(jù)庫(kù)三范式是什么?

    第一范式:列不可再分第二范式:行可以唯一區(qū)分,主鍵約束第三范式:表的非主屬性不能依賴(lài)與其他表的非主屬性外鍵約束且三大范式是一級(jí)一級(jí)依賴(lài)的,第二范式建立在第一范式上,第三范式建立第一第二范式上

    union和unionall有什么不同?

    UNIOn在進(jìn)行表鏈接后會(huì)篩選掉重復(fù)的記錄,所以在表鏈接后會(huì)對(duì)所產(chǎn)生的結(jié)果集進(jìn)行排序運(yùn)算,刪除重復(fù)的記錄再返回結(jié)果。實(shí)際大部分應(yīng)用中是不會(huì)產(chǎn)生重復(fù)的記錄,最常見(jiàn)的是過(guò)程表與歷史表UNIOn。UNIOnALL只是簡(jiǎn)單的將兩個(gè)結(jié)果合并后就返回。這樣,如果返回的兩個(gè)結(jié)果集中有重復(fù)的數(shù)據(jù),那么返回的結(jié)果集就會(huì)包含重復(fù)的數(shù)據(jù)了。從效率上說(shuō),UNIOnALL要比UNIOn快很多,所以,如果可以確認(rèn)合并的兩個(gè)結(jié)果集中不包含重復(fù)的數(shù)據(jù)的話(huà),那么就使用UNIOnALL。

    Varchar2和varchar有什么區(qū)別?

    Char的長(zhǎng)度是固定的,而varchar2的長(zhǎng)度是可以變化的,比如,存儲(chǔ)字符串“abc”對(duì)于char(20),表示你存儲(chǔ)的字符將占20個(gè)字節(jié),包含17個(gè)空,而同樣的varchar2(20)只占了3個(gè)字節(jié),20只是最大值,當(dāng)你存儲(chǔ)的字符小于20時(shí),按實(shí)際長(zhǎng)度存儲(chǔ)。char的效率要被varchar2的效率高。目前varchar是varchar2的同義詞,工業(yè)標(biāo)準(zhǔn)的varchar類(lèi)型可以存儲(chǔ)空字符串,但是oracle不能這樣做,盡管它保留以后這樣做的權(quán)利。Oracle自己開(kāi)發(fā)了一個(gè)數(shù)據(jù)類(lèi)型varchar2,這個(gè)類(lèi)型不是一個(gè)標(biāo)準(zhǔn)的varchar,他將在數(shù)據(jù)庫(kù)中varchar列可以存儲(chǔ)空字符串的特性改為存儲(chǔ)null值,如果你想有向后兼容的能力,oracle建議使用varchar2而不是varchar

 以上就是北大青鳥(niǎo)長(zhǎng)沙麓谷校區(qū)java培訓(xùn)機(jī)構(gòu)的小編針對(duì)“Java程序員面試數(shù)據(jù)庫(kù)面試題總結(jié)”的內(nèi)容進(jìn)行的回答,希望對(duì)大家有所幫助,如有疑問(wèn),請(qǐng)?jiān)诰€咨詢(xún),有專(zhuān)業(yè)老師隨時(shí)為你服務(wù)。

Java面試題

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