- Env
- Remove characters from a string via translate
- Remove characters from a string via regexp_replace
- Split strings and numbers
- Reference
Oracle Basic SQL 013 Study Tips
Remove characters from a string
- translate
- regexp_replace
Split strings and numbers
- regexp_replace
Env
SQL> select banner from v$version;
BANNER
----------------------------------------------------------------------
Oracle Database 19c Enterprise Edition Release 19.0.0.0.0 - Production
SQL> select banner_full from v$version;
BANNER_FULL
-----------------------------------------------------------------------------------------
Oracle Database 19c Enterprise Edition Release 19.0.0.0.0 - Production
Version 19.3.0.0.0
SQL> !cat /etc/redhat-release
Red Hat Enterprise Linux release 8.4 (Ootpa)
SQL> !uname -r
5.4.17-2102.201.3.el8uek.x86_64
SQL>
SQL> show user
USER is "HR"
SQL>
grant dba to hr;
Remove characters from a string via translate
Remove bc characters.
SQL> select 'abcdef',translate('abcdef','1bc','1') as remove_text from dual;
'ABCDE REMO
------ ----
abcdef adef
SQL>
Remove characters from a string via regexp_replace
Remove bc characters.
SQL> select 'abcdef',regexp_replace('abcdef','[bc]') as remove_text from dual;
'ABCDE REMO
------ ----
abcdef adef
SQL>
Split strings and numbers
create or replace view v_str_num as 
select 'abc123' as data from dual union all
select 'efg456' as data from dual union all
select '789hig' as data from dual;
select regexp_replace(data, '[0-9]', '') as str, regexp_replace(data, '[^0-9]', '') as num from v_str_num;
Split strings and numbers
SQL>
create or replace view v_str_num as
  2  select 'abc123' as data from dual union all
  3  select 'efg456' as data from dual union all
  4  select '789hig' as data from dual;
View created.
SQL>
SQL> select * from v_str_num;
DATA
------
abc123
efg456
789hig
SQL>
SQL> 
COL "STR"                            FOR A3
COL "NUM"                            FOR A3
SQL> select regexp_replace(data, '[0-9]', '') as str, regexp_replace(data, '[^0-9]', '') as num from v_str_num;
STR NUM
--- ---
abc 123
efg 456
hig 789
SQL>
Reference
SQL Language Reference / TRANSLATE
SQL> SELECT TRANSLATE('SQL*Plus User''s Guide', ' */''', '___') FROM DUAL;
TRANSLATE('SQL*PLUSU
--------------------
SQL_Plus_Users_Guide
SQL>
Have a good work&life! 2022/02 via LinHong