drop、truncate、 delete區別
TRUNCATE TABLE 在功能上與不帶 WHERE 子句的 DELETE 語句相同:二者均刪除表中的全部行。但 TRUNCATE TABLE 比 DELETE 速度快,且使用的系統和事務日志資源少。
數據庫三范式是什么?
第一范式(1NF):字段具有原子性,不可再分。所有關系型數據庫系統都滿足第一范式。
數據庫表中的字段都是單一屬性的,不可再分。例如,姓名字段,其中的姓和名必須作為一個整體,無法區分哪部分是姓,哪部分是名,如果要區分出姓和名,必須設計成兩個獨立的字段。
第二范式(2NF):是在第一范式(1NF)的基礎上建立起來的,即滿足第二范式(2NF)必須先滿足第一范式(1NF)。
要求數據庫表中的每個實例或行必須可以被惟一地區分。通常需要為表加上一個列,以存儲各個實例的惟一標識。這個惟一屬性列被稱為主關鍵字或主鍵。
第二范式(2NF)要求實體的屬性完全依賴於主關鍵字。所謂完全依賴是指不能存在僅依賴主關鍵字一部分的屬性,如果存在,那么這個屬性和主關鍵字的這一部分應該分離出來形成一個新的實體,新實體與原實體之間是一對多的關系。為實現區分通常需要為表加上一個列,以存儲各個實例的惟一標識。簡而言之,第二范式就是非主屬性非部分依賴於主關鍵字。
第三范式(3NF):必須先滿足第二范式(2NF)。簡而言之,第三范式(3NF)要求一個數據庫表中不包含已在其它表中已包含的非主關鍵字信息。
所以第三范式具有如下特征:
1,每一列只有一個值
2,每一行都能區分。
3,每一個表都不包含其他表已經包含的非主關鍵字信息。
例如,帖子表中只能出現發帖人的id,而不能出現發帖人的id,還同時出現發帖人姓名,否則,只要出現同一發帖人id的所有記錄,它們中的姓名部分都必須嚴格保持一致,這就是數據冗余。
union和union all有什么不同?
UNION在進行表鏈接后會篩選掉重復的記錄,所以在表鏈接后會對所產生的結果集進行排序運算,刪除重復的記錄再返回結果。實際大部分應用中是不會產生重復的記錄,最常見的是過程表與歷史表UNION。
UNION ALL只是簡單的將兩個結果合並后就返回。這樣,如果返回的兩個結果集中有重復的數據,那么返回的結果集就會包含重復的數據了。
從效率上說,UNION ALL 要比UNION快很多,所以,如果可以確認合並的兩個結果集中不包含重復的數據的話,那么就使用UNION ALL。
char、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
合並查詢有哪些?
union(並集去重復)、
union all(並集不去重復)、
intersect(交集)、
minus(差集)
SQL語句執行順序
關鍵字:select、from、join、on、where、group by、having、order by、distinct執行順序
1、from
2、join
3、on
4、where
5、group by 分組字段
6、having 表達式
7、select
8、distinct
9、order by
null的含義
在我們不知道具體有什么數據的時候,也即未知,可以用NULL,我們稱它為空,ORACLE中,含有空值的表列長度為零。
ORACLE允許任何一種數據類型的字段為空,除了以下兩種情況:
1、主鍵字段(primary key),
2、定義時已經加了NOT NULL限制條件的字段
說明:
1、等價於沒有任何值、是未知數。
2、NULL與0、空字符串、空格都不同。
3、對空值做加、減、乘、除等運算操作,結果仍為空。
4、NULL的處理使用NVL函數。
5、比較時使用關鍵字用“is null”和“is not null”。
6、空值不能被索引,所以查詢時有些符合條件的數據可能查不出來,count(*)中,用nvl(列名,0)處理后再查。
7、排序時比其他數據都大(索引默認是降序排列,小→大),所以NULL值總是排在最后。
MySQL、SqlServer、oracle寫出字符存儲、字符串轉時間
1、在MySQL、SqlServer、oracle中兩個單引號代表字符
2、字符串轉時間
Oracle:使用to_date(‘字符串時間’, 'yyyy-MM-dd HH24:mi:ss')函數
SqlServer:CONVERT(數據類型,日期值,日期樣式ID)
MySQL:date_format(日期值,'%Y-%c-%d %h:%i:%s');
update語句可以修改結果集中的數據嗎?
在oracle中是可以的,在mysql中不可以。
如下語句:
update (select * from table1 t1 left join table2 t2 on t1.字段 = t2.字段 ) set 字段名 = 值 where 條件字段 = 條件值
B樹和B+樹的區別
- B樹,每個節點都存儲key和data,所有節點組成這棵樹,並且葉子節點指針為nul,葉子結點不包含任何關鍵字信息。
- B+樹,所有的葉子結點中包含了全部關鍵字的信息,及指向含有這些關鍵字記錄的指針,且葉子結點本身依關鍵字的大小自小而大的順序鏈接,所有的非終端結點可以看成是索引部分,結點中僅含有其子樹根結點中最大(或最小)關鍵字。 (而B 樹的非終節點也包含需要查找的有效信息)
為什么說B+比B樹更適合實際應用中操作系統的文件索引和數據庫索引?
- B+的磁盤讀寫代價更低 B+的內部結點並沒有指向關鍵字具體信息的指針。因此其內部結點相對B樹更小。如果把所有同一內部結點的關鍵字存放在同一盤塊中,那么盤塊所能容納的關鍵字數量也越多。一次性讀入內存中的需要查找的關鍵字也就越多。相對來說IO讀寫次數也就降低了。
- B+-tree的查詢效率更加穩定 由於非終結點並不是最終指向文件內容的結點,而只是葉子結點中關鍵字的索引。所以任何關鍵字的查找必須走一條從根結點到葉子結點的路。所有關鍵字查詢的路徑長度相同,導致每一個數據的查詢效率相當。
未作答案
- 你建過索引嗎? 建索引的原則
- 索引的類型, 如主鍵索引
- 查看SQL執行計划
- 有十萬條數據, 寫SQL語句查詢其中某字段較大值的幾條數據
- 子查詢與關聯查詢的區別
- MySQL InnoDB、Mysaim的特點?
- 樂觀鎖和悲觀鎖的區別??
- 行鎖和表鎖的區別?
- 數據庫隔離級別是什么?有什么作用?
- MySQL主備同步的基本原理。
- 如何優化數據庫性能(索引、分庫分表、批量操作、分頁算法、升級硬盤SSD、業務優化、主從部署)
- SQL什么情況下不會使用索引(不包含,不等於,函數)
- 一般在什么字段上建索引(過濾數據最多的字段)
- MySQL,B+索引實現,行鎖實現,SQL優化
- 如何解決高並發減庫存問題
- 數據庫事務的幾種粒度
數據庫 題目:
- 事務四大特性(ACID)
- 數據庫隔離級別,每個級別會引發什么問題,mysql默認是哪個級別
- MYSQL的兩種存儲引擎區別(事務、鎖級別等等),各自的適用場景
- 數據庫的優化(從sql語句優化和索引兩個部分回答)
- 索引有B+索引和hash索引,各自的區別
- B+索引數據結構,和B樹的區別
- 索引的分類(主鍵索引、唯一索引),最左前綴原則,哪些情況索引會失效
- 聚集索引和非聚集索引區別。
- 有哪些鎖(樂觀鎖悲觀鎖),select時怎么加排它鎖
- 關系型數據庫和非關系型數據庫區別
- MVCC機制
數據庫實戰
- 數據庫三范式,根據秒殺場景設計數據表
- 數據庫的主從復制
- 死鎖怎么解決
- mysql並發情況下怎么解決(通過事務、隔離級別、鎖)
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
21、order by與group by的區別
order by 排序查詢、asc升序、desc降序 group by 分組查詢、having 只能用於group by子句、作用於組內,having條件子句可以直接跟函數表達式。使用group by 子句的查詢語句需要使用聚合函數。