- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我有一个使用 Postgres 数据库的 Java 应用程序,我正在尝试引入 PPGool 以扩展我的数据库。我遇到了 Postgres 抛出以下错误的问题:未命名的准备语句不存在
。在启动 Postgres 上的日志记录后,我看到我的应用程序执行的每个选择语句都发生了以下情况:
EDTLOG: 00000: duration: 7.585 ms parse <unnamed>: "my select statement here"
EDTLOG: 00000: duration: 0.088 ms bind <unnamed>: "my select statement here"
EDTLOG: 00000: duration: 79.014 ms execute <unnamed>: "my select statement here"
但有时,在解析/绑定(bind)/执行步骤之间,PGPool 会执行一些额外的查询,因此日志如下所示:
EDTLOG: 00000: duration: 7.585 ms parse <unnamed>: "my select statement here"
EDTLOG: 00000: duration: 0.088 ms bind <unnamed>: "my select statement here"
EDTLOG: 00000: duration: 0.328 ms statement: SELECT count(*) FROM pg_class AS c, pg_namespace AS n WHERE c.relname = 'my_table' AND c.relnamespace = n.oid AND n.nspname = 'pg_catalog'
EDTLOG: 00000: duration: 79.014 ms execute <unnamed>: "my select statement here"
EDTERROR: 26000: unnamed prepared statement does not exist
EDTLOG: 00000: duration: 0.022 ms parse S_2: ROLLBACK
EDTLOG: 00000: duration: 0.005 ms bind S_2: ROLLBACK
EDTLOG: 00000: duration: 0.008 ms execute S_2: ROLLBACK
据我所知,因为查询是未命名的,如果在执行未命名查询之前在该数据库 session 期间出现另一个查询,它会被 Postgres 丢弃。因此,由于 PGPool 有时会在解析/绑定(bind)/执行步骤之间发出这些额外的查询,这会导致查询被丢弃。
我的第一个想法是,也许我的 Java 应用程序不需要为每个查询发送解析/绑定(bind)/执行语句。但看起来这是自 JDBC 版本 3 和 Postgres 7.4 以来 Postgres JDBC 驱动程序的默认行为 http://jdbc.postgresql.org/documentation/head/server-prepare.html .我想我可以尝试完全禁用服务器端准备好的语句,但文档没有具体说明如何做到这一点,而且我不确定这是否是我想要做的事情。
我的第二个想法是让 PGPool II 停止发送那些元数据查询。由于我只是想将 PGPool 用作负载平衡器,所以我真的不明白为什么它需要了解我的表元数据的所有信息。我在此处的 PPGool 源的 is_system_catalog 方法中追踪了执行这些查询的代码:https://github.com/iakio/pgpool-II/blob/master/pool_select_walker.c#L256似乎 PGPool 出于某种原因想要了解我的表关系,不幸的是我没有看到任何禁用该行为的方法。
任何有关如何解决此问题的见解都将不胜感激。
关于我的环境的一些信息:
JDBC Driver: postgresql-9.1-901.jdbc4.jar
Java version "1.6.0_31"
Spring 3.1 managed JPA
Hibernate 3.5
Postgres 9.1
更新:我找到了解决该问题的方法。通过在 JDBC URL 中放置 protocolVersion=2
,它基本上告诉 Postgres JDBC 驱动程序不要使用服务器端准备好的语句。这允许我的应用程序在我的数据库前使用 PGPool II 时运行。不过,我不得不回退到 JDBC 版本 2 协议(protocol)才能使用 PPGool,这让我很困扰。
最佳答案
我找到了解决该问题的方法。通过在 JDBC URL 中放置 protocolVersion=2 它基本上告诉 Postgres JDBC 驱动程序不要使用服务器端准备好的语句。这允许我的应用程序在我的数据库前使用 PGPool II 时运行。不过,我不得不回退到 JDBC 版本 2 协议(protocol)才能使用 PPGool,这让我很困扰。
关于针对 PPGool II 的 Java 查询导致 "unnamed prepared statement does not exist"错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9725018/
在 go lang 中使用“If with a short statement”有什么好处。引用:go tour if v := math.Pow(x, n); v < lim { retur
完全错误: Warning: Unsafe statement written to the binary log using statement format since BINLOG_FORMAT
完全错误: Warning: Unsafe statement written to the binary log using statement format since BINLOG_FORMAT
我有三个存储过程 Sp1、Sp2 和 Sp3。 第一个 (Sp1) 将执行第二个 (Sp2) 并将返回的数据保存到 @tempTB1 中,第二个将执行第三个 (Sp3) 并将数据保存到 @tempTB
我已将 FLAG 设置为 1,并且正在执行 ARG 值应该仅为 DEV。但是我得到的是 ARG= DEV + CLIENTID 000023 // FLAG=1 000026 // I
我已将 FLAG 设置为 1,并且正在执行 ARG 值应该仅为 DEV。但是我得到的是 ARG= DEV + CLIENTID 000023 // FLAG=1 000026 // I
已关闭。这个问题是 not reproducible or was caused by typos 。目前不接受答案。 这个问题是由拼写错误或无法再重现的问题引起的。虽然类似的问题可能是 on-top
PMD告诉我 A switch with less than 3 branches is inefficient, use a if statement instead. 这是为什么呢?为什么是3?他
我刚开始学习 Racket,所以我仍在努力弄清楚这门语言的复杂性。我正在尝试在列表中实现我自己的搜索功能。如果函数找到它,则返回索引,否则返回 -1。 (define (find-index list
在 Kotlin 中,您可以使用类似于三元运算符的 if 语句。 我们可以选择做这样的事情: val x = if (isOdd) 1 else 2 但是如果我们有多个变量需要根据某些条件进行设置,那
在我的 Android 应用程序中,我尝试使用 XMLPullParser 使用以下代码读取 xml 文件: while (eventType != XmlPullParser.END_DOCUMEN
这个问题已经有答案了: Boolean expressions in Java (8 个回答) 已关闭 7 年前。 我遇到过一些情况,其中第一个似乎改变了 boolean 值,而第二个却没有!两者之间
我基本上想做的是: select * from request where id = 1 and created_at like (today's date); 但使用 Eloquent 。 我试过:
我不确定为什么会收到此代码。基本上我希望能够动态定位我的发射器,但是当我添加一个选项来检查位置并根据需要进行纠正时,我不断收到此错误。 添加的代码是 if (
何时使用语句而不是准备语句。我想语句用于没有参数的查询,但为什么不使用准备好的语句呢?对于没有参数的查询,哪个更快。 最佳答案 I suppose statement is used in queri
我必须创建一个表,如下所示 借款人(客户编号,贷款编号) 如果客户没有超过 3 笔贷款,则可以贷款。 我创建的表如下 create table borrower( customerno int(5),
这个问题在这里已经有了答案: 关闭 12 年前。 Possible Duplicates: Is "else if" faster than "switch() case"? What is the
typescript 版本 2.2.2 我在我的 UserRoutzr.ts 中写了这个要求 const users = require(path.join(process.cwd() + "/da
我有一个用 JPQL 编写的应用程序,它可以命中非常不同的查询(在不同的资源上)。 对于很多此类查询,我需要知道结果总数(计数),因为我没有应用任何 LIMIT/OFFSET 由于此查询的性质非常不同
我对以下 Java 语句感到困惑: ArtClass artClass0 = new ArtClass(); int int3 = 73; boolean boolean0 = artClass0.f
我是一名优秀的程序员,十分优秀!