PSQLException:错误:在或附近出现语法错误

Posted

技术标签:

【中文标题】PSQLException:错误:在或附近出现语法错误【英文标题】:PSQLException: ERROR: syntax error at or near 【发布时间】:2017-03-16 22:00:54 【问题描述】:

我在 JPA 中有一个我认为是直截了当的关系。看起来像这样。公司集团:

@Entity
@Table
public class CompanyGroup implements Serializable 


    private static final long serialVersionUID = 1L;
    @Id
    @GeneratedValue
    private Long id;
    @Column(name = "name")
    private String name;
    @JoinColumn(name = "companies")
    @OneToMany(fetch = FetchType.EAGER, cascade = CascadeType.ALL)
    private List<Company> companies;

公司:

@Entity
@Table
public class Company implements Serializable 
    private static final long serialVersionUID = 1L;

    @Column(name = "name")
    private String name;
    @JoinColumn(name = "users")
    @OneToMany(fetch = FetchType.EAGER, cascade = CascadeType.ALL)
    private List<User> users;

    @Id
    @GeneratedValue
    private Long id;

用户:

@Entity
@Table
public class User 

    @Column(name = "firstName")
    private String firstName;
    @Column(name = "lastName")
    private String lastName;
    @Column(name = "email")
    private String email;


    @Id
    @GeneratedValue
    private Long id;

我省略了 setter、getter 等。

这不起作用。我正在尝试将 CompanyGroup(有 2 家公司,每家公司有 2 个用户,所有实体都是唯一的)保存到一个完全空的数据库中。

我使用 Spring-Data 将其持久化,在这样的服务中访问:

@Service
public class ConcreteCompanyGroupService implements CompanyGroupService 

    @Autowired
    private CompanyGroupRepository repository;
    @Transactional
    @Override
    public void save(CompanyGroup group) 
        repository.save(Collections.singleton(group));
    

当我尝试调用此方法时,我收到:

 org.postgresql.util.PSQLException: ERROR: syntax error at or near "User"
  Position: 13
    at org.postgresql.core.v3.QueryExecutorImpl.receiveErrorResponse(QueryExecutorImpl.java:2458)
    at org.postgresql.core.v3.QueryExecutorImpl.processResults(QueryExecutorImpl.java:2158)
    at org.postgresql.core.v3.QueryExecutorImpl.execute(QueryExecutorImpl.java:291)

希望我做了一些愚蠢的事情,有人可以很快找到。我不知道如何解决这个问题。

编辑:

我的 pom.xml 中的驱动程序:

<dependency>
    <groupId>org.postgresql</groupId>
    <artifactId>postgresql</artifactId>
    <version>9.4.1211</version>
</dependency>

【问题讨论】:

似乎和这里发生的一样:***.com/questions/3608420/… 【参考方案1】:

您的实体映射到作为 SQL 保留关键字 (User) 的表名。遗憾的是,您选择的 JPA 提供程序不会自动引用表名标识符,因此在引用该表时会出现异常。

解决方法是要么自己在@Table注解中引用表名,要么将表名改为非保留关键字。或者使用自动为您引用此类保留关键字的 JPA 提供程序(例如 DataNucleus

【讨论】:

"desc" 也是保留字。我使用了@Column private String desc;并遇到异常的运行时问题。将数据库字段从“desc”更改为“description”解决了这个问题。【参考方案2】:

解决方案 1:正如 Pascal 提到的,您必须使用反斜杠转义表名,例如:

@Entity
@Table(name="\"User\"")
public class User 
    ...

解决方案 2:用另一个名称重命名您的表的名称 (Users)

@Entity
@Table(name="Users")
public class User 
    ...

解决方案 3:为表名添加后缀:

@Entity
@Table(name="APP_User")
public class User 
    ...

解决方案 4:更改实体名称,例如ApplicationUser

@Entity
public class ApplicationUser 
    ...

原因

PostgreSQL 作为一些保留的SQL Key Words。例如:ABORT, ALL, ARRAY, CACHE, CUBE, USER, ... 这些标记在 SQL 标准中或特定于 PostgreSQL

【讨论】:

【参考方案3】:

使用 @Table 注释或将类名从 User 更改为其他名称,因为 User 是 sql 中的保留关键字。

【讨论】:

嗨,Jatin,在发布自己的答案之前,请先查看其他人的答案。您的建议已被其他写过答案的人提及。

以上是关于PSQLException:错误:在或附近出现语法错误的主要内容,如果未能解决你的问题,请参考以下文章

使用 psycopg2 在 python 中执行查询时出现“ProgrammingError:在或附近出现语法错误”

获取 PSQLException:错误:在带有 Postgres 的 spark jdbc 中使用查询而不是表名时在“SELECT”处或附近出现语法错误

java - PSQLException:错误:“$ 1”处或附近的语法错误[重复]

在 PostgreSQL 中选择具有特定列名的列

PSQLException:错误:tsquery 中的语法错误

为啥我在意外标记 `(' 附近出现语法错误