在开发过程中,由于功能的需求,经常需要编写较为复杂的存储过程。在以前,总是通过返回执行的结果来进行调试,非常麻烦。其实,可以使用PG下插件支持的调试功能,可以设置break point,单步调试,就象在eclipse里面调试Java code,一个很复杂的function通过这种方式很快就找出问题,大大提高开发效率。 加载plugin_debugger插件 PG默认情况下是不支持function的调试的,需要加载PG的plugin_debugger插件。具体的步骤如下: 开发环境:WIN7 + Postgresql 9.2.14
步骤1: 修改postgresql.conf文件,将 #shared_preload_libraries = '' 改成:shared_preload_libraries = '$libdir/plugin_debugger.dll'
步骤2: 重启postgressql服务,重启服务后,如果 (1)输入show shared_preload_libraries,会显示libdir\plugin_debugger.dll
步骤3: 安装pldbgapi扩展 选择需要加载调试功能的数据库; 在该数据库中,右键单击选择扩展(extensions),单击 new extension;在弹出窗口中,单击properties选项卡,在name下拉菜单选择pldbgapi单击definition选项卡,在Schema下拉菜单中,选择public;在version下拉菜单中,选择版本。点击确定。
函数调试 选择需要调试的函数 -> 右键打开菜单 -> 选择调试中 -> 选择调试 -> 打开函数参数输入界面,如下所示
输入入参后,打开调试器,可以按步进行调试了