`
aaron7524
  • 浏览: 63510 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

oracle sql 去掉汉字保留数字或字母

阅读更多
一、语法
TRANSLATE(string,from_str,to_str)
二、用途
返回将(所有出现的)from_str中的每个字符替换为to_str中的相应字符以后的string。TRANSLATE是REPLACE所提供的功能的一个超集。如果from_str比 to_str长,那么在 from_str中而不在to_str中的额外字符将从string中被删除,因为它们没有相应的替换字符。to_str不能为空。Oracle将空字符串解释为NULL,并且如果TRANSLATE中的任何参数为NULL,那么结果也是NULL。
三、transate使用示例

dw@dw>column col1 format a10
dw@dw>column col2 format a10
dw@dw>select translate('helloword',
  2                   'abcdefghijklmnopqrstuvwxyz',
  3                   'zyxwvutsrqponmlkjihgfedcba') col1,
  4         translate('hbcadhlk',
  5                   'abcdefghijklmnopqrstuvwxyz',
  6                   '123456') col2
  7  from dual;

COL1       COL2
---------- ----------
svooldliw  2314

已选择 1 行。

已用时间:  00: 00: 00.01
我们在实际工作中,经常用到的去掉汉字保留数字或字母,也有可能是去掉数字或字母,保留汉字。
本文将用oracle sql tranlsate函数实现去掉汉字、保留数字;去掉数字和母、保留汉字,本文所用到sql如下:

create table oracle_extract_number (
id number,
name varchar2(50)
);

insert into oracle_extract_number(id,name)  values(1,'32提取汉字中11222的333数44411字11');
insert into oracle_extract_number(id,name)  values(1,'ad提取汉字中11dddfw222的3ddd33数444dd11字11');
insert into oracle_extract_number(id,name)  values(1,'abd2提取汉字中11222的333数44ddd411字11');
insert into oracle_extract_number(id,name)  values(1,'45提取汉233字中1ddd1222ddd的333数44411字11');
insert into oracle_extract_number(id,name)  values(1,'78提取汉字中112SDD22的33ddad3数44ddfdf411字11');

commit;
1.用oracle translate去掉汉字和字母,提取数字

dw@dw>select id,name,
  2         translate(name, '#' ||
  3           translate(name, '0123456789', '#'), '/') "oracle extract number"
  4    from oracle_extract_number;

        ID NAME                                               oracle extract number
---------- -------------------------------------------------- ------------------------------
         1 32提取汉字中11222的333数44411字11                  32112223334441111
         2 ad提取汉字中11dddfw222的3ddd33数444dd11字11        112223334441111
         3 abd2提取汉字中11222的333数44ddd411字11             2112223334441111
         4 45提取汉233字中1ddd1222ddd的333数44411字11         45233112223334441111
         5 78提取汉字中112SDD22的33ddad3数44ddfdf411字11      78112223334441111

已选择5行。

已用时间:  00: 00: 00.03
2.用oracle translate去掉汉字,提取数字和字母

dw@dw>select id,name,
  2  translate(name,'#'||
  3  translate(name,'abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789','#')
  4  ,'/')  "oracle extract number"
  5  from oracle_extract_number;

        ID NAME                                               oracle extract number
---------- -------------------------------------------------- ------------------------------
         1 32提取汉字中11222的333数44411字11                  32112223334441111
         2 ad提取汉字中11dddfw222的3ddd33数444dd11字11        ad11dddfw2223ddd33444dd1111
         3 abd2提取汉字中11222的333数44ddd411字11             abd21122233344ddd41111
         4 45提取汉233字中1ddd1222ddd的333数44411字11         452331ddd1222ddd3334441111
         5 78提取汉字中112SDD22的33ddad3数44ddfdf411字11      78112SDD2233ddad344ddfdf41111

已选择5行。

已用时间:  00: 00: 00.00
3.用oracle translate去掉数字和字母,提取汉字

dw@dw>select id,
  2         name,
  3         translate(name,
  4                   '0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ',
  5                   '/') "oracle extract number"
  6    from oracle_extract_number;

        ID NAME                                               oracle extract number
---------- -------------------------------------------------- ---------------------------
         1 32提取汉字中11222的333数44411字11                  提取汉字中的数字
         2 ad提取汉字中11dddfw222的3ddd33数444dd11字11        提取汉字中的数字
         3 abd2提取汉字中11222的333数44ddd411字11             提取汉字中的数字
         4 45提取汉233字中1ddd1222ddd的333数44411字11         提取汉字中的数字
         5 78提取汉字中112SDD22的33ddad3数44ddfdf411字11      提取汉字中的数字

已选择5行。

已用时间:  00: 00: 00.01


本文来自iDB Stock:http://www.idb-stock.net/idb/2011/06/15/176.html
分享到:
评论

相关推荐

    Oracle9i的init.ora参数中文说明

    Oracle9i初始化参数中文说明 Blank_trimming: 说明: 如果值为TRUE, 即使源长度比目标长度 (SQL92 兼容) 更长, 也允许分配数据。 值范围: TRUE | FALSE 默认值: FALSE serializable: 说明: 确定查询是否获取表级...

    C#编程经验技巧宝典

    73 <br>0106 如何获得一个字符串中数字的长度 74 <br>0107 如何获得字符串中数字或字母的长度 74 <br>0108 如何获得字符串中某个数字的位置 75 <br>0109 获得字符串中汉字的个数 76 <br>0110...

    PHP开发实战1200例(第1卷).(清华出版.潘凯华.刘中华).part1

    实例178 去掉下拉选项的边框 215 实例179 修改表单属性为弹出窗口 216 实例180 表单输入单元的文字设置 217 实例181 表单输入单元单击删除 218 实例182 表单文本输入的移动选择 219 实例183 通过下拉列表选择头像 ...

    PHP开发实战1200例(第1卷).(清华出版.潘凯华.刘中华).part2

    实例178 去掉下拉选项的边框 215 实例179 修改表单属性为弹出窗口 216 实例180 表单输入单元的文字设置 217 实例181 表单输入单元单击删除 218 实例182 表单文本输入的移动选择 219 实例183 通过下拉列表选择头像 ...

    基于模板的代码生成器LKGenerator1.1.0_x86

    (1)本工具提供了3中连接数据库的方式,分别是:MySql、Oracle、SqlServer,在界面上给出连接示例,方便进行复制和修改(减少因错误配置连接方式而带来了不能链接数据库问题)。配置正确后即可正确读取出数据库中的...

    基于模板的代码生成器LKGenerator1.1.0_x64

    (1)本工具提供了3中连接数据库的方式,分别是:MySql、Oracle、SqlServer,在界面上给出连接示例,方便进行复制和修改(减少因错误配置连接方式而带来了不能链接数据库问题)。配置正确后即可正确读取出数据库中的...

    Java开发实战1200例(第1卷).(清华出版.李钟尉.陈丹丹).part3

    实例081 去掉字符串中的所有空格 101 实例082 汉字与区位码的转换 102 第5章 面向对象技术应用 103 5.1 Java中类的定义 104 实例083 自定义图书类 104 实例084 温度单位转换工具 105 实例085 域的默认初始化值 106 ...

Global site tag (gtag.js) - Google Analytics