这个提示是达梦 disql 客户端的「变量替换交互式提示符」 ,核心原因是:你的 INSERT 语句中包含 ¤tPage 字符串,而 & 是 disql 的「变量引用符号」------ disql 会把 & 开头的内容识别为「需要手动输入值的变量」,而非普通字符串,因此弹出这个提示要求你输入 currentPage 变量的值。
一、详细原因拆解
-
disql 的变量替换规则 : disql 中,
&是默认的「变量定义/引用符」(类似 Oracle SQL*Plus),作用是实现动态变量替换。比如执行SELECT &name FROM test;,disql 会提示「输入 name 的值:」,输入后替换变量再执行 SQL。 -
你的 SQL 触发了这个规则: 你的 INSERT 语句中,
REQUEST_BODY字段的值包含¤tPage(pageSize=0¤tPage=1&appId=...),disql 解析时把¤tPage当成了「待替换的变量」,而非 URL 参数里的普通&符号,因此中断 SQL 执行,要求你输入currentPage变量的值。
二、如何解决
临时关闭 disql 的变量替换功能(推荐)
在执行 INSERT 语句前,先执行 SET DEFINE OFF; 关闭「& 变量替换」,这样 disql 会把 & 当成普通字符,不再触发输入提示:
sql
-- 第一步:关闭变量替换(仅当前会话生效)
SQL> SET DEFINE OFF;
-- 第二步:重新执行你的 INSERT 语句(此时¤tPage会被当成普通字符串)
SQL> INSERT INTO "ADMIN_DEMO"."T_SYS_LOG"("ID",...,"REQUEST_BODY",...)
VALUES(1996220375130296321,'10.233.90.171',..., 'pageSize=0¤tPage=1&appId=...',...);