数据库面试知识点汇总
主鍵:數(shù)據(jù)庫表中唯一標識;一個數(shù)據(jù)列只能有一個主鍵,且主鍵的取值不能缺失,即不能為空值(Null)。
外鍵:在一個表中存在的另一個表的主鍵稱此表的外鍵。
觸發(fā)器的作用?
觸發(fā)器是一種特殊的存儲過程,主要是通過事件來觸發(fā)而被執(zhí)行的。它可以強化約束,來維護數(shù)據(jù)的完整性和一致性,可以跟蹤數(shù)據(jù)庫內(nèi)的操作從而不允許未經(jīng)許可的更新和變化??梢月?lián)級運算。如,某表上的觸發(fā)器上包含對另一個表的數(shù)據(jù)操作,而該操作又會導致該表觸發(fā)器被觸發(fā)。
什么是存儲過程?用什么來調(diào)用?
存儲過程是一個預編譯的SQL語句,優(yōu)點是允許模塊化的設(shè)計,就是說只需創(chuàng)建一次,以后在該程序中就可以調(diào)用多次。如果某次操作需要執(zhí)行多次SQL,使用存儲過程比單純SQL語句執(zhí)行要快。
調(diào)用:
1)可以用一個命令對象來調(diào)用存儲過程。
2)可以供外部程序調(diào)用,比如:java程序。
存儲過程的優(yōu)缺點?
優(yōu)點:
1)存儲過程是預編譯過的,執(zhí)行效率高。
2)存儲過程的代碼直接存放于數(shù)據(jù)庫中,通過存儲過程名直接調(diào)用,減少網(wǎng)絡(luò)通訊。
3)安全性高,執(zhí)行存儲過程需要有一定權(quán)限的用戶。
4)存儲過程可以重復使用,可減少數(shù)據(jù)庫開發(fā)人員的工作量。
缺點:移植性差
視圖:
是一種虛擬的表,具有和物理表相同的功能。可以對視圖進行增,改,查,操作
游標:
是對查詢出來的結(jié)果集作為一個單元來有效的處理。游標可以定在該單元中的特定行,從結(jié)果集的當前行檢索一行或多行??梢詫Y(jié)果集當前行做修改
視圖的優(yōu)缺點
優(yōu)點:
1對數(shù)據(jù)庫的訪問,因為視圖可以有選擇性的選取數(shù)據(jù)庫里的一部分。
2)用戶通過簡單的查詢可以從復雜查詢中得到結(jié)果。
3)維護數(shù)據(jù)的獨立性,試圖可從多個表檢索數(shù)據(jù)。
4)對于相同的數(shù)據(jù)可產(chǎn)生不同的視圖。
缺點:
性能:查詢視圖時,必須把視圖的查詢轉(zhuǎn)化成對基本表的查詢,如果這個視圖是由一個復雜的多表查詢所定義,那么,那么就無法更改數(shù)據(jù)
drop、truncate、 delete區(qū)別
最基本:
- drop直接刪掉表。
- truncate刪除表中數(shù)據(jù),再插入時自增長id又從1開始。
- delete刪除表中數(shù)據(jù),可以加where字句。
- 什么是臨時表,臨時表什么時候刪除?
- 臨時表可以手動刪除:
- 臨時表只在當前連接可見,當關(guān)閉連接時,MySQL會自動刪除表并釋放所有空間。因此在不同的連接中可以創(chuàng)建同名的臨時表,并且操作屬于本連接的臨時表。
轉(zhuǎn)載于:https://www.cnblogs.com/jimsu/p/11185216.html
總結(jié)
以上是生活随笔為你收集整理的数据库面试知识点汇总的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: GINA后门代码
- 下一篇: 数据库中范式的理解1NF、2NF、3NF