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=...',...);
相关推荐
小码哥_常14 小时前
MyBatis-Plus:让数据库操作飞起来的神器
后端
2301_8112743115 小时前
基于SpringBoot的智能家居管理系统
spring boot·后端·智能家居
AI人工智能+电脑小能手15 小时前
【大白话说Java面试题】【Java基础篇】第15题:JDK1.7中HashMap扩容为什么会发生死循环?如何解决
java·开发语言·数据结构·后端·面试·哈希算法
舒一笑15 小时前
我把设备指纹生成逻辑拆开了:它到底凭什么区分不同设备?
后端·程序员·掘金技术征文
Nicander16 小时前
多数据源下@transcation事务踩坑
java·后端
郑州光合科技余经理16 小时前
同城O2O海外版二次开发实战:从支付网关到配送算法
开发语言·前端·后端·算法·架构·uni-app·php
sjsjsbbsbsn17 小时前
大模型核心知识总结
java·人工智能·后端
Moment17 小时前
2026 年,AI 全栈时代到了,前端简历别再只写前端技术了 🫠🫠🫠
前端·后端·面试
白晨并不是很能熬夜18 小时前
【PRC】第 2 篇:Netty 通信层 — NIO 模型 + 自定义协议 + 心跳
java·开发语言·后端·面试·rpc·php·nio
zshs00018 小时前
#从偶发无字幕到补偿探测链路:一次 B 站字幕导入问题的完整收敛过程
java·后端·重构