postgresql - Npgsql.PostgresException (0x80004005): XX000: 模式删除时类型 207852 的缓存查找失败
问题描述
我',运行我的测试套件并尝试使用枚举:
CREATE TYPE dockind AS ENUM ('I', 'O', 'Q');
CREATE TABLE document (
doc_id SERIAL,
doc_kind dockind NOT NULL DEFAULT 'O',
)
let openConn() =
let conStr = localConnectionString()
let conn = new NpgsqlConnection(conStr)
conn.Open()
conn :> IDbConnection
//Called after the schema is created
let initDb (conn:IDbConnection) =
let db = conn :?> NpgsqlConnection
db.TypeMapper.MapEnum<DocKind>("dockind") |> ignore
但是,我遇到了一个奇怪的错误:
Npgsql.PostgresException (0x80004005): XX000: cache lookup failed for type 207852
at Npgsql.NpgsqlConnector.<>c__DisplayClass161_0.<<ReadMessage>g__ReadMessageLong|0>d.MoveNext()
--- End of stack trace from previous location where exception was thrown ---
at Npgsql.NpgsqlConnector.<>c__DisplayClass161_0.<<ReadMessage>g__ReadMessageLong|0>d.MoveNext() in C:\projects\npgsql\src\Npgsql\NpgsqlConnector.cs:line 1032
--- End of stack trace from previous location where exception was thrown ---
at Npgsql.NpgsqlDataReader.NextResult(Boolean async, Boolean isConsuming) in C:\projects\npgsql\src\Npgsql\NpgsqlDataReader.cs:line 444
at Npgsql.NpgsqlDataReader.NextResult() in C:\projects\npgsql\src\Npgsql\NpgsqlDataReader.cs:line 332
at Npgsql.NpgsqlCommand.ExecuteDbDataReader(CommandBehavior behavior, Boolean async, CancellationToken cancellationToken) in C:\projects\npgsql\src\Npgsql\NpgsqlCommand.cs:line 1221
at Npgsql.NpgsqlCommand.ExecuteScalar(Boolean async, CancellationToken cancellationToken) in C:\projects\npgsql\src\Npgsql\NpgsqlCommand.cs:line 1086
at Npgsql.NpgsqlCommand.ExecuteScalar() in C:\projects\npgsql\src\Npgsql\NpgsqlCommand.cs:line 1063
at CoreLib.Db.queryScalar[a,b](a con, String sql, IEnumerable`1 parameters) in /Users/mamcx/Proyectos/BestSellerPOS/CoreLib/DbStore.fs:line 184
Npgsql 版本 4.0.0
这发生在我删除架构并重建它时。如果我不重建它,它会起作用。那么如何解决这个问题呢?
let createDb() =
use con = openConn()
let sql = openDbFile()
exeSql con sql |> ignore
let testDb() =
DbServer.createDb()
let db = DbServer.openConn()
DbServer.initDb(db)
我没有使用重用连接来构建数据库并执行测试。
解决方案
Npgsql 在第一次连接到给定数据库时缓存给定数据库中的所有 PostgreSQL 类型(这些类型缓存在连接字符串上)。如果您对类型进行任何更改,例如定义新类型或删除类型,则必须通过调用来告诉 Npgsql 刷新类型缓存NpgsqlConnection.ReloadTypes()
。
推荐阅读
- c++ - OpenGL Spaceship 推进器在底部不是圆形的
- flutter - 获得异常的 A RenderFlex 在颤动的底部溢出 203 像素
- arduino - Arduino Nano 程序员没有响应
- python - 在 Python 中读取 SQL 文件以通过 databricks 对 JDBC 运行
- azure - Azure PIM PowerShell 脚本
- php - Laravel 授权策略使用微风仅显示用户创建的对象
- swift - 如何在 CGRect 中添加文本标签?
- node.js - 使用 express js 未定义用户名
- django - 如何在 Django 中为 UI 创建可重用组件
- linux - 具有特定扩展名的文件名的文件路径