1.觸發器的作用:
觸發器是一種特殊的存儲過程,主要是通過事件來觸發而被執行的
可以強化約束,來維護數據的完整性和一致性,可以跟蹤數據內的操作從而不允許未經許可的更新和變化,
可以級聯運算。
如:某表上的觸發器上包含對另一個表的數據操作,而該操作會導致該表觸發器被觸發
2.什么是存儲過程,用什么來調用
存儲過程是一個預編譯的sql語句,優點是允許模塊化的設計,就是說只需創建一次,
以后在該程序中就可以調用多次,
如果某次操作需要執行多次sql,使用存儲過程比單純sql語句執行要快
調用:
可以用一個命令對象來調用存儲過程
可以供外部程序調用,如java程序
3.存儲過程的優缺點
優點:
-存儲過程是預編譯過的,執行效率高
-存儲過程的代碼直接存放在數據庫中,通過存儲過程名直接調用,減少網絡通訊
-安全性高,執行存儲過程需要有一定權限的用戶
-存儲過程可以重復使用,可減少數據庫開發人員的工作量
缺點:
可移植性差
4.什么是視圖,與游標的區別是什么
視圖:是一種虛擬的表,具有和物理表相同的功能
游標:
是對查詢出來的結果集作為一個單元來進行有效的處理,游標可以定在該單元中的特定行,從結果集的當前行檢索一行或多行,
可以對結果集當前行進行修改。
游標一般不使用,一般用於需要逐條處理數據的時候
視圖的優點:
-視圖可以有選擇的選取數據庫里的一部分
-用戶通過簡單的查詢可以從復雜查詢中得到結果
-維護數據的獨立性,視圖可以從多個表檢索數據
-對於相同的數據可以產生不認同的視圖
缺點:
查詢視圖時,必須把視圖的查詢結果轉化為對基本表的查詢,
如果這個視圖是由一個復雜的多表查詢所定義,那么就無法改變數據
5.drop ,truncate ,delete 區別
-delete語句執行刪除的過程時每次從表中刪除一行,並且同時將該行的刪除操作作為事務記錄在日志中保存
以便進行回滾操作。 truncate 則一次型從表中刪除所有數據,無法恢復,並且在刪除過程中不會激活刪除觸發器
執行速度快
-表和索引所占空間 當表被truncate后,這個表和索引所占的空間會恢復到初始大小,而delete操作不會減少表或索引所占的空間,drop則釋放表所占空間
-truncate 與delete只刪除數據,drop將刪除表的結構,約束,觸發器,索引,保留該表的存儲過程/函數,變為invalid狀態
-delete為DML,truncate與drop為DLL
-truncate通過釋放存儲表數據所用的數據頁來刪除數據,在事務日志中記錄頁的釋放
delete語句每一次刪除一行,在事務日記中記錄刪除一行
6.數據庫范式,以及根據某個場景設計數據表
第一范式:確保每列保持原子性
是最基本的范式,數據庫表中的所有字段都應滿足第一范式
第二范式:確保表中每列都和主鍵相關
一張表只能保存一種數據,比如將訂單編號和商品編號作為數據庫表的聯合主鍵
第三范式:確保每列都和主鍵列直接相關,而不是間接相關
7.什么是內連接,外連接,交叉連接,笛卡爾積?
內連接:兩個表的交集
左連接:左邊表的所有行,以及匹配到的右邊表的行,未匹配到的用null補滿
交叉連接:生成笛卡爾積,它不使用任何匹配或者選取條件,而是直接將一個數據源中的每個行和另一個數據源的每個行一一匹配