微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

PostgreSQL完全刷缓存补丁

本文及其附件以Postgresql协议发布

曾经有朋友问过如何把缓存清空,没有这个功能,测试的时候非常不方便。

我做了一个补丁抛砖引玉,见附件。

提供两个sql命令,尽量兼容Oracle:

1、ALTER SYstem CHECKPOINT;
这个其实就是将 CHECKPOINT 封装到一个新语法,没什么改动。
2、ALTER SYstem FLUSH SHARED_BUFFER / BUFFER_CACHE;
清空数据库缓存,将发生修改的数据刷到硬盘,脏块写出功能仍然是调用PG核心代码

主要说明
1、语法是由Flex和Bison(Yacc)完成解析,请自行查阅它们的文档。
2、SYstem关键字由非保留改为保留
3、增加非保留关键字 FLUSH
4、SHARED_BUFFER 和 BUFFER_CACHE 并没有定义成关键字,而是用字符串比较
5、GANQI_VERSION是我自己定义的工程名,用的删掉或者在编译环境设定为1即可
6、仅经过简单测试,我个人无法保证代码安全,不要用在生产环境

不会发附件,用外部链接
http://bbs.pgsqldb.com/client/read.php?action=cy_download_click&post_fj_auto_bh=4460

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐