当我尝试在 table 中保存值时出现错误 table.auto_pk_support
Error table.auto_pk_support when I try to save a value in my table
我有另一个问题(似乎与: 相同)但是我在主键中为 ID 和 'Database-Generated' 设置了自动增量和唯一索引-增量字段,参见:
public abstract class _DateInfo extends CayenneDataObject {
public static final String ENDDATETIME_PROPERTY = "enddatetime";
public static final String STARTDATETIME_PROPERTY = "startdatetime";
public static final String USER_ID_PROPERTY = "userId";
public static final String DATEINFOID_PK_COLUMN = "DATEINFOID";
public static final String USERID_PK_COLUMN = "USERID";
public void setEnddatetime(Date enddatetime) {
writeProperty(ENDDATETIME_PROPERTY, enddatetime);
}
public Date getEnddatetime() {
return (Date)readProperty(ENDDATETIME_PROPERTY);
}
public void setStartdatetime(Date startdatetime) {
writeProperty(STARTDATETIME_PROPERTY, startdatetime);
}
public Date getStartdatetime() {
return (Date)readProperty(STARTDATETIME_PROPERTY);
}
public void setUserId(int userId) {
writeProperty(USER_ID_PROPERTY, userId);
}
public int getUserId() {
Object value = readProperty(USER_ID_PROPERTY);
return (value != null) ? (Integer) value : 0;
}
}
我试图在单击保存按钮时保存当地时间:
Button save = new Button("Save", event -> {
DateInfoFactory date = CayenneUtil.getContext().newObject(
DateInfoFactory.class);
date.setUserId(userIdSelected);
if (startTime.getValue() != null) {
LocalTime startDate = startTime.getValue();
date.setStartdatetime(toDate(startDate));
}
date.getObjectContext().commitChanges();
});
save.addStyleName(ValoTheme.BUTTON_PRIMARY);
但是后来,我收到了这个错误:
juin 12, 2017 9:38:32 PM org.apache.cayenne.log.CommonsJdbcEventLogger logQuery
INFOS: LOCK TABLES AUTO_PK_SUPPORT WRITE
juin 12, 2017 9:38:32 PM org.apache.cayenne.log.CommonsJdbcEventLogger logQuery
INFOS: UNLOCK TABLES
juin 12, 2017 9:38:32 PM com.vaadin.server.DefaultErrorHandler doDefault
GRAVE:
org.apache.cayenne.CayenneRuntimeException: [v.4.0.M5 Feb 24 2017 07:47:55] Commit Exception
..
Caused by: com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException: Table 'mam.auto_pk_support' doesn't exist
我在 MySQL 中的 table 是:
我该怎么办?
谢谢,
您可以通过多种方式修复代码。
你复合PK(dateinfoid
+userid
)这是故意的?
可能您应该使用单列 PK(即仅 dateinfoid
),因为它在您的案例中唯一标识对象,并有可能使您免于其他麻烦。
如果复合 PK 是有意的,那么请确保您在 userIdSelected
中提供非零值,否则 Cayenne 将尝试通过 auto_pk_support
table 提供它。
我有另一个问题(似乎与:
public abstract class _DateInfo extends CayenneDataObject {
public static final String ENDDATETIME_PROPERTY = "enddatetime";
public static final String STARTDATETIME_PROPERTY = "startdatetime";
public static final String USER_ID_PROPERTY = "userId";
public static final String DATEINFOID_PK_COLUMN = "DATEINFOID";
public static final String USERID_PK_COLUMN = "USERID";
public void setEnddatetime(Date enddatetime) {
writeProperty(ENDDATETIME_PROPERTY, enddatetime);
}
public Date getEnddatetime() {
return (Date)readProperty(ENDDATETIME_PROPERTY);
}
public void setStartdatetime(Date startdatetime) {
writeProperty(STARTDATETIME_PROPERTY, startdatetime);
}
public Date getStartdatetime() {
return (Date)readProperty(STARTDATETIME_PROPERTY);
}
public void setUserId(int userId) {
writeProperty(USER_ID_PROPERTY, userId);
}
public int getUserId() {
Object value = readProperty(USER_ID_PROPERTY);
return (value != null) ? (Integer) value : 0;
}
}
我试图在单击保存按钮时保存当地时间:
Button save = new Button("Save", event -> {
DateInfoFactory date = CayenneUtil.getContext().newObject(
DateInfoFactory.class);
date.setUserId(userIdSelected);
if (startTime.getValue() != null) {
LocalTime startDate = startTime.getValue();
date.setStartdatetime(toDate(startDate));
}
date.getObjectContext().commitChanges();
});
save.addStyleName(ValoTheme.BUTTON_PRIMARY);
但是后来,我收到了这个错误:
juin 12, 2017 9:38:32 PM org.apache.cayenne.log.CommonsJdbcEventLogger logQuery
INFOS: LOCK TABLES AUTO_PK_SUPPORT WRITE
juin 12, 2017 9:38:32 PM org.apache.cayenne.log.CommonsJdbcEventLogger logQuery
INFOS: UNLOCK TABLES
juin 12, 2017 9:38:32 PM com.vaadin.server.DefaultErrorHandler doDefault
GRAVE:
org.apache.cayenne.CayenneRuntimeException: [v.4.0.M5 Feb 24 2017 07:47:55] Commit Exception
..
Caused by: com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException: Table 'mam.auto_pk_support' doesn't exist
我在 MySQL 中的 table 是:
我该怎么办?
谢谢,
您可以通过多种方式修复代码。
你复合PK(
dateinfoid
+userid
)这是故意的? 可能您应该使用单列 PK(即仅dateinfoid
),因为它在您的案例中唯一标识对象,并有可能使您免于其他麻烦。如果复合 PK 是有意的,那么请确保您在
userIdSelected
中提供非零值,否则 Cayenne 将尝试通过auto_pk_support
table 提供它。