java - 添加数组时准备语句错误

标签 java sql arrays spring

我正在使用 SPRING famework,目前我正在尝试在创建新条目(行)时向我的数据库添加一个数组。有问题的列称为“关键字”。所以这是我的 sql 初始化代码(对我来说看起来不错)

CREATE TABLE IF NOT EXISTS Email (
    Email_Id INT UNSIGNED NOT NULL AUTO_INCREMENT,
    Sender_Email VARCHAR(255) NOT NULL,
    Recipient_Email VARCHAR(255) NOT NULL,
    Subject VARCHAR(255) NOT NULL,
    Body TEXT,
    Attachment_Path VARCHAR(255) NOT NULL,
    Creation_Date DATETIME NOT NULL,
    MaxKeywords INT UNSIGNED NOT NULL,
    Keywords VARCHAR(255) NOT NULL,
    Primary Key(Email_Id)
);

下面是我的添加函数中崩溃和燃烧的代码:

public boolean add(final MessageDto emailDto){
    boolean result = false;
    int rowsAffected;
    KeyHolder keyHolder = new GeneratedKeyHolder();
    final String sql;

    sql = "INSERT INTO email (Sender_Email, Recipient_Email, Subject, Body, Attachment_Path, Creation_Date, MaxKeywords, Keywords) " +
            "VALUES (?, ?, ?, ?, ?, ?, ?, ?)";

    try{
        rowsAffected = getJdbcTemplate().update(
                  new PreparedStatementCreator() {
                        public PreparedStatement createPreparedStatement(Connection connection) throws SQLException {
                            PreparedStatement statement = 
                                    connection.prepareStatement(sql, new String[] {"emailId"});

                            String[] foo = {"A","B"};

                            statement.setString(1, emailDto.getFrom());
                            statement.setString(2, emailDto.getTo());
                            statement.setString(3, emailDto.getSubject());
                            statement.setString(4, emailDto.getBody());
                            statement.setString(5, emailDto.getAttachmentPath());
                            statement.setTimestamp(6, new Timestamp(emailDto.getCreationDate().getMillis()));
                            statement.setInt(7, emailDto.getMaxKeywordCount());
                            statement.setArray(8, connection.createArrayOf("varchar", foo));

                            return statement;
                        }
                      }, keyHolder);

        if(rowsAffected > 0){
            emailDto.setEmailId(keyHolder.getKey().intValue());
            result = true;
        }
    } catch (Exception e){
        throw new RuntimeException(e);
    }

    return result;
}

抛出的错误是:

org.springframework.dao.InvalidDataAccessApiUsageException: PreparedStatementCallback; SQL []; null; nested exception is java.sql.SQLFeatureNotSupportedException

帮忙吗?

最佳答案

如果您决定放弃setArray 方法,您可以这样做。使用您自己的逻辑将数组转换为字符串。无论如何,您都将它存储在 varchar 中,因此您必须“展平”数组。

    String[] foo = {"A","B"};
    StringBuilder sb = new StringBuilder();
    for (String bar : foo) {
        sb.append(bar);
        sb.append("\t");
    }
    statement.setArray(8, sb.toString());

关于java - 添加数组时准备语句错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15559207/

相关文章:

java - bin/hadoop jar hadoop-0.20.0-examples.jar wordcount/tmp/gutenberg gutenberg-output

java - 在 wicket 中,如何创建未由组件层次结构/布局定义的 RadioGroup?

java - 将文件从本地共享复制到 Linux 本地驱动器

java - 无法使用RelativeLayout使TextView居中

mysql - 计算列中的不同值,如果在Where子句中没有找到则返回零

MySQL查询导致服务器崩溃?

sql - 这里最佳的 JOIN 方法是什么?

c - 下标值既不是数组也不是指针也不是c中的 vector

java - 在 Java 中初始化二维数组

c - C中简单的基于堆栈的机器