• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            cc

              C++博客 :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理 ::
              38 隨筆 :: 14 文章 :: 21 評論 :: 0 Trackbacks

            說明:

            今天在做一個(gè)OA的簡單增刪除該查的時(shí)候,有一個(gè)時(shí)間類型的字段(數(shù)據(jù)插入時(shí)間),本身想著,這個(gè)字段直接中Oracle數(shù)據(jù)庫設(shè)置一個(gè)Default Value ,就不用再前臺install這個(gè)字段的值了,但是后時(shí)間操作中發(fā)現(xiàn)插入的時(shí)候如果不通過hql去寫代碼的話,而是通過hibernate的接口getHibernateTemplate().saveOrUpdate(entity);的話,就出現(xiàn)問題,插入的時(shí)間類型字段的值是null,tmd有點(diǎn)郁悶,不好意思又說臟話了,也是當(dāng)時(shí)頭有點(diǎn)昏,呵呵。后來,一想如果通過getHibernateTemplate().saveOrUpdate(entity);這個(gè)借口,如果沒有設(shè)置值,那么就會(huì)設(shè)置null,所有出現(xiàn)了這個(gè)問題。查看了下hibernate的接口文檔,一看,原來是這樣的。

            需要添加下面的參數(shù)在*.hbm.xml中class節(jié)點(diǎn)設(shè)置,如下

            一是將dynamic-insert設(shè)置為true

            二是將對應(yīng)字段的屬性設(shè)置not-null為false

            <hibernate-mapping>
            <class name="com.tom.hibernate.xxxx" table="xxx schema="xxx" dynamic-insert="true" dynamic-update="true">

            <property name="entryDate" type="java.util.Date">
            <column name="ENTRY_DATE" length="7" not-null="false"/>
            </property>

            用拿來主義)貼過來一個(gè)這個(gè)接口說明:

            下面是有關(guān)其它配置的說明

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

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

            另外一種做法請看如下配置:

            Hibernate <property>配置

            <property name="name" unique="true" not-null="true" update="false" length="25"/>

            <property>元素 insert屬性:設(shè)置為false,在insert語句中不包含這個(gè)字段,表示永遠(yuǎn)不會(huì)被插入。默認(rèn)true。

            <property>元素 update屬性:設(shè)置為false,在update語句中不包含這個(gè)字段,表示永遠(yuǎn)不會(huì)被修改。默認(rèn)true。


            <class>元素 mutable屬性:設(shè)置為false,就是把所有的<property>元素的update屬性設(shè)置為了false,說明這個(gè)對象不會(huì)被更新。默認(rèn)true。

            <property>元素 dynamic-insert屬性:設(shè)置為true,表示insert對象的時(shí)候,生成動(dòng)態(tài)的insert語句,如果這個(gè)字段的值是null就不會(huì)加入到insert語句當(dāng)中。默認(rèn)false 

            <property>元素 dynamic-update屬性:設(shè)置為true,表示update對象的時(shí)候,生成動(dòng)態(tài)的update語句,如果這個(gè)字段的值是null就不會(huì)被加入到update語句中。默認(rèn)false 

            <class>元素 dynamic-insert屬性:設(shè)置為true,表示把所有的<property>元素的dynamic-insert屬性設(shè)置為true。默認(rèn)false 

            <class>元素 dynamic-update屬性:設(shè)置為true,表示把所有的<property>元素的dynamic-update屬性設(shè)置為true。默認(rèn)false

            dynamic-update,如果一個(gè)表字段比較多,并且經(jīng)常只是更新一條記錄的一兩個(gè)字段,避免了過多無用的sql語句,動(dòng)態(tài)更新會(huì)更有效。應(yīng)用程序會(huì)增加工作量,但是數(shù)據(jù)庫會(huì)減少工作量。在插入和修改數(shù)據(jù)的時(shí)候,語句中只包括要插入或者修改的字段,可以節(jié)省SQL語句的執(zhí)行時(shí)間,提高程序的運(yùn)行效率。
            posted on 2013-03-29 10:07 醒目西西 閱讀(304) 評論(0)  編輯 收藏 引用

            只有注冊用戶登錄后才能發(fā)表評論。
            網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


            日韩电影久久久被窝网| 性欧美大战久久久久久久久| 国产香蕉97碰碰久久人人| 国产亚洲成人久久| 手机看片久久高清国产日韩| 久久夜色精品国产亚洲| 久久亚洲私人国产精品vA | 久久人人妻人人爽人人爽| 69久久夜色精品国产69| 无码国内精品久久人妻麻豆按摩| 亚洲国产婷婷香蕉久久久久久| 久久99精品久久久久久齐齐| 久久久久久久久久久久中文字幕 | 婷婷伊人久久大香线蕉AV| 国产一区二区三区久久精品| 一本色道久久综合狠狠躁篇 | 久久精品无码一区二区三区免费| 无码人妻久久一区二区三区免费丨| 青青草原综合久久| 久久精品国产精品亚洲毛片| 性欧美大战久久久久久久| 99久久精品九九亚洲精品| 欧美丰满熟妇BBB久久久| 2021国产精品午夜久久| 久久综合五月丁香久久激情| 成人a毛片久久免费播放| 精品蜜臀久久久久99网站| 久久久久亚洲av无码专区导航 | 欧美黑人激情性久久| 亚洲精品无码久久久久sm| 久久精品国产亚洲AV忘忧草18| 国产精品久久久久a影院| 午夜福利91久久福利| 久久午夜综合久久| 久久影院午夜理论片无码 | 久久久久亚洲精品日久生情 | 国产午夜精品理论片久久| 亚洲国产精品人久久| 久久综合精品国产一区二区三区 | 亚洲精品国产字幕久久不卡| 亚洲精品无码久久久久sm|