Npgsql.PostgresException: 无法将列自动转换为类型 bytea

Npgsql.PostgresException: Column cannot be cast automatically to type bytea

使用 EF-Core for PostgresSQL,我有一个字段类型为 byte 的实体,但我决定将其更改为类型 byte[]。但是当我进行迁移时,在应用生成的迁移文件时,它引发了以下异常:

Npgsql.PostgresException (0x80004005): 42804: column "Logo" cannot be cast automatically to type bytea

我在互联网上搜索了解决方案,但我看到的都是其他数据类型的类似问题,而不是字节数组。请帮忙。

错误准确说明了正在发生的事情...在某些情况下,PostgreSQL 允许更改列类型(例如 int -> bigint),但在许多情况下,这种更改是非-微不足道或具有潜在破坏性,它拒绝自动这样做。在这种特定情况下,发生这种情况是因为 Npgsql 将您的 CLR 字节字段映射为 PostgreSQL smallint(2 字节字段),因为 PostgreSQL 缺少 1 字节数据字段。所以 PostgreSQL 拒绝从 smallint 转换为 bytea,这是有道理的。

但是,您仍然可以通过自己编写数据转换来进行迁移,从 smallintbytea。为此,编辑生成的迁移,找到 ALTER COLUMN ... ALTER TYPE 语句并添加 USING 子句。 As the PostgreSQL docs say,这允许您根据现有列(甚至其他列)为列提供新值。专门用于将 int(或 smallint)转换为 bytea,使用以下命令:

ALTER TABLE tab ALTER COLUMN col TYPE BYTEA USING set_bytea(E'0', 0, col);

如果您现有的列恰好包含一个以上的字节(对您来说应该不是问题),它应该被截断。显然仔细测试由此产生的数据。