日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

oracle 合并重复数据_三天三夜整理出来的数据库常见的面试题,让你直接拿走...

發(fā)布時間:2024/4/19 数据库 42 豆豆
生活随笔 收集整理的這篇文章主要介紹了 oracle 合并重复数据_三天三夜整理出来的数据库常见的面试题,让你直接拿走... 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

1、觸發(fā)器的作用?

觸發(fā)器是一中特殊的存儲過程,主要是通過事件來觸發(fā)而被執(zhí)行的。它可以強(qiáng)化約束,來維護(hù)數(shù)據(jù)的完整性和一致性,可以跟蹤數(shù)據(jù)庫內(nèi)的操作從而不允許未經(jīng)許可的更新和變化。可以聯(lián)級運(yùn)算。如,某表上的觸發(fā)器上包含對另一個表的數(shù)據(jù)操作,而該操作又會導(dǎo)致該表觸發(fā)器被觸發(fā)。

2、什么是存儲過程?用什么來調(diào)用?

存儲過程是一個預(yù)編譯的SQL語句,優(yōu)點(diǎn)是允許模塊化的設(shè)計,就是說只需創(chuàng)建一次,以后在該程序中就可以調(diào)用多次。如果某次操作需要執(zhí)行多次SQL,使用存儲過程比單純SQL語句執(zhí)行要快。 調(diào)用: 1)可以用一個命令對象來調(diào)用存儲過程。 2)可以供外部程序調(diào)用,比如:java程序。

3、存儲過程的優(yōu)缺點(diǎn)?

優(yōu)點(diǎn): 1)存儲過程是預(yù)編譯過的,執(zhí)行效率高。 2)存儲過程的代碼直接存放于數(shù)據(jù)庫中,通過存儲過程名直接調(diào)用,減少網(wǎng)絡(luò)通訊。 3)安全性高,執(zhí)行存儲過程需要有一定權(quán)限的用戶。 4)存儲過程可以重復(fù)使用,可減少數(shù)據(jù)庫開發(fā)人員的工作量。 缺點(diǎn):移植性差

4、存儲過程與函數(shù)的區(qū)別

存儲過程

1、用于在數(shù)據(jù)庫中完成特定的操作或者任務(wù)(如插入、刪除等)

2、程序頭部聲明用procedure

3、程序頭部聲明時不需描述返回類型可以使用in/out/in out 三種模式的參數(shù)

4、可作為一個獨(dú)立的PL/SQL語句來執(zhí)行

5、可以通過out/in out 返回零個或多個值

6、SQL語句(DML 或SELECT)中不可調(diào)用存儲過程

函數(shù)

1、用于特定的數(shù)據(jù)(如選擇)

2、程序頭部聲明用function

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

4、可以使用in/out/in out 三種模式的參數(shù)

5、不能獨(dú)立執(zhí)行,必須作為表達(dá)式的一部分調(diào)用

6、通過return語句返回一個值,且改值要與聲明部分一致,也可以是通過out類型的參數(shù)帶出的變量

7、SQL語句(DML 或SELECT)中可以調(diào)用函數(shù)

5、索引的作用?和它的優(yōu)點(diǎn)缺點(diǎn)是什么?

索引就一種特殊的查詢表,數(shù)據(jù)庫的搜索可以利用它加速對數(shù)據(jù)的檢索。它很類似與現(xiàn)實(shí)生活中書的目錄,不需要查詢整本書內(nèi)容就可以找到想要的數(shù)據(jù)。索引可以是唯一的,創(chuàng)建索引允許指定單個列或者是多個列。缺點(diǎn)是它減慢了數(shù)據(jù)錄入的速度,同時也增加了數(shù)據(jù)庫的尺寸大小。

6、什么樣的字段適合建索引

唯一、不為空、經(jīng)常被查詢的字段

7、索引類型有哪些?

邏輯上:

Single column 單行索引

Concatenated 多行索引

Unique 唯一索引

NonUnique 非唯一索引

Function-based 函數(shù)索引

Domain 域索引 物理上:

Partitioned 分區(qū)索引

NonPartitioned 非分區(qū)索引

B-tree :

Normal 正常型B樹

Rever Key 反轉(zhuǎn)型B樹 Bitmap 位圖索引

8、什么是事務(wù)?什么是鎖?

事務(wù)就是被綁定在一起作為一個邏輯工作單元的SQL語句分組,如果任何一個語句操作失敗那么整個操作就被失敗,以后操作就會回滾到操作前狀態(tài),或者是上有個節(jié)點(diǎn)。為了確保要么執(zhí)行,要么不執(zhí)行,就可以使用事務(wù)。要將有組語句作為事務(wù)考慮,就需要通過ACID測試,即原子性,一致性,隔離性和持久性。 鎖:在所以的DBMS中,鎖是實(shí)現(xiàn)事務(wù)的關(guān)鍵,鎖可以保證事務(wù)的完整性和并發(fā)性。與現(xiàn)實(shí)生活中鎖一樣,它可以使某些數(shù)據(jù)的擁有者,在某段時間內(nèi)不能使用某些數(shù)據(jù)或數(shù)據(jù)結(jié)構(gòu)。當(dāng)然鎖還分級別的。

9、什么叫視圖?游標(biāo)是什么?

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

10、視圖的優(yōu)缺點(diǎn)

優(yōu)點(diǎn): 1)對數(shù)據(jù)庫的訪問,因?yàn)橐晥D可以有選擇性的選取數(shù)據(jù)庫里的一部分。 2 )用戶通過簡單的查詢可以從復(fù)雜查詢中得到結(jié)果。 3 )維護(hù)數(shù)據(jù)的獨(dú)立性,試圖可從多個表檢索數(shù)據(jù)。 4 )對于相同的數(shù)據(jù)可產(chǎn)生不同的視圖。 缺點(diǎn): 性能:查詢視圖時,必須把視圖的查詢轉(zhuǎn)化成對基本表的查詢,如果這個視圖是由一個復(fù)雜的多表查詢所定義,那么,那么就無法更改數(shù)據(jù)

11、列舉幾種表連接方式,有什么區(qū)別?

內(nèi)連接、自連接、外連接(左、右、全)、交叉連接 內(nèi)連接:只有兩個元素表相匹配的才能在結(jié)果集中顯示。 外連接: 左外連接:左邊為驅(qū)動表,驅(qū)動表的數(shù)據(jù)全部顯示,匹配表的不匹配的不會顯示。 右外連接:右邊為驅(qū)動表,驅(qū)動表的數(shù)據(jù)全部顯示,匹配表的不匹配的不會顯示。 全外連接:連接的表中不匹配的數(shù)據(jù)全部會顯示出來。 交叉連接: 笛卡爾效應(yīng),顯示的結(jié)果是鏈接表數(shù)的乘積。

12、主鍵和外鍵的區(qū)別?

主鍵在本表中是唯一的、不可唯空的,外鍵可以重復(fù)可以唯空;外鍵和另一張表的主鍵關(guān)聯(lián),不能創(chuàng)建對應(yīng)表中不存在的外鍵。

13、在數(shù)據(jù)庫中查詢語句速度很慢,如何優(yōu)化?

1.建索引 2.減少表之間的關(guān)聯(lián) 3.優(yōu)化sql,盡量讓sql很快定位數(shù)據(jù),不要讓sql做全表查詢,應(yīng)該走索引,把數(shù)據(jù) 量大的表排在前面 4.簡化查詢字段,沒用的字段不要,已經(jīng)對返回結(jié)果的控制,盡量返回少量數(shù)據(jù) 5.盡量用PreparedStatement來查詢,不要用Statement

14、數(shù)據(jù)庫三范式是什么?

第一范式:列不可再分 第二范式:行可以唯一區(qū)分,主鍵約束 第三范式:表的非主屬性不能依賴與其他表的非主屬性 外鍵約束 且三大范式是一級一級依賴的,第二范式建立在第一范式上,第三范式建立第一第二范式上

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

UNION在進(jìn)行表鏈接后會篩選掉重復(fù)的記錄,所以在表鏈接后會對所產(chǎn)生的結(jié)果集進(jìn)行排序運(yùn)算,刪除重復(fù)的記錄再返回結(jié)果。實(shí)際大部分應(yīng)用中是不會產(chǎn)生重復(fù)的記錄,最常見的是過程表與歷史表UNION。 UNION ALL只是簡單的將兩個結(jié)果合并后就返回。這樣,如果返回的兩個結(jié)果集中有重復(fù)的數(shù)據(jù),那么返回的結(jié)果集就會包含重復(fù)的數(shù)據(jù)了。 從效率上說,UNION ALL 要比UNION快很多,所以,如果可以確認(rèn)合并的兩個結(jié)果集中不包含重復(fù)的數(shù)據(jù)的話,那么就使用UNION ALL。

16、Varchar2和varchar有什么區(qū)別?

Char的長度是固定的,而varchar2的長度是可以變化的,比如,存儲字符串“abc”對于char(20),表示你存儲的字符將占20個字節(jié),包含17個空,而同樣的varchar2(20)只占了3個字節(jié),20只是最大值,當(dāng)你存儲的字符小于20時,按實(shí)際長度存儲。 char的效率要被varchar2的效率高。 目前varchar是varchar2的同義詞,工業(yè)標(biāo)準(zhǔn)的varchar類型可以存儲空字符串,但是oracle不能這樣做,盡管它保留以后這樣做的權(quán)利。Oracle自己開發(fā)了一個數(shù)據(jù)類型varchar2,這個類型不是一個標(biāo)準(zhǔn)的varchar,他將在數(shù)據(jù)庫中varchar列可以存儲空字符串的特性改為存儲null值,如果你想有向后兼容的能力,oracle建議使用varchar2而不是varchar

17、Oracle和Mysql的區(qū)別?

1)庫函數(shù)不同。 2)Oracle是用表空間來管理的,Mysql不是。 3)顯示當(dāng)前所有的表、用戶、改變連接用戶、顯示當(dāng)前連接用戶、執(zhí)行外部腳本的語句的不同。 4)分頁查詢時候時候,mysql用limit oracle用rownum

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

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

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

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

由于文章篇幅原因只寫了一部分,本人這邊專門整理了一套對應(yīng)的Java面經(jīng)pdf文檔復(fù)習(xí)資料,含全面的數(shù)據(jù)庫面試題,還有其他各類知識點(diǎn)的整理,特別適合一些即將面試或準(zhǔn)備跳槽的Java開發(fā)者查缺補(bǔ)漏,需要獲取這套文檔資料的讀者朋友們可以關(guān)注小編,后臺私信關(guān)鍵字“面試資料”獲取這套Java面經(jīng)pdf文檔資料。

覺得此文不錯的大佬們可以幫忙轉(zhuǎn)發(fā)分享一下,希望能幫助到更多正在為面試做準(zhǔn)備的碼友們,感謝!!!!

總結(jié)

以上是生活随笔為你收集整理的oracle 合并重复数据_三天三夜整理出来的数据库常见的面试题,让你直接拿走...的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。