java常见面试题:Java程序员面试题(五)
本期的java面試題是偏向數據庫方面的,對相關技術知識匱乏的,或者對這方面不大自信的同學,面試之前可以參考一下這套題,這只是節(jié)選,試運營一下,如果不能滿足你們的需求,可以直接評論留言!
?
1、視圖的優(yōu)缺點
答:優(yōu)點: 1)對數據庫的訪問,因為視圖可以有選擇性的選取數據庫里的一部分。 2 )用戶通過簡單的查詢可以從復雜查詢中得到結果。 3 )維護數據的獨立性,試圖可從多個表檢索數據。 4 )對于相同的數據可產生不同的視圖。 缺點: 性能:查詢視圖時,必須把視圖的查詢轉化成對基本表的查詢,如果這個視圖是由一個復雜的多表查詢所定義,那么就無法更改數據。
2、在數據庫中查詢語句速度很慢,如何優(yōu)化?
答:1.建索引 2.減少表之間的關聯(lián) 3.優(yōu)化sql,盡量讓sql很快定位數據,不要讓sql做全表查詢,應該走索引,把數據量大的表排在前面 4.簡化查詢字段,沒用的字段不要,已經對返回結果的控制,盡量返回少量數據 5.盡量用PreparedStatement來查詢,不要用Statement
3、數據庫三范式是什么?
答:第一范式:列不可再分 第二范式:行可以唯一區(qū)分,主鍵約束 第三范式:表的非主屬性不能依賴與其他表的非主屬性 外鍵約束 且三大范式是一級一級依賴的,第二范式建立在第一范式上,第三范式建立第一第二范式上
4、union和union all有什么不同?
答:UNION在進行表鏈接后會篩選掉重復的記錄,所以在表鏈接后會對所產生的結果集進行排序運算,刪除重復的記錄再返回結果。實際大部分應用中是不會產生重復的記錄,常見的是過程表與歷史表UNION。 UNION ALL只是簡單的將兩個結果合并后就返回。這樣,如果返回的兩個結果集中有重復的數據,那么返回的結果集就會包含重復的數據了。 從效率上說,UNION ALL 要比UNION快很多,所以,如果可以確認合并的兩個結果集中不包含重復的數據的話,那么就使用UNION ALL。
5、Varchar2和varchar有什么區(qū)別?
答:Char的長度是固定的,而varchar2的長度是可以變化的,比如,存儲字符串“abc”對于char(20),表示你存儲的字符將占20個字節(jié),包含17個空,而同樣的varchar2(20)只占了3個字節(jié),20只是最大值,當你存儲的字符小于20時,按實際長度存儲。 char的效率要被varchar2的效率高。
目前varchar是varchar2的同義詞,工業(yè)標準的varchar類型可以存儲空字符串,但是oracle不能這樣做,盡管它保留以后這樣做的權利。Oracle自己開發(fā)了一個數據類型varchar2,這個類型不是一個標準的varchar,他將在數據庫中varchar列可以存儲空字符串的特性改為存儲null值,如果你想有向后兼容的能力,oracle建議使用varchar2而不是varchar。
未完待續(xù)……
總結
以上是生活随笔為你收集整理的java常见面试题:Java程序员面试题(五)的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: java 移位运算符_Java的移位运算
- 下一篇: Java的Socket编程实例