SQuirreL中的PostgreSQL函数定义:未终止的美元引用字符串

我有一个Postgresql 9.3.4数据库的以下函数定义:
CREATE OR REPLACE FUNCTION update_modified_timestamp()  
RETURNS TRIGGER AS $$
  BEGIN
    NEW.modified_at = Now();
    RETURN NEW; 
  END;
$$LANGUAGE plpgsql;

当我尝试在SQuirreL(3.5.3或3.6)中执行此操作时,我收到以下错误

Error: ERROR: unterminated dollar-quoted string at or near "$$
 BEGIN
     NEW.modified_at = Now()"
  Position: 77
sqlState:  42601
ErrorCode: 0

到目前为止,我已经学会了这个can be mitigated by using single quotes来划分函数体,就像这样:

CREATE OR REPLACE FUNCTION update_modified_timestamp()  
RETURNS TRIGGER AS '
  BEGIN
    NEW.modified_at = Now();
    RETURN NEW; 
  END;
' LANGUAGE plpgsql;

我仍然想知道这是否无法解决 – 我认为必须可行,因为Flyway可以执行此脚本并且它使用在SQuirreL中配置的完全相同的JDBC驱动程序.

更新:@a_horse_with_no_name指出此错误与JDBC驱动程序无关,而是与SQuirreL如何解析sql语句并在将它们发送到数据库之前将其拆分为块.因此剩下的问题是:SQuirreL可以发送原始/未解析的查询吗?我搜索了很多,找不到办法做到这一点.

您可以更改语句分隔符,以便不将语句拆分为;:

转至:会话→会话属性sql→语句分隔符

即使您无法将其更改为空字符串,也可以将其更改为例如//,这样可以在问题中执行语句.

相关文章

项目需要,有个数据需要导入,拿到手一开始以为是mysql,结果...
本文小编为大家详细介绍“怎么查看PostgreSQL数据库中所有表...
错误现象问题原因这是在远程连接时pg_hba.conf文件没有配置正...
因本地资源有限,在公共测试环境搭建了PGsql环境,从数据库本...
wamp 环境 这个提示就是说你的版本低于10了。 先打印ph...
psycopg2.OperationalError: SSL SYSCALL error: EOF detect...