1

在 Postgres 中使用准备好的语句时,我有一些查询要慢得多(这是一个已知问题,请参阅http://www.postgresql.org/docs/current/static/sql-prepare.html)。因此,我想关闭这些查询的语句准备。

在 DBIx::Class 中,我可以在连接到数据库时通过在 connect_info 中传递参数“pg_server_prepare => 0”来全局关闭准备好的语句。但我看不到如何为现有连接更改此设置。给定一个 DBIx::Class::Schema,我试过这个:

$schema->storage->connect_info->[0]->{'pg_server_prepare'} = 0;

如果我在那个调用之后记录 connect_info,我会看到这个参数的新值,但是数据库驱动程序仍然使用准备好的语句。我也尝试断开连接并重新连接

$schema->storage->connect_info->[0]->{'pg_server_prepare'} = 0;
$schema->storage->disconnect;
$schema->connect(@{ $schema->storage->connect_info->[0] });

但这也无济于事。

有任何想法吗?

4

1 回答 1

1

我没有使用 DBD::Pg,所以我不能肯定地说,但这 - 可能 - 工作:

$schema->storage->dbh_do(sub {
    my (undef, $dbh) = @_;
    local $dbh->{pg_server_prepare} = 0;
    # now do anything with $dbh you want
});
于 2011-10-25T14:52:47.207 回答