如何學好java

          如何學好java,其實很簡單,只要用心體會,慢慢積累!
          posts - 106, comments - 7, trackbacks - 0, articles - 3
            BlogJava :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

          數據庫面試知識

          Posted on 2011-05-08 08:28 哈希 閱讀(228) 評論(0)  編輯  收藏 所屬分類: java面試題
          1.觸發器的作用?
           答:觸發器是一中特殊的存儲過程,主要是通過事件來觸發而被執行的。它可以強化約束,來維護數據的完整性和一致性,可以跟蹤數據庫內的操作從而不允許未經許可的更新和變化。可以聯級運算。如,某表上的觸發器上包含對另一個表的數據操作,而該操作又會導致該表觸發器被觸發。
          2。什么是存儲過程?用什么來調用?
          答:存儲過程是一個預編譯的SQL語句,優點是允許模塊化的設計,就是說只需創建一次,以后在該程序中就可以調用多次。如果某次操作需要執行多次SQL,使用存儲過程比單純SQL語句執行要快。可以用一個命令對象來調用存儲過程。
          3。索引的作用?和它的優點缺點是什么?
          答:索引就一種特殊的查詢表,數據庫的搜索引擎可以利用它加速對數據的檢索。它很類似與現實生活中書的目錄,不需要查詢整本書內容就可以找到想要的數據。索引可以是唯一的,創建索引允許指定單個列或者是多個列。缺點是它減慢了數據錄入的速度,同時也增加了數據庫的尺寸大小。
          3。什么是內存泄漏?
          答:一般我們所說的內存泄漏指的是堆內存的泄漏。堆內存是程序從堆中為其分配的,大小任意的,使用完后要顯示釋放內存。當應用程序用關鍵字new等創建對象時,就從堆中為它分配一塊內存,使用完后程序調用free或者delete釋放該內存,否則就說該內存就不能被使用,我們就說該內存被泄漏了。
          4。維護數據庫的完整性和一致性,你喜歡用觸發器還是自寫業務邏輯?為什么?
          答:我是這樣做的,盡可能使用約束,如check,主鍵,外鍵,非空字段等來約束,這樣做效率最高,也最方便。其次是使用觸發器,這種方法可以保證,無論什么業務系統訪問數據庫都可以保證數據的完整新和一致性。最后考慮的是自寫業務邏輯,但這樣做麻煩,編程復雜,效率低下。
          5。什么是事務?什么是鎖?
          答:事務就是被綁定在一起作為一個邏輯工作單元的SQL語句分組,如果任何一個語句操作失敗那么整個操作就被失敗,以后操作就會回滾到操作前狀態,或者是上有個節點。為了確保要么執行,要么不執行,就可以使用事務。要將有組語句作為事務考慮,就需要通過ACID測試,即原子性,一致性,隔離性和持久性。
           鎖:在所以的DBMS中,鎖是實現事務的關鍵,鎖可以保證事務的完整性和并發性。與現實生活中鎖一樣,它可以使某些數據的擁有者,在某段時間內不能使用某些數據或數據結構。當然鎖還分級別的。
          6。什么叫視圖?游標是什么?
          答:視圖是一種虛擬的表,具有和物理表相同的功能。可以對視圖進行增,改,查,操作,試圖通常是有一個表或者多個表的行或列的子集。對視圖的修改不影響基本表。它使得我們獲取數據更容易,相比多表查詢。
           游標:是對查詢出來的結果集作為一個單元來有效的處理。游標可以定在該單元中的特定行,從結果集的當前行檢索一行或多行。可以對結果集當前行做修改。一般不使用游標,但是需要逐條處理數據的時候,游標顯得十分重要。
          7。為管理業務培訓信息,建立3個表:

              S(S#,SN,SD,SA)S#,SN,SD,SA分別代表學號,學員姓名,所屬單位,學員年齡

              C(C#,CN)C#,CN分別代表課程編號,課程名稱

               SC(S#,C#,G) S#,C#,G分別代表學號,所選的課程編號,學習成績

             (1)使用標準SQL嵌套語句查詢選修課程名稱為’稅收基礎’的學員學號和姓名?

                   答案:select s# ,sn from s where S# in(select S# from c,sc where c.c#=sc.c# and cn=’稅收基礎’)

               (2) 使用標準SQL嵌套語句查詢選修課程編號為’C2’的學員姓名和所屬單位?

          答:select sn,sd from s,sc where s.s#=sc.s# and sc.c#=’c2’

               (3) 使用標準SQL嵌套語句查詢不選修課程編號為’C5’的學員姓名和所屬單位?

          答:select sn,sd from s where s# not in(select s# from sc where c#=’c5’)

                (4)查詢選修了課程的學員人數

          答:select 學員人數=count(distinct s#) from sc

                (5) 查詢選修課程超過5門的學員學號和所屬單位?

          答:select sn,sd from s where s# in(select s# from sc group by s# having count(distinct c#)>5)


          主站蜘蛛池模板: 彰武县| 邳州市| 稷山县| 洞口县| 昭苏县| 高尔夫| 喀喇沁旗| 扶风县| 左权县| 水城县| 昌乐县| 金川县| 永和县| 苏州市| 苏尼特左旗| 凤山县| 天峨县| 兴国县| 濮阳县| 鄂伦春自治旗| 胶南市| 涞水县| 包头市| 延长县| 宜章县| 襄垣县| 曲靖市| 安图县| 扶绥县| 鸡泽县| 琼中| 民县| 泽库县| 正镶白旗| 遂溪县| 金平| 中宁县| 保德县| 襄汾县| 玉山县| 增城市|