- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
使用 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
,这是有道理的。
但是,您仍然可以通过自己编写数据转换来进行迁移,从 smallint
到 bytea
。为此,编辑生成的迁移,找到 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);
如果您现有的列碰巧包含多个字节(对您来说应该不是问题),它应该被截断。显然要仔细测试由此产生的数据。
关于entity-framework - Npgsql.PostgresException : Column cannot be cast automatically to type bytea 异常,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52462902/
我有一个 cmd.ExecuteReader() 的问题,我得到一个 Npgsql.PostgresException public void connectDB() {
当我尝试从 asp.net web api 插入用户时出现以下异常:Microsoft.EntityFrameworkCore.DbUpdateException:更新条目时出错。有关详细信息,请参阅
我有以下 SQL 查询: select distinct "Customers"."CustomerId" as "CustomerId", "Custo
使用 EF-Core for PostgresSQL,我有一个字段类型为 byte 的实体,但我决定将其更改为类型 byte[]。但是当我进行迁移时,在应用生成的迁移文件时,它引发了以下异常: Npg
我',运行我的测试套件并尝试使用枚举: CREATE TYPE dockind AS ENUM ('I', 'O', 'Q'); CREATE TABLE document ( doc_id
我使用 NLog 登录到 PostrgeSQL 数据库。 我创建了表格: CREATE TABLE "Data"."Logs" ( "ID" serial primary key, "
我使用 NLog 登录到 PostrgeSQL 数据库。 我创建了表格: CREATE TABLE "Data"."Logs" ( "ID" serial primary key, "
我在 Azure 上有一个用于测试目的的 postgresql 数据库。直到昨天为止都运行良好。它开始给出错误,例如 PostgresException: 28000: no pg_hba.conf
我是一名优秀的程序员,十分优秀!