我有一个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可以发送原始/未解析的查询吗?我搜索了很多,找不到办法做到这一点.
原文地址:https://www.jb51.cc/postgresql/191928.html
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。