[英]Oracle Update data in Clob datatype column
I am very new to Oracle and Clob datatype.我对 Oracle 和 Clob 数据类型非常陌生。
We have a table with name ABC which has a column of CLOB data type.我们有一个名为 ABC 的表,其中有一列 CLOB 数据类型。
The Clob Column "MyClob" has following text data: Clob 列“MyClob”具有以下文本数据:
{ "UD_1":"John", "UD_2":"Doe", "UD_3":"1011=John Doe"}
When I query the table 'ABC' using below query,当我使用以下查询查询表“ABC”时,
Select Id,
JSON_VALUE(MyClob, '$.UD_1') FirstName
JSON_VALUE(MyClob, '$.UD_2') LastName
JSON_VALUE(MyClob, '$.UD_3') Status
From Abc
I get the following table:我得到下表:
Id FirstName LastName Status
1 John Doe 1011=John Doe
2 Jack Ham 2022=Jack Ham
I want to update only the 'UD_3' value for one of the rows.我只想更新其中一行的“UD_3”值。 I am not sure how to write an update query to update the text in Clob column.
我不确定如何编写更新查询来更新 Clob 列中的文本。
You can perform updates to JSON using JSON_MERGEPATCH .您可以使用JSON_MERGEPATCH对 JSON 执行更新。 To use
JSON_MERGEPATCH
, in the second argument you will need to pass a JSON object of the key/value pairs that you want to update.要使用
JSON_MERGEPATCH
,在第二个参数中,您需要传递要更新的键/值对的 JSON object 。 See example below.请参见下面的示例。
Another item to note is that the returned value of JSON_MERGEPATCH
will remove any unnecessary spaces from the JSON.还有一点需要注意的是,JSON_MERGEPATCH 的返回值会从
JSON_MERGEPATCH
中删除任何不必要的空格。
SQL> CREATE TABLE sampletable
2 (
3 id,
4 myclob
5 )
6 AS
7 SELECT 1,
8 EMPTY_CLOB ()
9 || '{ "UD_1":"John", "UD_2":"Doe", "UD_3":"1011=John Doe"}'
10 FROM DUAL
11 UNION ALL
12 SELECT 2,
13 EMPTY_CLOB ()
14 || '{ "UD_1":"Jack", "UD_2":"Ham", "UD_3":"2022=Jack Ham"}'
15* FROM DUAL;
Table SAMPLETABLE created.
SQL> SELECT *
2 FROM sampletable t
3 CROSS JOIN
4 JSON_TABLE (
5 t.myclob,
6 '$'
7 COLUMNS (firstname VARCHAR2 PATH '$.UD_1',
8 lastname VARCHAR2 PATH '$.UD_2',
9* status VARCHAR2 PATH '$.UD_3'));
ID MYCLOB FIRSTNAME LASTNAME STATUS
_____ _________________________________________________________ ____________ ___________ ________________
1 { "UD_1":"John", "UD_2":"Doe", "UD_3":"1011=John Doe"} John Doe 1011=John Doe
2 { "UD_1":"Jack", "UD_2":"Ham", "UD_3":"2022=Jack Ham"} Jack Ham 2022=Jack Ham
SQL> UPDATE sampletable
2 SET myclob = json_mergepatch (myclob, '{"UD_3":"3033-Devp"}')
3* WHERE id = 1;
1 row updated.
SQL> commit;
Commit complete.
SQL> SELECT *
2 FROM sampletable t
3 CROSS JOIN
4 JSON_TABLE (
5 t.myclob,
6 '$'
7 COLUMNS (firstname VARCHAR2 PATH '$.UD_1',
8 lastname VARCHAR2 PATH '$.UD_2',
9* status VARCHAR2 PATH '$.UD_3'));
ID MYCLOB FIRSTNAME LASTNAME STATUS
_____ _________________________________________________________ ____________ ___________ ________________
1 {"UD_1":"John","UD_2":"Doe","UD_3":"3033-Devp"} John Doe 3033-Devp
2 { "UD_1":"Jack", "UD_2":"Ham", "UD_3":"2022=Jack Ham"} Jack Ham 2022=Jack Ham
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.