Maison > Article > base de données > Quelles sont les fonctions de remplacement dans Oracle ?
Les fonctions de remplacement d'oracle sont : 1. fonction translation(), syntaxe "TRANSLATE(char, from, to)" ; 2. fonction replace(), syntaxe "REPLACE (chaîne, valeur de recherche, valeur de remplacement)".
L'environnement d'exploitation de ce tutoriel : système Windows 7, version Oracle 11g, ordinateur Dell G3.
Remplacer la fonction remplacer et traduire la fonction dans Oracle
1.translate
Syntaxe : TRANSLATE(char, from, to)
TRANSLATE(char, from, to)
用法:返回将出现在from中的每个字符替换为to中的相应字符以后的字符串。
若from比to字符串长,那么在from中比to中多出的字符将会被删除。
三个参数中有一个是空,返回值也将是空值。
举例:
SQL> select translate('abcdefga','abc','wo') 返回值 from dual;
返回值
wodefgw
分析:
该语句要将'abcdefga'中的'abc'转换为'wo',由于'abc'中'a'对应'wo'中的'w',故将'abcdefga'中的'a'全部转换成'w';
而'abc'中'b'对应'wo'中的'o',故将'abcdefga'中的'b'全部转换成'o';
'abc'中的'c'在'wo'中没有与之对应的字符,故将'abcdefga'中的'c'全部删除;
简单说来,就是将from中的字符转换为to中与之位置对应的字符,若to中找不到与之对应的字符,返回值中的该字符将会被删除。
在实际的业务中,可以用来删除一些异常数据,比如表a中的一个字段t_no表示电话号码,而电话号码本身应该是一个由数字组成的字符串,为了删除那些含有非数字的异常数据,就用到了translate函数:
SQL> delete from a, where length(translate(trim(a.t_no), '0123456789' || a.t_no, '0123456789')) <> length(trim(a.t_no));
2.replace
语法:REPLACE(char, search_string,replacement_string)
SQL> select REPLACE('fgsgswsgs', 'fk' ,'j') 返回值 from dual;Valeur de retour
fgsgswsgsAnalyse : Cette instruction consiste à convertir le "abc" dans "abcdefga" en "wo", car le "a" dans "abc" correspond au "w" dans 'wo'', donc tous les 'a' dans 'abcdefga' sont convertis en 'w' ; Le 'b' dans 'abc' correspond au 'o' dans 'wo', donc tous les 'b' dans 'abcdefga' ' sont convertis Convertir en 'o';
SQL> select REPLACE('fgsgswsgs', 'sg' ,'eeerrrttt') 返回值 from dual;
REPLACE(char, search_string,replacement_string)
Exemple 1 : 🎜fgeeerrrtttsweeerrrttts🎜Valeur de retour 🎜rrreee🎜Exemple 2 : 🎜rrreee🎜Valeur de retour 🎜rrreee🎜Analyse : 🎜🎜🎜🎜Dans le premier exemple, puisqu'il n'y a pas de chaîne correspondant à 'fk' dans 'fgsgs wsgs', donc , la valeur de retour est toujours 'fgsgswsgs' ; 🎜🎜🎜🎜Dans le deuxième exemple, toute la chaîne 'sg' dans 'fgsgswsgs' est convertie en 'eeerrrttt'. 🎜🎜🎜🎜Résumé : Pour résumer, remplacer et traduire sont tous deux des fonctions de remplacement, sauf que le remplacement cible une chaîne, tandis que la traduction cible un seul caractère. 🎜🎜Tutoriel recommandé : "🎜Tutoriel Oracle🎜"🎜
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!