34個數據庫常見面試題講解

1、觸發器的作用?

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

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

存儲過程是一個預編譯的SQL語句,優點是允許模塊化的設計,就是說只需創建一次,以後在該程序中就可以調用多次。如果某次操作需要執行多次SQL,使用存儲過程比單純SQL語句執行要快。 調用: 1)可以用一個命令對象來調用存儲過程。 2)可以供外部程序調用,比如:java程序。

3、存儲過程的優缺點?

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

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

存儲過程函數
用於在數據庫中完成特定的操作或者任務(如插入、刪除等)用於特定的數據(如選擇)
程序頭部聲明用procedure程序頭部聲明用function
程序頭部聲明時不需描述返回類型程序頭部聲明時要描述返回類型,而且PL/SQL塊中至少要包括一個有效的return語句
可以使用in/out/in out 三種模式的參數可以使用in/out/in out 三種模式的參數
可作爲一個獨立的PL/SQL語句來執行不能獨立執行,必須作爲表達式的一部分調用
可以通過out/in out 返回零個或多個值通過return語句返回一個值,且改值要與聲明部分一致,也可以是通過out類型的參數帶出的變量
SQL語句(DML 或SELECT)中不可調用存儲過程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
  1. mysql> SELECT * FROM table LIMIT 5,10; // 檢索記錄行 6-15 //爲了檢索從某一個偏移量到記錄集的結束所有的記錄行,可以指定第二個參數爲 -1: mysql> SELECT * FROM tableLIMIT 95,-1; // 檢索記錄行 96-last. //如果只給定一個參數,它表示返回最大的記錄行數目: mysql> SELECT * FROM table LIMIT 5; //檢索前 5 個記錄行 //換句話說,LIMIT n 等價於 LIMIT 0,n。 5)sql的語法的不同。

    18、Oracle語句有多少類型

    Oracle語句分三類:DDL、DML、DCL。 DDL(Data Definition Language)數據定義語言,包括: Create語句:可以創建數據庫和數據庫的一些對象。 Drop語句:可以刪除數據表、索引、觸發程序、條件約束以及數據表的權限等。 Alter語句:修改數據表定義及屬性。 Truncate語句:刪除表中的所有記錄,包括所有空間分配的記錄被刪除。 DML(Data Manipulation Language)數據操控語言,包括: Insert語句:向數據表張插入一條記錄。 Delete語句:刪除數據表中的一條或多條記錄,也可以刪除數據表中的所有記錄,但是它的操作對象仍是記錄。 Update語句:用於修改已存在表中的記錄的內容。 DCL(Data Control Language)數據庫控制語言,包括: Grant語句:允許對象的創建者給某用戶或某組或所有用戶(PUBLIC)某些特定的權限。 Revoke語句:可以廢除某用戶或某組或所有用戶訪問權限

    19、oracle分頁查詢語句

    使用rownum,兩種如下: 第一種: select * from (select t.*,rownum row_num from mytable t) b where b.row_num between 1 and 10 第二種: select * from ( select a.*, rownum rn from mytable a where rownum <= 10 ) where rn >= 1 使用rowid, 如下: select * from scott.emp where rowid in (select rd from (select rowid as rd ,rownum as rn from scott.emp ) where rn<=6 and rn>3)

    20、從數據庫中隨機取50條

    select * from (select * from t_example order by dbms_random.random) where rownum <= 50

    21、order by與group by的區別

    order by 排序查詢、asc升序、desc降序 group by 分組查詢、having 只能用於group by子句、作用於組內,having條件子句可以直接跟函數表達式。使用group by 子句的查詢語句需要使用聚合函數。

    22、commit在哪裏會運用

    oracle的commit就是DML語句提交數據(這裏是釋放鎖不是鎖表),在未提交前你前面的操作更新的都是內存,沒有更新到物理文件中。 執行commit從用戶角度講就是更新到物理文件了,事實上commit時還沒有寫date file,而是記錄了redo log file,要從內存寫到data物理文件,需要觸發檢查點,由DBWR這個後臺進程來寫,這裏內容有點多的,如果不深究的話你就理解成commit即爲從內存更新到物理文件。

    23、行轉列、列換行怎麼轉

    1)使用decode函數 2)使用case when語句

    24、什麼是PL/SQL?

    PL/SQL是一種程序語言,叫做過程化SQL語言(Procedural Language/SQL)。PL/SQL是Oracle數據庫對SQL語句的擴展。在普通SQL語句的使用上增加了編程語言的特點,所以PL/SQL把數據操作和查詢語句組織在PL/SQL代碼的過程性單元中,通過邏輯判斷、循環等操作實現複雜的功能或者計算。PL/SQL 只有 Oracle 數據庫有。 MySQL 目前不支持 PL/SQL 的。

    25、序列的作用

    Oracle使用序列來生成唯一編號,用來處理一個表中自增字段。 Oracle序列是原子對象,並且是一致的。也就是說,一旦您訪問一個序列號,Oracle將在處理下一個請求之前自動遞增下一個編號,從而確保不會出現重複值。

    26、表和視圖的關係

    視圖其實就是一條查詢sql語句,用於顯示一個或多個表或其他視圖中的相關數據。 表就是關係數據庫中實際存儲數據用的。

    27、oracle基本數據類型

    1)字符串類型 char、nchar、varchar、varchar2、nvarchar2 2)數字類型 number、integer 3)浮點類型 binary_float、binary_double、float 4)日期類型 date、 timestamp 5)LOB類型 blob、clob、nclob、bfile

    28、truncate與 delete區別

    TRUNCATE TABLE 在功能上與不帶 WHERE 子句的 DELETE 語句相同:二者均刪除表中的全部行。但 TRUNCATE TABLE 比 DELETE 速度快,且使用的系統和事務日誌資源少。 DELETE 語句每次刪除一行,並在事務日誌中爲所刪除的每行記錄一項。
    TRUNCATE TABLE 通過釋放存儲表數據所用的數據頁來刪除數據,並且只在事務日誌中記錄頁的釋放。 TRUNCATE,DELETE,DROP 放在一起比較:
    TRUNCATE TABLE :刪除內容、釋放空間但不刪除定義。
    DELETE TABLE: 刪除內容不刪除定義,不釋放空間。
    DROP TABLE :刪除內容和定義,釋放空間。

    29、oracle獲取系統時間

    select to_char(sysdate, 'yyyy-MM-dd HH24:mi:ss') from dual;

    30、oracle怎麼去除去重

    使用distinct關鍵字

    31、現在有表:

    A(id ,name,regdate) B(id,groupid) C(id,name2) 寫出下面的SQL語句 A)統計A表中每個月註冊用戶數 select count(*),to_char(regdate,'yyyymm') from A group by to_char(regdate,'yyyymm'); B)統計A表中有姓名相同的用戶數 select count(*) from (select name from A group by name having count(*) >1); C)如果表A中有姓名相同的用戶,把相同的查出,寫入表C中 nsert into C(name2) select name from A group by name having count(*) >1; D)A中ID有多個相同的數據,A中姓名相同的ID只保留註冊時間最大的數據 delete from E where e.regdate < (select max(regdate) from a X where E.id = X.id);

    32、現有表:

    Student(S#,SN,SD)學生表 Course(C#,CN,T#)課程表 SC(S#,C#,score)成績表 1.查詢選了課程‘稅收’的學生的學號和名字 答: select SN,SD from Student where S# in( select S# from Course C , SC where C.C#=SC.C# and CN= ’稅收基礎’); 2.查詢選課數量大於5的學生的學號和名字 答: select SN,SD from Student where S# in ( select S# from SC group by S# having count(distinct C#) > 5); ) 3.建立一個學生表students,包括name,age,head_teacher,id,score(姓名,年齡,班主任,學號,成績) Create table students ( Id number(9) not null primary key, Name varchar2(40) not null, Age int check(age between 0 and 100), Head_teacher vachar2(40), Score float ); 4.對上表插入一條記錄,姓名:張三,年齡:18,班主任:李四,學號:22 Insert into student(id,name,age,head_teacher) values(‘22’,’張三’,’18’,’李四’); 5.對上表中的age+name創建一個索引,並說明它的作用和使用方法 Create index student_index on students(age,name);

    33、怎樣把這樣一個表(表名:tmp_table_201307)

    year month amount 2012 1 1.1 2012 2 1.2 2012 3 1.3 2012 4 1.4 2012 4 1.6 2013 1 2.1 2013 2 2.2 2013 2 2.2 2013 3 2.3  2013 4 2.4   查成這樣一個結果   year m1 m2 m3 m4   2012 1.1 1.2 1.3 3   2013 2.1 4.4 2.3 2.4   Select   year,   Sum(case when month = 1 then amount else 0 end) as m1,   Sum(case when month = 2 then amount else 0 end) as m2,   Sum(case when month = 3 then amount else 0 end) as m3,   Sum(case when month = 4 then amount else 0 end) as m4   From tmp_table_201307 a   Group by year   Order by 1;

    34、數據庫中有一張表ismg_icp_flow,結構如下

    SQL> desc ismg_icp_flow Name Null Type ———————————————————————————————— ICPNO NOT NULL VARCHAR2(6) SERVICE_ID NOT NULL VARCHAR2(10) STAT_MIN NOT NULL DATETIME MT_RECV_OK NOT NULL NUMBER(10) 請寫出一條SQL語句同時滿足以下3個條件: 計算MT_RECV_OK的總和(顯示爲total),並以此對結果集進行升序排序 以ICPNO和SERVICE_ID兩個字段進行分組 所得出數據的STAT_MIN必須爲大於2003年1月1號0時0分並且小於2003 年2月1號0時0分 期望的輸出結果如下: ICPNO SERVICE_ID TOTAL ———— —————— ———————————— 901001 7700 271965 901001 7800 3857795 答: select ICPNO,SERVICE_ID,sum(MT_RECV_OK) TOTAL from ismg_icp_flow where STAT_MIN between to_date('2003-1-1','yyyy-mm-dd') and to_date('2003-2-1','yyyy-mm-dd') group by ICPNO,SERVICE_ID order by TOTAL;
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章