數據庫全部面試題,都給你收集好了!!!

一、觸發器的做用?

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

 

二、什麼是存儲過程?用什麼來調用?mysql

存儲過程是一個預編譯的SQL語句,優勢是容許模塊化的設計,就是說只需建立一次,之後在該程序中就能夠調用屢次。若是某次操做須要執行屢次SQL,使用存儲過程比單純SQL語句執行要快。 調用: 1)能夠用一個命令對象來調用存儲過程。 2)能夠供外部程序調用,好比:java程序。sql

 

三、存儲過程的優缺點?數據庫

優勢: 1)存儲過程是預編譯過的,執行效率高。 2)存儲過程的代碼直接存放於數據庫中,經過存儲過程名直接調用,減小網絡通信。 3)安全性高,執行存儲過程須要有必定權限的用戶。 4)存儲過程能夠重複使用,可減小數據庫開發人員的工做量。 缺點:移植性差安全

 

四、存儲過程與函數的區別網絡

存儲過程數據結構

一、用於在數據庫中完成特定的操做或者任務(如插入、刪除等)併發

二、程序頭部聲明用procedureoracle

三、程序頭部聲明時不需描述返回類型可使用in/out/in out 三種模式的參數模塊化

四、可做爲一個獨立的PL/SQL語句來執行

五、能夠經過out/in out 返回零個或多個值

六、SQL語句(DML 或SELECT)中不可調用存儲過程

 

函數

一、用於特定的數據(如選擇)

二、程序頭部聲明用function

三、程序頭部聲明時要描述返回類型,並且PL/SQL塊中至少要包括一個有效的return語句

四、可使用in/out/in out 三種模式的參數

五、不能獨立執行,必須做爲表達式的一部分調用

六、經過return語句返回一個值,且改值要與聲明部分一致,也能夠是經過out類型的參數帶出的變量

七、SQL語句(DML 或SELECT)中能夠調用函數

 

五、索引的做用?和它的優勢缺點是什麼?

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

 

六、什麼樣的字段適合建索引

惟1、不爲空、常常被查詢的字段

 

七、索引類型有哪些?

邏輯上:

Single column 單行索引

Concatenated 多行索引

Unique 惟一索引

NonUnique 非惟一索引

Function-based 函數索引

Domain 域索引 物理上:

Partitioned 分區索引

NonPartitioned 非分區索引

B-tree :

Normal 正常型B樹

Rever Key 反轉型B樹 Bitmap 位圖索引

 

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

事務就是被綁定在一塊兒做爲一個邏輯工做單元的SQL語句分組,若是任何一個語句操做失敗那麼整個操做就被失敗,之後操做就會回滾到操做前狀態,或者是上有個節點。爲了確保要麼執行,要麼不執行,就可使用事務。要將有組語句做爲事務考慮,就須要經過ACID測試,即原子性,一致性,隔離性和持久性。 鎖:在因此的DBMS中,鎖是實現事務的關鍵,鎖能夠保證事務的完整性和併發性。與現實生活中鎖同樣,它可使某些數據的擁有者,在某段時間內不能使用某些數據或數據結構。固然鎖還分級別的。

 

九、什麼叫視圖?遊標是什麼?

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

 

十、視圖的優缺點

優勢: 1)對數據庫的訪問,由於視圖能夠有選擇性的選取數據庫裏的一部分。 2 )用戶經過簡單的查詢能夠從複雜查詢中獲得結果。 3 )維護數據的獨立性,試圖可從多個表檢索數據。 4 )對於相同的數據可產生不一樣的視圖。 缺點: 性能:查詢視圖時,必須把視圖的查詢轉化成對基本表的查詢,若是這個視圖是由一個複雜的多表查詢所定義,那麼,那麼就沒法更改數據

 

十一、列舉幾種錶鏈接方式,有什麼區別?

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

 

十二、主鍵和外鍵的區別?

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

 

1三、在數據庫中查詢語句速度很慢,如何優化?

1.建索引 2.減小表之間的關聯 3.優化sql,儘可能讓sql很快定位數據,不要讓sql作全表查詢,應該走索引,把數據 量大的表排在前面 4.簡化查詢字段,沒用的字段不要,已經對返回結果的控制,儘可能返回少許數據 5.儘可能用PreparedStatement來查詢,不要用Statement

 

1四、數據庫三範式是什麼?

第一範式:列不可再分 第二範式:行能夠惟一區分,主鍵約束 第三範式:表的非主屬性不能依賴與其餘表的非主屬性 外鍵約束 且三大範式是一級一級依賴的,第二範式創建在第一範式上,第三範式創建第一第二範式上

 

1五、union和union all有什麼不一樣?

UNION在進行表連接後會篩選掉重複的記錄,因此在表連接後會對所產生的結果集進行排序運算,刪除重複的記錄再返回結果。實際大部分應用中是不會產生重複的記錄,最多見的是過程表與歷史表UNION。 UNION ALL只是簡單的將兩個結果合併後就返回。這樣,若是返回的兩個結果集中有重複的數據,那麼返回的結果集就會包含重複的數據了。 從效率上說,UNION ALL 要比UNION快不少,因此,若是能夠確認合併的兩個結果集中不包含重複的數據的話,那麼就使用UNION ALL。

 

1六、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

 

1七、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的語法的不一樣。

相關文章
相關標籤/搜索