欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

oracle 截取字符 正则匹配,临时表操作

程序员文章站 2022-05-07 20:56:20
...
截取 订单,成本,运费
select note,to_number(substr(regexp_substr(note,'[^,]+',1,1),9)),to_number(substr(regexp_substr(note,'[^,]+',1,2),5)),
to_number(substr(regexp_substr(note,'[^,]+',1,4),5))  from seller_deposit_log where type=0
 and created_time>to_date('2016-11-18','yyyy-mm-dd')
and note like '%订单费用%' and rownum<5;



运行结果:查看附件截图

订单费用,订单: 14545228, 成本: 36.72, 处理费: 2, 运费: 56.00	 运行结果:14545228 36.72	56
订单费用,订单: 14543096, 成本: 26.60, 处理费: 2, 运费: 74.49 运行结果:	14543096	26.6	74.49
订单费用,订单: 14542539, 成本: 203.48, 处理费: 2, 运费: 147.00 运行结果:	14542539	203.48	147
订单费用,订单: 14529948, 成本: 13.56, 处理费: 2, 运费: 17.94	运行结果:14529948	13.56	17.94





1.translate
语法: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)
用法:将char中的字符串search_string全部转换为字符串replacement_string。
举例:SQL> select REPLACE('fgsgswsgs', 'fk' ,'j') 返回值 from dual;
            返回值
            ---------
            fgsgswsgs
            SQL> select REPLACE('fgsgswsgs', 'sg' ,'eeerrrttt') 返回值 from dual;
            返回值
            -----------------------
            fgeeerrrtttsweeerrrttts
分析:第一个例子中由于'fgsgswsgs'中没有与'fk'匹配的字符串,
            故返回值仍然是'fgsgswsgs';
            第二个例子中将'fgsgswsgs'中的字符串'sg'全部转换为'eeerrrttt'。
总结:综上所述,replace与translate都是替代函数,
         只不过replace针对的是字符串,而translate针对的是单个字符。



临时表

如果temp表存在:
insert into temp select * from 表名 where id=1; 
commit;  


如果temp表不存在
create table temp as insert into temp select * from 表名 where id=1; 
简化写法
create table temp123  as
select * from 表名  

清空所有记录
truncate table temp123
  • oracle 截取字符 正则匹配,临时表操作
            
    
    博客分类: oracle oralce 
  • 大小: 14.1 KB
相关标签: oralce