動態SQL+變量綁定:解決ORA-01704: 字符串文字太長的問題

最近在做一個ESB項目,有一個trigger里面執行動態SQL的時候報錯:

ORA-01704: 字符串文字太長

經檢查發現SQL里面有個字段是clob類型,內容長度4009,在oracle里面,

一對引號內的字符長度如果超過4000,就會報ORA-01704: 字符串文字太長的錯誤;

在網上查了一下資料,有大神提出了解決的方法:動態SQL+變量綁定:

什么是動態SQL、什么是變量綁定,度娘上有很多資料,這里就不解釋了

下面例子測試通過了:

EXECUTE IMMEDIATE 'insert into '||V_ROW.t_id||' VALUES(:1,:2,:3,:4,:5)'
???????????????? ?? USING V_1, V_2, V_3, V_4, V_CLOB;

上面的:1,:2,:3,:4,:5就是綁定變量,using后面的幾個變量就是和上面的幾個綁定變量一一對應;

最后一個變量V_CLOB是一個內容長度超過4000的clob類型變量;

如果寫成這樣:會報ORA-01704: 字符串文字太長的錯誤;

EXECUTE IMMEDIATE 'insert into '||V_ROW.t_id

?????????? ||' VALUES('''||REPLACE(V_1,'''','''''')
????????????????????? ||''','''||REPLACE(V_2,'''','''''')
????????????????????? ||''','''||REPLACE(V_3,'''','''''')
????????????????????? ||''','''||REPLACE(V_4,'''','''''')
????????????????????? ||''','''||V_CLOB
????????????????????? ||''')';

上面對分隔符做了處理,不做多解釋,這里V_CLOB變量,內容超過4000長,所以會報錯字符串太長

?

轉載于:https://www.cnblogs.com/hglh1287/p/5590947.html

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/372794.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/372794.shtml
英文地址,請注明出處:http://en.pswp.cn/news/372794.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

JavaME:Google靜態地圖API

無論您是需要基于位置的應用程序的地圖還是只是出于娛樂目的,都可以使用有史以來最簡單的方法:Google Static Maps API。 在這篇文章中,我們將看到如何從緯度和經度獲得地圖作為圖像。 可以使用Location API獲得緯度和經度,我們將…

在ASP.NET中實現OAuth2.0(一)之了解OAuth

1、什么是OAuth2.0 是一個開放授權標準,允許用戶讓第三方應用訪問該用戶在某一個網站或平臺上的私密資源(如照片、視頻、聯系人等),而無須將用戶名和密碼提供給第三方應用 2、OAuth2.0授權模式 授權碼模式(authorizati…

mysql日期條件如何應用_MySQL如何使用時間作為判斷條件

背景:在開發過程中,我們經常需要根據時間作為判斷條件來查詢數據,例如:當月,當日,當前小時,幾天內......1. 當月我們只需要使用一個mysql的month(date)函數即可實現。(注意判斷年份)month(date)…

深入探討JS中的數組排序函數sort()和reverse()

最近在研究Javascript發現了其中一些比較靈異的事情。有點讓人感到無語比如: alert(typeof( NaN NaN));//結果為假。 alert(typeof( NaN ! NaN));//結果為真。 嘿嘿,當然這個不是這篇文章要討論的!!開始我們的正文 首先,我們來看一下JS中sor…

帶有謂詞的Java中的功能樣式-第1部分

您一直在聽到將要席卷全球的函數式編程,而您仍然堅持使用普通Java? 不用擔心,因為您已經可以在日常Java中添加一些功能樣式。 此外,它很有趣,可以節省許多代碼行并減少錯誤。 什么是謂詞? 實際上&#xff…

寶塔添加多占點_寶塔面板啟用WordPress多站點子域名、子目錄

其實在很早以前,陌小雨就聽說了 wordpress 的多站點功能,不過因為不清楚,所以懶得折騰,這不這幾天閑著蛋疼,好好研究了下這玩意,用起來的感覺還是相當不錯的,總結起來就是如果你準備開始用 word…

centos 6.5下安裝文件上傳下載服務

centos 6.5下安裝文件上傳下載服務 由于每次在CentOS中要下載一些配置文件到物理機,和上傳一些文件到服務器,導致來回的開啟ftp軟件有點麻煩,這里我們可以使用文件上傳下載服務,來解決上傳和下載的問題。 1.登錄服務器 2.執行命令…

Jenkins 入門系列--jenkins 介紹

第一章 Jenkins是什么? Jenkins 是一個可擴展的持續集成引擎。 主要用于: l 持續、自動地構建/測試軟件項目。 l 監控一些定時執行的任務。Jenkins擁有的特性包括: l 易于安裝-只要把jenkins.war部署到servlet容器,不需要數據庫支…

在方法參數上使用final關鍵字

經過一些自己的混淆,最終博客方法的具體含義(最終聲明的方法參數)將對此博客條目進行澄清。 至少可以將方法參數上的final關鍵字視為Java編譯器的指示符,表明該參數不能重新分配給另一個引用。 Java參數處理始終是“按值調用” &a…

PHP MySQLi 增刪改查

最近幾天,我們一直在學習利用MySQLi訪問數據庫并對其中的數據進行操作。今天給大家展現一個完整的例子,我們來制作一個新聞發布系統,利用MySQLi來操作數據庫,實現對新聞的添加、修改、刪除、查詢等基本功能。(以下代碼…

20162303《程序設計與數據結構》第一周學習總結

學號 2016-2017-2 《程序設計與數據結構》第1周學習總結 教材學習內容總結 本周學習了基本的JAVA知識,雖然比較基礎,但是在實際過程中還是出現了許許多多的問題,代碼一遍遍的敲錯,又一遍遍的修改,剛開始甚至不會切換模…

Java EE與NoSQL的未來

自一段時間以來,我一直在關注NoSQL的近期發展勢頭,似乎這個流行語也引起了企業Java界的某種關注。 即EclipseLink 2.4開始支持MongoDB和Oracle NoSQL 。 將EclipseLink作為JPA參考實現,您可能想知道這對Java EE 7意味著什么。這里簡短說明&am…

【C/C++開發】C語言實現函數可變參數

函數原型: int printf(const char *format[,argument]...) 返 回 值: 成功則返回實際輸出的字符數,失敗返回-1. 函數說明: 在printf()函數中,format后面的參數個數不確定,且類型也不確定,這些參數都存放在棧內.調用…

java postgresql json_java – 將PostgreSQL JSON列映射到Hibernate值類...

See PgJDBC bug #265.PostgreSQL對數據類型轉換過于嚴格,非常嚴格.它不會隱式地將文本轉換為類似文本的值,例如xml和json.解決此問題的嚴格正確方法是編寫使用JDBC setObject方法的自定義Hibernate映射類型.這可能有點麻煩,所以你可能只想通過創建一個較弱的強制轉換來使Postgr…

面向接口編程詳解(三)——模式研究

通過前面兩篇,我想各位朋友對“面向接口編程”的思想有了一定認識,并通過第二篇的例子,獲得了一定的直觀印象。但是,第二篇中的例子旨在展示面向接口編程的實現方法,比較簡單,不能體現出面向接口編程的優勢…

錯誤學習:Java + OSGi

最近,我致力于在OSGi環境中使Apache Hive工作。 雖然沒有被證明是小菜一碟(軟件對嗎?。。為什么我不感到驚訝? ),它引導我解決了各種Java和OSGi錯誤。 在這里,我列出了其中一些讓我有些吃力的東…

iOS多Targets管理

序言: 個人不善于寫東西,就直奔主題了。 其實今天會注意到多targets這個東西,是因為在學習一個第三方庫FBMemoryProfiler的時候,用到了,所以就搜索了一些相關資料,就在這里記錄一下。 可能每個人都會遇到這…

優化的34條定律

1.Minimize HTTP Requests 減少HTTP請求 圖片、css、script、flash等等這些都會增加http請求數,減少這些元素的數量就能減少響應時間。把多個JS、CSS在可能的情況下寫進一個文件,頁面里直接寫入圖片也是不好的做法,應該寫進CSS里,…

休眠提示:排序和排序

讓我們介紹另一個休眠性能提示。 你還記得以前的休眠的模式后 ? 我們有一個與一對多協會有關的星際飛船和軍官。 Entity public class Starship {Id GeneratedValue(strategyGenerationType.SEQUENCE) private Long id;public Long getId() {return id;}protected v…

java 基本類型 線程安全_java的基本類型和i++線程安全性的深入解析

在java中,除了long和double的8個字節、64位比特的變量外,其他的基本變量都是原子性的。java存儲模型要求獲取和存儲操作都為原子性,但是對于非volatile的long和double變量,jvm允許將64位的讀或寫劃分為兩個32位的操作。如果讀和寫…