HTTP状态500 - 请求处理失败;嵌套异常是org.hibernate.exception.SQLGrammarException:表'rbcart.product'不存在

时间:2017-02-01 19:17:20

标签: hibernate spring-mvc jpa

我正在创建一个应用程序,每当我点击产品标签时,它应该列出数据库中的所有产品。以下是文件。

<?xml version="1.0" encoding="utf-8"?>
<beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-bean">
    <bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
        <property name="driverClassName" value="com.mysql.jdbc.Driver"/>
        <property name="url" value="jdbc:mysql://localhost:3306/rbcart"/>
        <property name="username" value="root"/>
        <property name="password" value="root"/>
    </bean>
    <bean id="sessionFactory" class="org.springframework.orm.hibernate4.LocalSessionFactoryBean">
        <property name="dataSource" ref="dataSource"/>
        <property name="hibernateProperties">
            <props>
                <prop key="hibernate.dialect">org.hibernate.dialect.MySQLDialect</prop>
                <prop key="hibernate.hbm2ddl.auto">update</prop>
                <prop key="hibernate.show_sql">true</prop>
                <prop key="hibernate.format_sql">true</prop>
            </props>
        </property>
        <property name="packagesToScan">
            <list>
                <value>com.emusicstore</value>
            </list>
        </property>
    </bean>
    <bean id="transactionManager" class="org.springframework.orm.hibernate4.HibernateTransactionManager">
        <property name="sessionFactory" ref="sessionFactory"/>
    </bean>
</beans>

因此,当我点击“产品”标签时,它会给我错误 HTTP状态500 - 请求处理失败;嵌套异常是org.hibernate.exception.SQLGrammarException:表'rbcart.product'不存在

Error Page

但是hibernate应该自己创建表。那么这有什么问题呢?

2 个答案:

答案 0 :(得分:0)

我有同样的问题。我的问题是我将id保存为String(在模型类中)并添加了注释@GeneratedValue(strategy = GenerationType.AUTO)。如果我对注释进行了注释,则表在数据库中创建,并且错误不再出现。 希望这有帮助。

答案 1 :(得分:0)

也许您没有创建架构。您可以尝试通过添加“?createDatabaseIfNotExist = true”来修改网址,如下所示: