19

我有一些自定义类型。它们基本上都是枚举。以下是它们的外观示例:

CREATE TYPE card_suit AS ENUM
   ('spades',
    'clubs',
    'hearts',
    'diamonds');

我在 Java 中有一些准备好的语句,看起来像这样:

// Setup stuff up here.
sql = "INSERT INTO foo (suit) VALUES (?)";
st.setString(1, 'spades');
st.executeUpdate(sql);

Java 给了我一些像这样的讨厌的异常:

org.postgresql.util.PSQLException: ERROR: column "suit" is of type card_suit but expression is of type character varying
Hint: You will need to rewrite or cast the expression.

他们很高兴给我一个提示,但我不确定如何遵循它。

4

2 回答 2

27

您是否尝试将列转换为枚举?

// Setup stuff up here.
sql = "INSERT INTO foo (suit) VALUES (?::card_suit)";
st.setString(1, 'spades');
st.executeUpdate(sql);

在“网络编码博客”的Java 枚举和 PostgreSQL 枚举之间的转换文章中进行了解释,并附有示例:

INSERT INTO pet (pet_id, pet_type, name) 
         VALUES (?, CAST(? AS animal_type), ?);

--or

INSERT INTO pet (pet_id, pet_type, name) 
         VALUES (?, ?::animal_type, ?);
于 2012-05-13T12:54:26.517 回答
0

另一种方法是

st.setObject(1, 'spades', Types.OTHER);
于 2020-03-17T15:56:07.507 回答