zb2*_*226 11 sql postgresql squirrel-sql plpgsql
我有一个PostgreSQL 9.3.4数据库的以下函数定义:
CREATE OR REPLACE FUNCTION update_modified_timestamp()
RETURNS TRIGGER AS $$
BEGIN
NEW.modified_at = now();
RETURN NEW;
END;
$$ LANGUAGE plpgsql;
Run Code Online (Sandbox Code Playgroud)
当我尝试在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
Run Code Online (Sandbox Code Playgroud)
到目前为止,我已经了解到这可以通过使用单引号来分隔函数体来缓解:
CREATE OR REPLACE FUNCTION update_modified_timestamp()
RETURNS TRIGGER AS '
BEGIN
NEW.modified_at = now();
RETURN NEW;
END;
' LANGUAGE plpgsql;
Run Code Online (Sandbox Code Playgroud)
我仍然想知道这是否无法解决 - 我认为必须有可能,因为Flyway可以执行此脚本并且它使用在SQuirreL中配置的完全相同的JDBC驱动程序.
更新: @a_horse_with_no_name指出此错误与JDBC驱动程序无关,而是与SQuirreL如何解析SQL语句并在将它们发送到数据库之前将其拆分为块.因此剩下的问题是:SQuirreL可以发送原始/未解析的查询吗?我搜索了很多,找不到办法做到这一点.
rub*_*nsa 10
您可以更改语句分隔符,以便语句不会拆分为;:
转至:会话 → 会话属性 → SQL → 语句分隔符
即使您无法将其更改为空字符串,也可以将其更改为例如//,这样可以在问题中执行语句.
| 归档时间: |
|
| 查看次数: |
5572 次 |
| 最近记录: |