Подтвердить что ты не робот

Как заменить определенные значения в столбце базы данных оракула?

Я хочу заменить значения в определенном столбце. Например, следующие значения столбца

column name
----------
Test1
Test2
Test3
Test12

должен быть (заменяя est1 на rest1)

column name
----------
Trest1
Test2
Test3
Trest12
4b9b3361

Ответ 1

Используйте REPLACE:

SELECT REPLACE(t.column, 'est1', 'rest1')
  FROM MY_TABLE t

Если вы хотите обновить значения в таблице, используйте:

UPDATE MY_TABLE t
   SET column = REPLACE(t.column, 'est1', 'rest1')

Ответ 2

Если вам нужно обновить значение в конкретной таблице:

UPDATE TABLE-NAME SET COLUMN-NAME = REPLACE(TABLE-NAME.COLUMN-NAME, 'STRING-TO-REPLACE', 'REPLACEMENT-STRING');

где

  TABLE-NAME         - The name of the table being updated
  COLUMN-NAME        - The name of the column being updated
  STRING-TO-REPLACE  - The value to replace
  REPLACEMENT-STRING - The replacement

Ответ 3

В Oracle существует концепция имени схемы, поэтому попробуйте использовать этот

update schemname.tablename t
set t.columnname = replace(t.columnname, t.oldvalue, t.newvalue);

Ответ 4

Я использую Версию 4.0.2.15 с Строкой 15.21

Мне нужно было это:

UPDATE table_name SET column_name = REPLACE(column_name,"search str","replace str");

Ввод t.column_name в первый аргумент replace не работал.