我的数据库操作使用的是hibernate。在save 的时候是将主键设置为0,然后在数据库中插入时,利用触发器调用存储过程获得主键。目前数据库插入是没问题的,但是,利用Long id = (Long)this.getHibernateTemplate().save(entity);
依然得不到主键请问,哪位大侠知道。。hibernate是否可以得到主键呢
通过什么方式呢。。
依然得不到主键请问,哪位大侠知道。。hibernate是否可以得到主键呢
通过什么方式呢。。
解决方案 »
- 两个项目共享一个数据库出现卡死,求解决方法!打酱油的、赚可用分的请绕道!
- 紧急求助,关于线程安全问题
- 请问:hibernate中,此时的对象user2是脱管状态,还是瞬时状态?
- 大家帮帮忙,这个flash是用什么java flash图表工具完成的?
- Hibernate多值查询后使用Spring处理结果的问题
- EJB错误
- 使用复合主键时,发生classcastException异常,复合主键类能否被序列化
- xfire中文问题,会的指点一下啊
- 怎么限制tomcat日志文件catalina.out的大小?
- 一款用于测试发布于服务器端(如Weblogic, Websphere)的 EJB组件、Servlet以及 Beans的黑盒/白盒智能化测试工具
- Struts2的配置问题
- Struts2 modelDriven的 神奇 惊讶 发现
Long id = (Long)this.getHibernateTemplate().find("select id from entity ");
没有明白你的意思,
entity是我要save的对象,
在save的时候,通过在数据库中设置before insert的触发器,来为entity付主键,
我如何可以得到触发器为这个entity付的主键呢??
long id=entity.getId();
试验下!
这是我常用的spring的配置:<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:aop="http://www.springframework.org/schema/aop"
xmlns:tx="http://www.springframework.org/schema/tx"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-2.5.xsd
http://www.springframework.org/schema/tx
http://www.springframework.org/schema/tx/spring-tx-2.5.xsd
http://www.springframework.org/schema/aop
http://www.springframework.org/schema/aop/spring-aop-2.5.xsd">
<!-- 定义数据源Bean,使用C3P0数据源实现 -->
<bean id="dataSource"
class="com.mchange.v2.c3p0.ComboPooledDataSource"
destroy-method="close">
<!-- 指定连接数据库的驱动 -->
<property name="driverClass" value="com.mysql.jdbc.Driver" />
<!-- 指定连接数据库的URL -->
<property name="jdbcUrl" value="jdbc:mysql://localhost/ems" />
<!-- 指定连接数据库的用户名 -->
<property name="user" value="root" />
<!-- 指定连接数据库的密码 -->
<property name="password" value="" />
<!-- 指定连接数据库连接池的最大连接数 -->
<property name="maxPoolSize" value="40" />
<!-- 指定连接数据库连接池的最小连接数 -->
<property name="minPoolSize" value="1" />
<!-- 指定连接数据库连接池的初始化连接数 -->
<property name="initialPoolSize" value="1" />
<!-- 指定连接数据库连接池的连接的最大空闲时间 -->
<property name="maxIdleTime" value="20" />
</bean> <!-- 定义Hibernate的SessionFactory -->
<bean id="sessionFactory"
class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
<!-- 依赖注入数据源,注入正是上面定义的dataSource -->
<property name="dataSource" ref="dataSource" />
<!-- mappingResouces属性用来列出全部映射文件 -->
<property name="mappingResources">
<list>
<!-- 以下用来列出Hibernate映射文件 -->
<value>包名/XXX.hbm.xml</value>
</list>
</property>
<!-- 定义Hibernate的SessionFactory的属性 -->
<property name="hibernateProperties">
<props>
<!-- 指定数据库方言 -->
<prop key="hibernate.dialect">
org.hibernate.dialect.MySQLInnoDBDialect
</prop>
<!-- 是否根据需要每次自动创建数据库 -->
<prop key="hibernate.hbm2ddl.auto">update</prop>
<!-- 显示Hibernate持久化操作所生成的SQL -->
<prop key="hibernate.show_sql">true</prop>
<!-- 将SQL脚本进行格式化后再输出 -->
<prop key="hibernate.format_sql">true</prop>
</props>
</property>
</bean> <!-- 配置Hibernate的局部事务管理器,使用HibernateTransactionManager类 -->
<!-- 该类实现PlatformTransactionManager接口,是针对Hibernate的特定实现-->
<bean id="transactionManager"
class="org.springframework.orm.hibernate3.HibernateTransactionManager">
<!-- 配置HibernateTransactionManager时需要依注入SessionFactory的引用 -->
<property name="sessionFactory" ref="sessionFactory" />
</bean> <!-- 配置事务切面Bean,指定事务管理器 -->
<tx:advice id="txAdvice" transaction-manager="transactionManager">
<!-- 用于配置详细的事务语义 -->
<tx:attributes>
<!-- 所有以'get'开头的方法是read-only的 -->
<tx:method name="get*" read-only="true" />
<!-- 其他方法使用默认的事务设置 -->
<tx:method name="*" />
</tx:attributes>
</tx:advice> <aop:config>
<!-- 配置一个切入点,匹配xxxx包下
所有以Impl结尾的类的所有方法的执行 -->
<aop:pointcut id="leePointcut"
expression="execution(* xxxx.*Impl.*(..))" />
<!-- 指定在leePointcut切入点应用txAdvice事务切面 -->
<aop:advisor advice-ref="txAdvice" pointcut-ref="leePointcut" />
</aop:config>
</beans>
我测了下,如果我的主键策略采用ORACLE序列的话,初始化为0,
再存储后,entity的主键会是序列中的值,
说明我的transaction的配置应该也没问题,(我的transaction和你的差不多)
我在想7楼的话,
是不是通过hibernate是拿不到通过我这个流程存储后的主键??(触发器调用存储过程),
我也试了下hibernate3提供的触发器策略,
也不可以,(可能是因为我的触发器是通过调用存储过程得到id?)
解决办法:this.getHibernateTemplate().save(entity);
entity = this.getHibernateTemplate().findByExample(entity).get(0);结贴散分~