<timestamp name="updDate" column="UPD_DATE"></timestamp>
这个必须跟在id定义之后
这使用AP服务器的时间,而不是DB服务器的时间,来更新数据库。
即更新数据库时使用的是new Date(),而不是sysdate。
如果要使用DB服务器时间来更新DB,必须加上source="db"
此时,hibernate会先从数据库中取出当前时间(select sysdate from dual),然后再用该时间进行更新。
并不是严格意义上的用sysdate更新数据库(update table1 set upd_date=sysdate ……)。
如果更新结果中没有毫秒信息,请检查Dialect,应使用org.hibernate.dialect.Oracle10gDialect。(Oracle9及其后续版本应该都支持毫秒)
不要使用org.hibernate.dialect.OracleDialect,该类已经被Deprecated。
使用org.hibernate.dialect.Oracle10gDialect之后,取DB时间的SQL会变为 select systimestamp from dual。
Hibernate使用Criteria,除了默认的关联条件之外,添加额外的关联条件:createAlias("xxxx", "b",Criteria.LEFT_JOIN,criteria)。
<set name="MUpdateFuncTabs" table="M_UPDATE_FUNC_TAB" inverse="true" lazy="false" fetch="join">
或者criteria.setFetchMode("MUpdateFuncTabs", FetchMode.JOIN)
在一般情况下,只执行一条SQL语句就能把主表和副表的数据都取回来。但是join会导致检索结果增多,结果件数为join之后的件数……
但是如果在criteria中指定了副表的关联查询条件
criteria.createAlias("MUpdateFuncTabs", "tabs", JoinType.LEFT_OUTER_JOIN, Restrictions.eq(MUpdateFuncTab.DEL_FLG, Constant.DEL_FLG_VALID));
那么,就会变成fetch="select"一样的效果,将会执行N条SQL语句以取得副表的数据。