我正在尝试使用最新版本的 r2dbc-postgresql (0.8.4) 中的 EnumCodec 失败,我想知道您是否可以帮助我。
我也使用 spring-data-r2dbc 1.1.1 版。
我从 GitHub 中获取了确切的示例,并在我的 Postgres 中创建了一个枚举类型“my_enum”,以及一个包含“name”(文本)和“value”(my_enum)的表“sample_table”。
然后我按照示例进行操作:
SQL:
CREATE TYPE my_enum AS ENUM ('FIRST', 'SECOND');
Java模型:
enum MyEnumType {
FIRST, SECOND;
}
编解码器注册:
PostgresqlConnectionConfiguration.builder()
.codecRegistrar(EnumCodec.builder().withEnum("my_enum", MyEnumType.class).build());
我使用 DatabaseClient 来与数据库通信。我尝试使用 2 种方法插入:
databaseClient.insert().into(SampleTable.class)
.using(sampleTable).fetch().rowsUpdated();
或者:
databaseClient.insert().into("sample_table")
.value("name", sampleTable.getName())
.value("value", sampleTable.getValue())
.then();
其中 SampleTable 是:
@Data
@AllArgsConstructor
@NoArgsConstructor
@Builder
@Table("sample_table")
@JsonIgnoreProperties(ignoreUnknown = true)
@JsonInclude(JsonInclude.Include.NON_NULL)
public class SampleTable implements Serializable {
private String name;
@Column("value")
@JsonProperty("value")
private MyEnumType value;
}
但是我同时使用这两种方法得到了同样的错误:
列“值”的类型为 my_enum,但表达式的类型为字符变化
你能帮我理解我做错了什么,或者让我参考一些工作示例吗?我感谢您的帮助!