我认为我在JPA中是一个直接的关系。看起来像这样。 CompanyGroup:
@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,getters等。
这不起作用。我试图将一个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>
答案 0 :(得分:22)
您的实体映射到表名称,该表名称是SQL保留关键字(User
)。遗憾的是,您选择的JPA提供程序不会自动引用表名标识符,因此在引用该表时会出现异常。
解决方案是在@Table
注释中自己引用表名,或者将表名更改为不是保留关键字。或者使用JPA提供程序为您自动引用此类保留关键字(例如DataNucleus
)
答案 1 :(得分:4)
解决方案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
答案 2 :(得分:0)
使用@Table 注释或将类名从 User 更改为其他名称,因为 User 是 sql 中的保留关键字。