Oracle 日常开发(一)

     在我们平常的开发中可能会遇到这样的问题,就是判断某一列是否全部由数字组成,我们都知道oracle并没有给我们提供这样一个现成的函数,那么根据我的经验我总结了两个行之有效的方法(列名:column,表名:table):

 1.使用trim+translate函数:

         

 

  select * from table where trim(translate(column,'0123456789',' ')) is NULL;

 

     这里要注意的是:translate函数的第三个参数是一个空格,不是'', 因为translate的第三个参数如果为空的话,那么永远返回'',这样的就不能达到过滤纯数字的目的。这样把所有的数字都转化为空格,如果全部是由数字构成,那么一旦trim后自然是空,实现了上述目标。当然如果想排除空项的话,可以这样写:

 

 

  select * from table where trim(translate(nvl(column,'x'),'0123456789',' ')) is NULL;

--x 表示任何'0-9'以外的字符。

 

2.使用regexp_like函数:

   

 select * from table where regexp_like(column,'^[0-9]+[0-9]$');

 

     这里要注意的是:regexp_like函数不是在所有的oracle版本中 都能使用的。regexp_like是oracle支持正则表达式的四个函 数:regexp_like,regexp_replace,regexp_instr,regexp_substr中的 一个,有关这方面更加详细信息,请关注相关文档。

3.删除重复数据:

  3.1 首先定义怎样的数据是重复的数据,即在将要建立主键的列上存在重复的数据。这里假如准备建立主键的列是col_1,可以巧用rowid来实现:

  3.2 SQL语句如下:

     delete from table  A where A.rowid<(select max(rowid) from table B where A.col_1=B.col_1 );

 

4.把字符串转换成数字函数CAST

CAST(column as type);

select max(cast(column as numeric)) +1 as column_1 from table;

 

5.填充函数LPad

LPad(colName,len,char);

update table set col_1 = LPad(cast(col_2 as numeric)+1,2,'') where aa ='love';

 

  

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值