歡迎光臨
每天分享高質量文章

資料庫常見的面試題大全

綜合自網路


1、觸發器的作用?

觸發器是一中特殊的儲存過程,主要是透過事件來觸發而被執行的。它可以強化約束,來維護資料的完整性和一致性,可以跟蹤資料庫內的操作從而不允許未經許可的更新和變化。可以聯級運算。如,某表上的觸發器上包含對另一個表的資料操作,而該操作又會導致該表觸發器被觸發。

2、什麼是儲存過程?用什麼來呼叫?

儲存過程是一個預編譯的SQL陳述句,優點是允許模組化的設計,就是說只需建立一次,以後在該程式中就可以呼叫多次。如果某次操作需要執行多次SQL,使用儲存過程比單純SQL陳述句執行要快。 呼叫: 1)可以用一個命令物件來呼叫儲存過程。 2)可以供外部程式呼叫,比如:java程式。

3、儲存過程的優缺點?

優點: 1)儲存過程是預編譯過的,執行效率高。 2)儲存過程的程式碼直接存放於資料庫中,透過儲存過程名直接呼叫,減少網路通訊。 3)安全性高,執行儲存過程需要有一定許可權的使用者。 4)儲存過程可以重覆使用,可減少資料庫開發人員的工作量。 缺點:移植性差

4、儲存過程與函式的區別

儲存過程

1、用於在資料庫中完成特定的操作或者任務(如插入、刪除等)

2、程式頭部宣告用procedure

3、程式頭部宣告時不需描述傳回型別可以使用in/out/in out 三種樣式的引數

4、可作為一個獨立的PL/SQL陳述句來執行

5、可以透過out/in out 傳回零個或多個值

6、SQL陳述句(DML 或SELECT)中不可呼叫儲存過程

函式

1、用於特定的資料(如選擇)

2、程式頭部宣告用function

3、程式頭部宣告時要描述傳回型別,而且PL/SQL塊中至少要包括一個有效的return陳述句

4、可以使用in/out/in out 三種樣式的引數

5、不能獨立執行,必須作為運算式的一部分呼叫

6、透過return陳述句傳回一個值,且改值要與宣告部分一致,也可以是透過out型別的引數帶出的變數

7、SQL陳述句(DML 或SELECT)中可以呼叫函式

5、索引的作用?和它的優點缺點是什麼?

索引就一種特殊的查詢表,資料庫的搜尋可以利用它加速對資料的檢索。它很類似與現實生活中書的目錄,不需要查詢整本書內容就可以找到想要的資料。索引可以是唯一的,建立索引允許指定單個列或者是多個列。缺點是它減慢了資料錄入的速度,同時也增加了資料庫的尺寸大小。

6、什麼樣的欄位適合建索引

唯一、不為空、經常被查詢的欄位

7、索引型別有哪些?

邏輯上:

Single column 單行索引

Concatenated 多行索引

Unique 唯一索引

NonUnique 非唯一索引

Function-based 函式索引

Domain 域索引 物理上:

Partitioned 分割槽索引

NonPartitioned 非分割槽索引

B-tree :

Normal 正常型B樹

Rever Key 反轉型B樹 Bitmap 點陣圖索引

8、什麼是事務?什麼是鎖?

事務就是被系結在一起作為一個邏輯工作單元的SQL陳述句分組,如果任何一個陳述句操作失敗那麼整個操作就被失敗,以後操作就會回滾到操作前狀態,或者是上有個節點。為了確保要麼執行,要麼不執行,就可以使用事務。要將有組陳述句作為事務考慮,就需要透過ACID測試,即原子性,一致性,隔離性和永續性。 鎖:在所以的DBMS中,鎖是實現事務的關鍵,鎖可以保證事務的完整性和併發性。與現實生活中鎖一樣,它可以使某些資料的擁有者,在某段時間內不能使用某些資料或資料結構。當然鎖還分級別的。

9、什麼叫檢視?遊標是什麼?

檢視:是一種虛擬的表,具有和物理表相同的功能。可以對檢視進行增,改,查,操作,試圖通常是有一個表或者多個表的行或列的子集。對檢視的修改會影響基本表。它使得我們獲取資料更容易,相比多表查詢。 遊標:是對查詢出來的結果集作為一個單元來有效的處理。遊標可以定在該單元中的特定行,從結果集的當前行檢索一行或多行。可以對結果集當前行做修改。一般不使用遊標,但是需要逐條處理資料的時候,遊標顯得十分重要。

10、檢視的優缺點

優點: 1)對資料庫的訪問,因為檢視可以有選擇性的選取資料庫裡的一部分。 2 )使用者透過簡單的查詢可以從複雜查詢中得到結果。 3 )維護資料的獨立性,試圖可從多個表檢索資料。 4 )對於相同的資料可產生不同的檢視。 缺點: 效能:查詢檢視時,必須把檢視的查詢轉化成對基本表的查詢,如果這個檢視是由一個複雜的多表查詢所定義,那麼,那麼就無法更改資料

11、列舉幾種表連線方式,有什麼區別?

內連線、自連線、外連線(左、右、全)、交叉連線 內連線:只有兩個元素表相匹配的才能在結果集中顯示。 外連線: 左外連線:左邊為驅動表,驅動表的資料全部顯示,匹配表的不匹配的不會顯示。 右外連線:右邊為驅動表,驅動表的資料全部顯示,匹配表的不匹配的不會顯示。 全外連線:連線的表中不匹配的資料全部會顯示出來。 交叉連線: 笛卡爾效應,顯示的結果是連結表數的乘積。

12、主鍵和外來鍵的區別?

主鍵在本表中是唯一的、不可唯空的,外來鍵可以重覆可以唯空;外來鍵和另一張表的主鍵關聯,不能建立對應表中不存在的外來鍵。

13、在資料庫中查詢陳述句速度很慢,如何最佳化?

1.建索引 2.減少表之間的關聯 3.最佳化sql,儘量讓sql很快定位資料,不要讓sql做全表查詢,應該走索引,把資料 量大的表排在前面 4.簡化查詢欄位,沒用的欄位不要,已經對傳回結果的控制,儘量傳回少量資料 5.儘量用PreparedStatement來查詢,不要用Statement

14、資料庫三正規化是什麼?

第一正規化:列不可再分 第二正規化:行可以唯一區分,主鍵約束 第三正規化:表的非主屬性不能依賴與其他表的非主屬性 外來鍵約束 且三大正規化是一級一級依賴的,第二正規化建立在第一正規化上,第三正規化建立第一第二正規化上

15、union和union all有什麼不同?

UNION在進行錶連結後會篩選掉重覆的記錄,所以在錶連結後會對所產生的結果集進行排序運算,刪除重覆的記錄再傳回結果。實際大部分應用中是不會產生重覆的記錄,最常見的是過程表與歷史表UNION。 UNION ALL只是簡單的將兩個結果合併後就傳回。這樣,如果傳回的兩個結果集中有重覆的資料,那麼傳回的結果集就會包含重覆的資料了。 從效率上說,UNION ALL 要比UNION快很多,所以,如果可以確認合併的兩個結果集中不包含重覆的資料的話,那麼就使用UNION ALL。

16、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

17、Oracle和Mysql的區別?

1)庫函式不同。 2)Oracle是用表空間來管理的,Mysql不是。 3)顯示當前所有的表、使用者、改變連線使用者、顯示當前連線使用者、執行外部指令碼的陳述句的不同。 4)分頁查詢時候時候,mysql用limit oracle用rownum

mysql> SELECT * FROM table LIMIT 5,10; // 檢索記錄行 6-15 

//為了檢索從某一個偏移量到記錄集的結束所有的記錄行,可以指定第二個引數為 -1: mysql> SELECT * FROM table LIMIT 95,-1; // 檢索記錄行 96-last. 

//如果只給定一個引數,它表示傳回最大的記錄行數目: mysql> SELECT * FROM table LIMIT 5; //檢索前 5 個記錄行 

//換句話說,LIMIT n 等價於 LIMIT 0,n。 5)sql的語法的不同。


●編號424,輸入編號直達本文

●輸入m獲取文章目錄

推薦↓↓↓

 

Web開發

更多推薦18個技術類微信公眾號

涵蓋:程式人生、演演算法與資料結構、駭客技術與網路安全、大資料技術、前端開發、Java、Python、Web開發、安卓開發、iOS開發、C/C++、.NET、Linux、資料庫、運維等。

贊(0)

分享創造快樂