SQuirreL中的PostgreSQL函数定义:未终止的美元引用字符串
发布时间:2020-12-13 16:14:29 所属栏目:百科 来源:网络整理
导读:我有一个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)中执行此操作时,我
我有一个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→语句分隔符 即使您无法将其更改为空字符串,也可以将其更改为例如//,这样可以在问题中执行语句. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |