防止Hibernate架构更改

时间:2013-05-14 14:59:15

标签: java oracle hibernate spring-mvc

我是Hibernate的新手,我的配置存在一些问题。我正在尝试建立与先前存在的Oracle数据库的只读连接。我不希望Hibernate执行任何DML / DDL并改变数据库模式,但每次我尝试部署我的项目时,这都是我看到的消息:

INFO: updating schema
SEVERE: Unsuccessful: create table WILLOEM.SAMPLE_INFO (SAMPLE_ID varchar2(255) not null, CELL_LINE varchar2(255), STUDY_ID varchar2(255), primary key (SAMPLE_ID))
SEVERE: ORA-00955: name is already used by an existing object

这里没有造成任何损害,因为表创建失败了,但我不想创建数据可能丢失的情况。如何配置Hibernate以只读方式运行?我是否可以完全阻止语句执行,而无需添加缺少权限的新Oracle用户?

这是我目前的Hibernate配置:

<bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
    <property name="driverClassName"><value>oracle.jdbc.OracleDriver</value></property>
    <property name="url"><value>jdbc:oracle:thin:@source.db.somewhere.com:1524:WILLOEM</value></property>
    <property name="username"><value>username</value></property>
    <property name="password"><value>password</value></property>
</bean>

<bean id="sessionFactory" class="org.springframework.orm.hibernate3.annotation.AnnotationSessionFactoryBean">
    <property name="dataSource"><ref local="dataSource"/></property>
    <property name="packagesToScan" value="com.willoem.project.hibernate" />
    <property name="hibernateProperties">
        <props>
            <prop key="hibernate.dialect">org.hibernate.dialect.OracleDialect</prop>
            <prop key="hibernate.show_sql">true</prop>
            <prop key="hibernate.hbm2ddl.auto">update</prop>
        </props>
    </property>
</bean>

<bean id="transactionManager" class="org.springframework.orm.hibernate3.HibernateTransactionManager">
    <property name="sessionFactory"><ref local="sessionFactory"/></property>
</bean>

1 个答案:

答案 0 :(得分:6)

你可以改变

<prop key="hibernate.hbm2ddl.auto">update</prop>

<prop key="hibernate.hbm2ddl.auto">validate</prop>

这会验证架构,但不会对其进行任何更改。