22

在我的 Java 程序 ..Hibernate Bean 类中定义一列,如..

TimtableVO.java

@Column(name="REPEAT_DAYS")
private WeekdayType repeatDays;//hear WeekdayType is Enum Class

在我的服务类中,我使用这个 TimetableVO.java bean 类作为..

这是我的服务类:

public void createEvent(TimetableVO timetableVO) {
    WeekdayType weekday = null;
    for (String day : timetableVO.getTemp().split(",")) {
        weekday = WeekdayType.valueOf(day);
    }
    timetableVO.setRepeatDays(weekday);
    userDAO.createEvent(timetableVO);
}

我的 DAO 类我正在插入 timetableVO 对象..

public void createEvent(TimetableVO timetableVO) throws DataAccessException {
    entityManager.persist(timetableVO);
}

但是异常会来..

Exception: Caused by: java.sql.BatchUpdateException: Data truncated for column 'REPEAT_DAYS' at row 1
    at com.mysql.jdbc.PreparedStatement.executeBatchSerially(PreparedStatement.java:2045)
    at coHibernate: insert into EC_TIMETABLE (CLASS_DURATION, COURSE_DURATION, COURSE_FEE, END_DATE, REPEAT_COUNT, REPEAT_DAYS, REPEAT_TYPE, SEARCH_KEY, START_DATE, S_ID) values (?, ?, ?, ?, ?, ?, ?, ?, ?, ?)
m.mysql.jdbc.PreparedStatement.executeBatch(PreparedStatement.java:1468)
    at org.hibernate.jdbc.BatchingBatcher.doExecuteBatch(BatchingBatcher.java:70)
    at org.hibernate.jdbc.AbstractBatcher.executeBatch(AbstractBatcher.java:268)
    ... 65 more
Caused by: java.sql.SQLException: Data truncated for column 'REPEAT_DAYS' at row 1
    at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:1073)

编辑: 这是我的 WeekdayType 枚举

public enum WeekdayType {
    MONDAY(Calendar.MONDAY), TUESDAY(Calendar.TUESDAY), WEDNESDAY(
    Calendar.WEDNESDAY), THURSDAY(Calendar.THURSDAY), FRIDAY(
    Calendar.FRIDAY), SATURDAY(Calendar.SATURDAY), SUNDAY(
    Calendar.SUNDAY);

    private int day;

    private WeekdayType(int day) {
        this.day = day;
    }

    public int getDay() {
        return day;
    }
}
4

5 回答 5

19

这可能是由于ENUM您的表架构中没有您尝试插入的所有值造成的。就像是:

CREATE TABLE IF NOT EXISTS event (
    weekday_type ENUM(
        'SUNDAY',
        'MONDAY',
        'TUESDAY',
        'WEDNESDAY',
        'THURSDAY',
        'FRIDAY'
    ) NOT NULL
);

然后当你执行插入时

INSERT INTO event (weekday_type) VALUES ('SATURDAY');

使用 JDBC 你会得到一个例外,比如:Data truncated for column 'weekday_type' at row 1因为你忘记包含SATURDAY在你的表定义中。当插入发生时,该值truncated变为空。

于 2013-05-06T22:49:02.827 回答
18

看起来错误是由于该列REPEAT_DAYS太小而无法保存您通过WeekdayType枚举传递的值。因此,重新检查下级数据库中该列的定义并最终增加它的大小。

您还缺少注释:

 @Column(name="REPEAT_DAYS", length="45")
 @Enumerated(EnumType.STRING)
 private WeekdayType repeatDays;

注释中的length应该与数据库模式中列的长度相匹配。

于 2012-12-19T10:51:45.263 回答
1

您的服务器似乎在严格模式下运行,您可能会尝试在 NOT NULL 列中插入 NULL。

另请参阅此处:这是什么错误?“数据库查询失败:第 1 行的列 'column_name' 的数据被截断

于 2012-12-19T10:49:13.443 回答
1

假设您的表是由休眠自动生成的,您不能像以前那样注释 Enum 类型

@Column(name="REPEAT_DAYS")

私人 WeekdayType repeatDays;

检查@Enumerated(EnumType.STRING)注释

于 2012-12-19T10:52:12.860 回答
1

仅当您尝试插入一个太长而无法容纳列的值时,才会出现此问题。在您的情况下,列定义REPEAT_DAYS不足以保持您的价值。另外,您不能注释枚举类型,例如

@Column(name="REPEAT_DAYS")

private WeekdayType repeatDays;

相反,你可以做类似的事情

@Enumerated(EnumType.STRING)并像这样定义您的枚举

enum Fruits {
  apple,
  orange
}
于 2012-12-19T10:57:08.283 回答