這是幾道數據庫的概念性面試題,有的面試題在之前收錄的面試題里面已經出現過了,不過還是要拿來強化一下概念:
1、觸發器的作用?
答:觸發器是一種特殊的存儲過程,它主要是通過事件來觸發而被執行的。它的作用是可以強化約束,維護數據的完整性和一致性,也可以可以跟蹤數據庫內的操作從而不允許未經許可的更新和變化。也可以聯級運算。如某表上的觸發器上包含對另一個表的數據操作,而該操作又會導致該表觸發器被觸發。
2、什么是存儲過程?如何來調用存儲過程?
答:存儲過程是一個預編譯的SQL語句,他的優點是允許模塊化的設計,也就是說只需創建一次,在該程序中就可以調用多次。例如某次操作需要執行多次SQL,就可以把這個SQL做一個存儲過程,因為存儲過程是預編譯的,所以使用存儲過程比單純SQL語句執行要快。可以用一個命令對象來調用存儲過程。
3、什么是內存泄漏?
答:一般我們所說的內存泄漏指的是堆內存的泄漏。堆內存是程序從堆中為其分配的,大小任意的,使用完后要顯示釋放內存。當應用程序用關鍵字new等創建對象時,就從堆中為它分配一塊內存,使用完后程序調用free或者delete釋放該內存,否則就說該內存就不能被使用,我們就說該內存被泄漏了。
4、什么是事務?
答:事務就是被綁定在一起作為一個邏輯工作單元的SQL語句分組,如果任何一個語句操作失敗那么整個操作就被失敗,以后操作就會回滾到操作前狀態,或者是上有個節點。為了確保要么執行,要么不執行,就可以使用事務。事務有四個特性,分別是:原子性,一致性,隔離性和持久性。
5、索引的作用?和它的優點缺點是什么?
答:索引就一種特殊的查詢表,數據庫的搜索引擎可以利用它加速對數據的檢索。索引很類似與現實生活中書的目錄,不需要查詢整本書內容就可以找到想要的數據。索引可以是唯一的,創建索引允許指定單個列或者是多個列。缺點是它減慢了數據錄入的速度,同時也增加了數據庫的尺寸大小。
6、什么是鎖?
答:鎖是實現事務的關鍵,鎖可以保證事務的完整性和并發性。與現實生活中鎖一樣,它可以使某些數據的擁有者,在某段時間內不能使用某些數據或數據結構。當然鎖還分級別的。
7、維護數據庫的完整性和一致性,你喜歡用觸發器還是自寫業務邏輯?為什么?
答:盡可能使用約束,如check、主鍵、外鍵、非空字段等來約束。這樣做效率最高,也最方便。其次是使用觸發器,這種方法可以保證,無論什么業務系統訪問數據庫都可以保證數據的完整新和一致性。最后考慮的是自寫業務邏輯,但這樣做麻煩,編程復雜,效率低下。
以上的答案不是很嚴謹,但是有利于理解,大家可以參考其他數據庫的資料進行記憶。