0

我有一张像下面这样的表(表名 IDN_CONSUMERS),

| USER_ID | USERNAME  |
| 001A    | ABC/Anne  |
| 034K    | ABC/John  |
| DF23    | ABC/Peter |

我需要删除所有用户名的 ABC/ 部分并将修改后的值放回表中,所以最终结果应该是这样的,

| USER_ID | USERNAME |
| 001A    | Anne     |
| 034K    | John     |
| DF23    | Peter    |

我尝试了以下脚本,但由于我不明白的原因它不起作用。谁能帮我解决这个问题?

DECLARE 
NEWUSERNAME VARCHAR2(512);

BEGIN

FOR ID IN (SELECT USER_ID FROM IDN_CONSUMERS) LOOP

SELECT SUBSTR((SELECT USERNAME FROM IDN_CONSUMERS WHERE USER_ID='||ID||'), 4) INTO NEWUSERNAME FROM DUAL;

UPDATE IDN_CONSUMERS SET USERNAME='||NEWUSERNAME||' WHERE USER_ID='||ID||';

END LOOP;

END;
4

2 回答 2

2

更通用的解决方案,使用REGEXP_REPLACE

UPDATE idn_consumers
   SET username = REGEXP_REPLACE(username, '.*/');

这确实假设用户名字段中只有一个“/”字符。它不假定要删除的字符串总是 4 个字符长,或者它们的长度都相同。

如果您的数据可以包含多个“/”,您可以使用:

UPDATE idn_consumers
   SET username = REGEXP_REPLACE(username, '[^/]*/','',1,1);

例如:

SQL> SELECT REGEXP_REPLACE('ABC/An/ne', '[^/]*/','',1,1) new_name FROM dual;

NEW_NAME
--------
An/ne
于 2013-09-16T19:19:26.530 回答
2

无需编写循环或单独存储新的用户名值。

UPDATE IDN_CONSUMERS SET USERNAME = SUBSTR(USERNAME, 4);
于 2013-09-16T18:13:58.210 回答