哈哈哈啊哈哈123 2022-08-19 20:06 采纳率: 80%
浏览 26
已结题

关于存储过程 使用变量拼接SQL语句

DECLARE
V_ID NUMBER :=2 ;
V_SQL VARCHAR2(2000);
V_SQL_TEXT VARCHAR2(2000);
BEGIN
SELECT SQL_TEXT INTO V_SQL_TEXT FROM BI_TEST WHERE ID =8;
V_SQL :='INSERT INTO BI_VALUE (ID,K_VALUE) '|| V_SQL_TEXT;
EXECUTE IMMEDIATE V_SQL;
END;

img

从BI_TEST表中查询出的SQL_TEXT的SQL语句中,想用到 V_ID 这个变量,上面的内容,或者这条SQL语句该怎么改?

  • 写回答

1条回答 默认 最新

  • WEB届的阿猫阿狗 2022-08-19 20:28
    关注

    可以使用替换

    -- BI_TEST表中的SQL
    INSERT INTO BI_TEST VALUES (8,'SELECT {vId} V_ID,15 K_VALUE FROM DUAL')
    
    -- 存储过程中进行变量替换
    V_SQL :='INSERT INTO BI_VALUE (ID,K_VALUE) '|| REPLACE('V_SQL_TEXT', '{vId}' ,V_ID);
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录

报告相同问题?

问题事件

  • 系统已结题 8月27日
  • 已采纳回答 8月19日
  • 创建了问题 8月19日

悬赏问题

  • ¥15 51单片机怎么把每次输入键值保存到数组作为我的确认键的判断条件呢
  • ¥30 easy photo不能使用,求帮助
  • ¥15 c语言字符串单词入门问题报错
  • ¥30 我现在是双非人工智能专业不知道要不要转到软件工程专业
  • ¥15 请问12脉波整流机组的外特性曲线具体是如何推导
  • ¥15 abaqus里的python算法
  • ¥100 如何在思科模拟器中进入CEF模式
  • ¥15 Simulink 仿真如何使用MATLAB function模块获取到仿真过程中某一仿真时刻输入到模块的函数的值?
  • ¥50 关于#微信小程序#的问题:微信小程序支持h5实现webrtc h264 h265低延迟传输渲染,能付费帮我们解决一下吗
  • ¥20 请问ansys License manager 这个问题如何解决