Hibernate 写入数据库加入Timetamp(时间戳)配置

xxx.hbm.xml配置如下:

<?xml version="1.0"?>
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<!-- Generated Jan 5, 2013 2:10:24 PM by Hibernate Tools 3.4.0.CR1 -->
<hibernate-mapping>
<class name="com.shinelife.dao.Player" table="player" catalog="tiexue">
<id name="id" type="java.lang.Integer">
<column name="ID" />
<generator class="identity" />
</id>
<property name="playerId" type="java.lang.String">
<column name="playerId" length="20" />
</property>
<property name="playerName" type="java.lang.String">
<column name="playerName" length="20" />
</property>
<property name="haveMoney" type="java.lang.Double">
<column name="haveMoney" precision="22" scale="0" />
</property>
<property name="sex" type="java.lang.String">
<column name="sex" length="1" />
</property>
<property name="headUrl" type="java.lang.String">
<column name="headUrl" length="50" />
</property>
<property name="timetamp" type="java.sql.Timestamp" generated="insert" not-null="true">
<column name="timetamp" sql-type="timestamp" default="CURRENT_TIMESTAMP" />
</property>
</class>
</hibernate-mapping>
----------------------------------------
一般使用 property 映射中的 generated 开关启用这个自动刷新,而最下面createTime的配置:

<property name="time" type="java.sql.Timestamp" generated="insert" not-null="true">
<column name="time" sql-type="timestamp" default="CURRENT_TIMESTAMP" />
</property>
---------------------

关于 generated 的适用值说明:

never(默认): 标明此属性值不是从数据库中生成, 也就是根本不用刷新实体类了.
insert: 标明此属性值在insert的时候生成, 但是不会在随后的update时重新生成. 也就是只在insert情况下才会刷新实体类.
always: 标明此属性值在insert和update时都会被生成, 也就是在insert, update情况下都会刷新实体类.

sql-type 指生成的时间的类型

default Hibernate本身提供 current_date, current_timestamp 和 current_time 三种函数.

个人总结:其实还有一种最为方便的方法:1.在数据库中选择字段类型为timestemp。
2.设置一个default为:CURRENT_TIMESTAMP
3.利用myEclipse的db映射工具自动映射过来就OK了。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

水番丘山

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值