oracle中判断某列是否为数字,删除重复数据的方法
2009-10-08 21:56
316 查看
在我们平常的开发中可能会遇到这样的问题,就是判断某一列是否全部由数字组成,我们都知道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 );
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 );
相关文章推荐
- 判断参数和数据库数据是否重复最简单的方法
- Java把字符串中的数字删除的方法和判断字符串里面是否有汉字的方法
- ORACLE 判断表是否存在,存在则删除方法
- oracle查询重复数据与删除重复记录方法
- 解决Oracle删除重复数据只留一条的方法详解
- oracle 删除重复数据你想不到的方法大全-开发系列(六)
- 高效删除Oracle中重复数据的方法
- Oracle:高效删除Oracle中重复数据的方法
- 高效删除Oracle中重复数据的方法
- 如何判断数据是否有重复数字
- Oracle删除重复记录只保留一条数据的几种方法
- Oracle删除重复记录只保留一条数据的几种方法
- Oracle 删除重复数据只留一条 查询及删除重复记录的SQL语句 1、查找表中多余的重复记录,重复记录是根据单个字段(Id)来判断 select * from 表 wher
- oracle 快速删除大批量数据方法(全部删除,条件删除,删除大量重复记录)
- Oracle查询重复数据与删除重复记录方法
- Java里List取并集方法retainAll不能用来判断是否有重复数据!
- Oracle查询重复数据与删除重复记录方法
- oracle 快速删除大批量数据方法(全部删除,条件删除,删除大量重复记录)
- oracle查询重复数据与删除重复记录方法
- Oracle查询重复数据与删除重复记录方法