沙漠中的魚

          欲上天堂,先下地獄
          posts - 0, comments - 56, trackbacks - 0, articles - 119
            BlogJava :: 首頁 ::  :: 聯系 :: 聚合  :: 管理

          Hibernate中dynamic-insert和dynamic-update

          Posted on 2009-06-07 11:56 沙漠中的魚 閱讀(1730) 評論(0)  編輯  收藏 所屬分類: 開源框架

          Hibernate允許我們在映射文件里控制insert和update語句的內容.比如在映射文件中<property 元素中的update屬性設置成為false,那么這個字段,將不被包括在基本的update語句中,修改的時候,將不包括這個字段了.insert同理.dynamic動態SQL語句的配置也是很常用的.下面介紹配置SQL語句的具體屬性:
                1)<property>元素 insert屬性:設置為false,在insert語句中不包含這個字段,表示永遠不會被插入,默認true
                2)<property>元素 update屬性:設置為false,在update語句中不包含這個字段,表示永遠不會被修改,默認true
                3)<class>元素 mutable屬性:設置為false就是把所有的<property>元素的update屬性設置為了false,說明這個對象不會被更新,默認true
                4)<property>元素 dynamic-insert屬性:設置為true,表示insert對象的時候,生成動態的insert語句,如果這個字段的值是null就不會加入到insert語句當中.默認false
                5)<property>元素 dynamic-update屬性,設置為true,表示update對象的時候,生成動態的update語句,如果這個字段的值是null就不會被加入到update語句中,默認false
                6)<class>元素 dynamic-insert屬性:設置為true,表示把所有的<property>元素的dynamic-insert屬性設置為true,默認false
                7)<class>元素 dynamic-update屬性:設置為true,表示把所有的<property>元素的dynamic-update屬性設置為true,默認false

                Hibernate生成動態SQL語句的消耗的系統資源(比如CPU,內存等)是很小的,所以不會影響到系統的性能,如果表中包含N多字段,建議把dynamic-update屬性和insert屬性設置為true,這樣在插入和修改數據的時候,語句中只包括要插入或者修改的字段.可以節省SQL語句的執行時間,提高程序的運行效率.

          主站蜘蛛池模板: 繁峙县| 南昌县| 蒲江县| 都昌县| 东海县| 大理市| 缙云县| 乐陵市| 施甸县| 科尔| 长白| 乐平市| 安图县| 竹山县| 莱州市| 宜城市| 鱼台县| 江门市| 沁阳市| 多伦县| 密云县| 隆回县| 鄂伦春自治旗| 万载县| 鄯善县| 贵溪市| 岫岩| 东乌珠穆沁旗| 翼城县| 全州县| 和平区| 缙云县| 黔江区| 东辽县| 莒南县| 虞城县| 汕尾市| 华坪县| 澜沧| 泾阳县| 怀安县|