解决You have an error in your SQL syntax; check the manual that corresponds to your MySQL server versi

Posted 何甜甜在吗

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了解决You have an error in your SQL syntax; check the manual that corresponds to your MySQL server versi相关的知识,希望对你有一定的参考价值。

在学习hibernate一对多映射关系时,根据视频学习的时候,例子是顾客和订单的问题,一个顾客有多个订单。按照视频中的敲代码出现了You have an error in your SQL syntax; check the manual that corresponds to your mysql server version for the right syntax to use near ‘order (order_name, customer)

 

原因是order是mysql关键字,不能做为表名

 

<?xml version="1.0"?>
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate Mapping DTD 3.0"
        "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<hibernate-mapping package="com.cqupt.dayday">
    <class name="Order" table="order1">
        <id name="orderId" type="java.lang.Integer">
            <column name="order_id"/>
            <!--指定主键的生成方式, native:使用数据库本地方式-->
            <generator class="native"/>
        </id>
        <property name="orderName" type="java.lang.String">
            <column name="order_name"/>
        </property>
        <!--映射多对一的关联关系-->
        <many-to-one name="customer" class="Customer" column="customer_id"></many-to-one>
    </class>
</hibernate-mapping>

后来将表名改为table1就运行成功了

以上是关于解决You have an error in your SQL syntax; check the manual that corresponds to your MySQL server versi的主要内容,如果未能解决你的问题,请参考以下文章

解决mysql 8报错 ERROR 1064 (42000): You have an error in your SQL syntax

ERROR 1064 (42000): You have an error in your SQL syntax...

解决——》ERROR 1064 (42000)You have an error in your SQL syntax; check the manual that corresponds

ERROR 1064 (42000): You have an error in your SQL syntax; check the manual ...

解决You have an error in your SQL syntax; check the manual that corresponds to your MySQL server versi

异常之You have an error in your SQL syntax