disql 会提示「输入 xxx 的值:」

这个提示是达梦 disql 客户端的「变量替换交互式提示符」 ,核心原因是:你的 INSERT 语句中包含 &currentPage 字符串,而 & 是 disql 的「变量引用符号」------ disql 会把 & 开头的内容识别为「需要手动输入值的变量」,而非普通字符串,因此弹出这个提示要求你输入 currentPage 变量的值。

一、详细原因拆解

  1. disql 的变量替换规则 : disql 中,& 是默认的「变量定义/引用符」(类似 Oracle SQL*Plus),作用是实现动态变量替换。比如执行 SELECT &name FROM test;,disql 会提示「输入 name 的值:」,输入后替换变量再执行 SQL。

  2. 你的 SQL 触发了这个规则: 你的 INSERT 语句中,REQUEST_BODY 字段的值包含 &currentPagepageSize=0&currentPage=1&appId=...),disql 解析时把 &currentPage 当成了「待替换的变量」,而非 URL 参数里的普通 & 符号,因此中断 SQL 执行,要求你输入 currentPage 变量的值。

二、如何解决

临时关闭 disql 的变量替换功能(推荐)

在执行 INSERT 语句前,先执行 SET DEFINE OFF; 关闭「& 变量替换」,这样 disql 会把 & 当成普通字符,不再触发输入提示:

sql 复制代码
-- 第一步:关闭变量替换(仅当前会话生效)
SQL> SET DEFINE OFF;

-- 第二步:重新执行你的 INSERT 语句(此时&currentPage会被当成普通字符串)
SQL> INSERT INTO "ADMIN_DEMO"."T_SYS_LOG"("ID",...,"REQUEST_BODY",...) 
VALUES(1996220375130296321,'10.233.90.171',..., 'pageSize=0&currentPage=1&appId=...',...);
相关推荐
Oneslide2 小时前
达梦数据库开启自动提交
后端
锦木烁光2 小时前
从零构建工业级流水号引擎:Spring Boot 2.7 + Redis 原子递增 + AntD Pro 全栈实战
后端
jolimark2 小时前
Spring Boot 集成 Kettle
java·spring boot·后端
用户7344028193422 小时前
Spring Boot使用@Async实现异步调用:ThreadPoolTaskScheduler线程池的优雅关闭
后端
sthnyph2 小时前
Spring Framework 中文官方文档
java·后端·spring
zb200641202 小时前
Spring Boot 实战篇(四):实现用户登录与注册功能
java·spring boot·后端
青柠代码录3 小时前
【MySQL】事务:事务的隔离级别
后端
分享牛3 小时前
Operaton入门到精通22-Operaton 2.0 升级指南:Spring Boot 4 核心变更详解
java·spring boot·后端
jinanmichael3 小时前
SpringBoot 如何调用 WebService 接口
java·spring boot·后端