org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'sessionFacto

本文讨论了在使用Spring框架与Hibernate进行数据库映射时遇到的MappingException与初始化失败的问题,通过调整主键生成策略,从序列改为native方式,成功解决了应用部署与启动时的错误。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

<2012-10-23 上午11时44分57秒 CST> <Warning> <HTTP> <BEA-101162> <User defined listener org.springframework.web.context.ContextLoaderListener failed: org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'sessionFactory' defined in ServletContext resource [/WEB-INF/applicationContext.xml]: Invocation of init method failed; nested exception is org.hibernate.MappingException: could not instantiate id generator.

org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'sessionFactory' defined in ServletContext resource [/WEB-INF/applicationContext.xml]: Invocation of init method failed; nested exception is org.hibernate.MappingException: could not instantiate id generator
 at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.initializeBean(AbstractAutowireCapableBeanFactory.java:1175)
 at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:428)
 at org.springframework.beans.factory.support.AbstractBeanFactory$1.getObject(AbstractBeanFactory.java:251)
 at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:156)
 at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:248)
 Truncated. see log file for complete stacktrace
org.hibernate.MappingException: could not instantiate id generator
 at org.hibernate.id.IdentifierGeneratorFactory.create(IdentifierGeneratorFactory.java:98)
 at org.hibernate.mapping.SimpleValue.createIdentifierGenerator(SimpleValue.java:152)
 at org.hibernate.impl.SessionFactoryImpl.<init>(SessionFactoryImpl.java:192)
 at org.hibernate.cfg.Configuration.buildSessionFactory(Configuration.java:1294)
 at org.springframework.orm.hibernate3.LocalSessionFactoryBean.newSessionFactory(LocalSessionFactoryBean.java:805)
 Truncated. see log file for complete stacktrace
org.hibernate.MappingException: Dialect does not support sequences
 at org.hibernate.dialect.Dialect.getSequenceNextValString(Dialect.java:595)
 at org.hibernate.id.SequenceGenerator.configure(SequenceGenerator.java:65)
 at org.hibernate.id.IdentifierGeneratorFactory.create(IdentifierGeneratorFactory.java:94)
 at org.hibernate.mapping.SimpleValue.createIdentifierGenerator(SimpleValue.java:152)
 at org.hibernate.impl.SessionFactoryImpl.<init>(SessionFactoryImpl.java:192)
 Truncated. see log file for complete stacktrace
>
<2012-10-23 上午11时44分57秒 CST> <Error> <Deployer> <BEA-149231> <Unable to set the activation state to true for the application 'xyssh'.
weblogic.application.ModuleException:
 at weblogic.servlet.internal.WebAppModule.startContexts(WebAppModule.java:1373)
 at weblogic.servlet.internal.WebAppModule.start(WebAppModule.java:468)
 at weblogic.application.internal.flow.ModuleStateDriver$3.next(ModuleStateDriver.java:204)
 at weblogic.application.utils.StateMachineDriver.nextState(StateMachineDriver.java:37)
 at weblogic.application.internal.flow.ModuleStateDriver.start(ModuleStateDriver.java:60)
 Truncated. see log file for complete stacktrace
org.hibernate.MappingException: Dialect does not support sequences
 at org.hibernate.dialect.Dialect.getSequenceNextValString(Dialect.java:595)
 at org.hibernate.id.SequenceGenerator.configure(SequenceGenerator.java:65)
 at org.hibernate.id.IdentifierGeneratorFactory.create(IdentifierGeneratorFactory.java:94)
 at org.hibernate.mapping.SimpleValue.createIdentifierGenerator(SimpleValue.java:152)
 at org.hibernate.impl.SessionFactoryImpl.<init>(SessionFactoryImpl.java:192)
 Truncated. see log file for complete stacktrace
>

 

看了半天才发现,原来是映射文件中的主键生成方式有问题

<hibernate-mapping>
    <class name="xiayu.com.vo.User" table="user" catalog="xy">
        <id name="merId" type="java.lang.Integer">
            <column name="merId" />
            <generator class="sequence" />
        </id>
        <many-to-one name="dept" class="xiayu.com.vo.Dept" fetch="select">
            <column name="deptId" />
        </many-to-one>
        <property name="merName" type="java.lang.String">
            <column name="merName" length="20" />
        </property>
        <property name="merPwd" type="java.lang.String">
            <column name="merPwd" length="20" />
        </property>
    </class>
</hibernate-mapping>

数据库主键的生成方式是自动增长,在Hibernate反转的时候选成了序列,把这里改成native就可以了

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值