错误:“用户”处或附近的语法错误
2022-09-01 21:35:23
我正在使用Hibernate,并且有一个名为“User”的持久类。由于这是一个关键字,我用不同的名称标记了@Entity属性(例如,我看到了这个问题:无法在postgresql休眠中使用名为“user”的表。)
但是,我仍然遇到麻烦,因为这个类扩展了另一个类,看起来休眠仍然试图使用“user”作为列名并搞砸了:
@Entity( name = "XonamiUser" )
public class User extends PropertyContainer {
...
和
@MappedSuperclass
public abstract class PropertyContainer implements Serializable {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
protected long key;
/** tags */
@ElementCollection
protected Set<String> tags;
@ElementCollection
protected Set<String> searchList;
...
我的其他扩展 PropertyContainer 的类似乎工作正常。
这是休眠状态中的错误吗?有没有办法解决这种亏缺的重构?谢谢!
以下是我看到的错误(略微清理):
WARN org.hibernate.util.JDBCExceptionReporter - SQL Error: 0, SQLState: 42601
ERROR org.hibernate.util.JDBCExceptionReporter - Batch entry 0 insert into user_search_list (user, search_list) values ('1', 'bjorn') was aborted. Call getNextException to see the cause.
WARN org.hibernate.util.JDBCExceptionReporter - SQL Error: 0, SQLState: 42601
ERROR org.hibernate.util.JDBCExceptionReporter - ERROR: syntax error at or near "user"
Position: 31