更新時間:2020-04-24 15:02:52 來源:動力節點 瀏覽2644次
什么是事務?什么是鎖?
事務就是被綁定在一起作為一個邏輯工作單元的SQL語句分組,如果任何一個語句操作失敗那么整個操作就被失敗,以后操作就會回滾到操作前狀態,或者是上有個節點。為了確保要么執行,要么不執行,就可以使用事務。要將有組語句作為事務考慮,就需要通過ACID測試,即原子性,一致性,隔離性和持久性。鎖:在所以的DBMS中,鎖是實現事務的關鍵,鎖可以保證事務的完整性和并發性。與現實生活中鎖一樣,它可以使某些數據的擁有者,在某段時間內不能使用某些數據或數據結構。當然鎖還分級別的。
什么叫視圖?游標是什么?
視圖:是一種虛擬的表,具有和物理表相同的功能。可以對視圖進行增,改,查,操作,試圖通常是有一個表或者多個表的行或列的子集。對視圖的修改會影響基本表。它使得我們獲取數據更容易,相比多表查詢。游標:是對查詢出來的結果集作為一個單元來有效的處理。游標可以定在該單元中的特定行,從結果集的當前行檢索一行或多行。可以對結果集當前行做修改。一般不使用游標,但是需要逐條處理數據的時候,游標顯得十分重要。
視圖的優缺點
優點:1)對數據庫的訪問,因為視圖可以有選擇性的選取數據庫里的一部分。2)用戶通過簡單的查詢可以從復雜查詢中得到結果。3)維護數據的獨立性,試圖可從多個表檢索數據。4)對于相同的數據可產生不同的視圖。缺點:性能:查詢視圖時,必須把視圖的查詢轉化成對基本表的查詢,如果這個視圖是由一個復雜的多表查詢所定義,那么,那么就無法更改數據
列舉幾種表連接方式,有什么區別?
內連接、自連接、外連接(左、右、全)、交叉連接內連接:只有兩個元素表相匹配的才能在結果集中顯示。外連接:左外連接:左邊為驅動表,驅動表的數據全部顯示,匹配表的不匹配的不會顯示。右外連接:右邊為驅動表,驅動表的數據全部顯示,匹配表的不匹配的不會顯示。全外連接:連接的表中不匹配的數據全部會顯示出來。交叉連接:笛卡爾效應,顯示的結果是鏈接表數的乘積。
主鍵和外鍵的區別?
主鍵在本表中是唯一的、不可唯空的,外鍵可以重復可以唯空;外鍵和另一張表的主鍵關聯,不能創建對應表中不存在的外鍵。
在數據庫中查詢語句速度很慢,如何優化?
1.建索引2.減少表之間的關聯3.優化sql,盡量讓sql很快定位數據,不要讓sql做全表查詢,應該走索引,把數據量大的表排在前面4.簡化查詢字段,沒用的字段不要,已經對返回結果的控制,盡量返回少量數據5.盡量用PreparedStatement來查詢,不要用Statement
數據庫三范式是什么?
第一范式:列不可再分第二范式:行可以唯一區分,主鍵約束第三范式:表的非主屬性不能依賴與其他表的非主屬性外鍵約束且三大范式是一級一級依賴的,第二范式建立在第一范式上,第三范式建立第一第二范式上
union和unionall有什么不同?
UNION在進行表鏈接后會篩選掉重復的記錄,所以在表鏈接后會對所產生的結果集進行排序運算,刪除重復的記錄再返回結果。實際大部分應用中是不會產生重復的記錄,最常見的是過程表與歷史表UNION。UNIONALL只是簡單的將兩個結果合并后就返回。這樣,如果返回的兩個結果集中有重復的數據,那么返回的結果集就會包含重復的數據了。從效率上說,UNIONALL要比UNION快很多,所以,如果可以確認合并的兩個結果集中不包含重復的數據的話,那么就使用UNIONALL。
Varchar2和varchar有什么區別?
Char的長度是固定的,而varchar2的長度是可以變化的,比如,存儲字符串“abc”對于char(20),表示你存儲的字符將占20個字節,包含17個空,而同樣的varchar2(20)只占了3個字節,20只是最大值,當你存儲的字符小于20時,按實際長度存儲。char的效率要被varchar2的效率高。目前varchar是varchar2的同義詞,工業標準的varchar類型可以存儲空字符串,但是oracle不能這樣做,盡管它保留以后這樣做的權利。Oracle自己開發了一個數據類型varchar2,這個類型不是一個標準的varchar,他將在數據庫中varchar列可以存儲空字符串的特性改為存儲null值,如果你想有向后兼容的能力,oracle建議使用varchar2而不是varchar
以上就是動力節點java培訓機構的小編針對“Java程序員面試數據庫面試題總結”的內容進行的回答,希望對大家有所幫助,如有疑問,請在線咨詢,有專業老師隨時為你服務。
0基礎 0學費 15天面授
有基礎 直達就業
業余時間 高薪轉行
工作1~3年,加薪神器
工作3~5年,晉升架構
提交申請后,顧問老師會電話與您溝通安排學習