在 redshift jdbc 驱动程序中将结果缓存设置为关闭

Posted

技术标签:

【中文标题】在 redshift jdbc 驱动程序中将结果缓存设置为关闭【英文标题】:Set result caching to off in redshift jdbc driver 【发布时间】:2020-02-13 12:23:39 【问题描述】:

我正在对 redshift 进行性能测试。有没有办法通过 JDBC 驱动程序关闭结果缓存。我尝试将 ("enable_result_cache_for_session", "off") 作为连接属性传递,但没有成功。

【问题讨论】:

【参考方案1】:

此变量中所指的session 是单个连接发出的所有查询。该设置不适用于其他连接并且不会持续存在。

您必须在每个连接中发出SET enable_result_cache_for_session TO off;。许多基准测试工具或脚本会为它们运行的​​每个查询创建一个新连接。

更新:我忘记了您可以使用ALTER USER以持久的方式将设置分配给用户

ALTER USER master SET enable_result_cache_for_session TO off;
-- ALTER USER

\q -- << disconnect then reconnect >> 

SHOW enable_result_cache_for_session ;
--  enable_result_cache_for_session
-- ---------------------------------
--  off

【讨论】:

由于发出此查询会增加整体性能结果的时间。是否有任何数据库级别标志可以将其关闭 这需要几毫秒,并且不会在 Redshift 性能测试中增加有意义的时间。 有一种持久的方法可以改变这个我忘记了,我更新了答案。

以上是关于在 redshift jdbc 驱动程序中将结果缓存设置为关闭的主要内容,如果未能解决你的问题,请参考以下文章

将结果从 Pig 直接存储到 Redshift?

不使用 jdbc 驱动程序查询 Amazon Redshift

如何在 Redshift 中将时间戳(具有毫秒)转换为 EPOCH

在 Redshift 中将日期时间列格式化为 ISO 日期时间

如何将redshift jdbc驱动程序添加到aws lambda函数

spark和aws redshift:java.sql.SQLException:没有找到适合jdbc的驱动程序:redshift://xxx.us-west-2.redshift.amazonaws