Oracle 日常开发(一)
2010-09-08 09:04
106 查看
在我们平常的开发中可能会遇到这样的问题,就是判断某一列是否全部由数字组成,我们都知道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';
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';
相关文章推荐
- Oracle生产日常开发维护总结
- 用Java开发的MySQL,Oracle,PostgreSQL,mongoDB 数据库web管理工具软件
- Oracle WebCenter 11g 快速开发指南--翻译(三)
- oracle程序开发基础二
- ORACLE 10G RAC 服务器日常维护手册
- php 开发日常收获
- Oracle学习笔记摘录8-----ORACLE的使用和开发汇总
- oracle 数据库开发面试题
- Oracle应用Linux开发C_网络服务器
- Oracle开发专题之:删除重复记录
- 前端开发之日常问题总结
- Oracle日常性能查看
- oracle_开发子程序和包
- oracle 开发字典
- Oracle的上下文开发--自己定义的Context开发
- Android日常开发60条经验
- 慕课网笔记之oracle开发利器-PL/SQL基础
- IT视频课程集(包含各类Oracle、DB2、Linux、Mysql、Nosql、Hadoop、BI、云计算、编程开发、网络、大数据、虚拟化
- Oracle开发之:窗口函数 3( rows between unbounded preceding and current row)
- Oracle SQL开发 之 Select语句完整的执行顺序