Oracle中如何判断字符串是否全为数字

Oracle中如何判断字符串是否全为数字

学习了:http://www.cnblogs.com/zrcoffee/archive/2012/12/11/2812744.html

本文介绍了判断字符串是否全为数字的4种办法,另外还介绍了一个translate函数的小技巧,从任意字符串中提取数字(调用2次translate函数)。这个办法是一个公司同事发现的,用起来很方便,但理解起来稍有点困难。
1、通过ASCII码判断是否数字,介于[48, 57]之间,(ascii(‘0‘) = 48, ascii(‘9‘) = ‘57‘)
2、调用cast函数尝试强制转换成NUMERIC或NUMBER,不是合法数字串即抛异常
3、调用translate函数,剔除所有[0-9]数字后,看是否为空串
4、调用正则表达式,进行模式匹配(10g版本新加入的功能)

--通过ASCII码判断是否数字,介于[48, 57]之间,(ascii(‘0‘) = 48, ascii(‘9‘) = ‘57‘)
DECLARE
    str             VARCHAR2(10) := ‘123a‘;
    val             NUMERIC(10);
    i               int;
    k               int;
    flag            BOOLEAN;
BEGIN
    flag := TRUE;
    for i in 1..10 loop   --新密码是否6位数字
        k := ascii(substr(str, i, 1));
        if k < 48 or k > 57 THEN
            flag := FALSE;
        end if;
    end LOOP;

    IF flag = true THEN
        dbms_output.put_line(str || ‘是[0-9]的数字序列‘);
    ELSE
        dbms_output.put_line(str || ‘不是[0-9]的数字序列‘);
    END IF;
END;

-- 调用cast函数尝试强制转换成NUMERIC或NUMBER,不是合法数字串即抛异常
DECLARE
    str    VARCHAR2(10) := ‘123‘;
    val    NUMERIC(10);
BEGIN
    val := CAST(str AS NUMERIC);
    dbms_output.put_line(str || ‘是[0-9]的数字序列‘);
EXCEPTION
   WHEN value_error THEN -- 字符串转实数错误
       --dbms_output.put_line(SQLCODE || ‘, ‘ || SQLERRM);
       dbms_output.put_line(str || ‘不是[0-9]的数字序列‘);
END;

--调用translate函数,剔除所有[0-9]数字后,看是否为空串
DECLARE
    str VARCHAR2(10) := ‘123abc‘;
BEGIN
    IF replace(translate(str, ‘0123456789‘, ‘0‘), ‘0‘, ‘‘) IS NULL THEN
        dbms_output.put_line(str || ‘是[0-9]的数字序列‘);
    ELSE
        dbms_output.put_line(str || ‘不是[0-9]的数字序列‘);
    END IF;
END;

--调用正则表达式,进行模式匹配(10g版本新加入的功能)
SELECT *
FROM dual
WHERE regexp_like(‘1234‘, ‘^[[:digit:]]+$‘);

--从任意字符串中提取数字串(调用2次translate函数)。
--假定初始串为str。首先将str中数字全部替换为空格,输出记为str2;
--其次,对每个在str中出现的任意str2串中字符,如果是str2的首字符则替换为空格,其它字符则全部剔除
DECLARE
    --str    VARCHAR2(100) := ‘ 护照01浙江2     3昆 山4苏 3‘;
    str    VARCHAR2(100) := ‘ 护照浙江     昆 山苏 4‘;
    ret    VARCHAR2(10);
BEGIN
    ret := TRIM(TRANSLATE(str, trim(TRANSLATE(str, ‘1234567890‘, ‘          ‘)), ‘ ‘));
    dbms_output.put_line(ret);
END;
时间: 2024-10-12 17:22:59

Oracle中如何判断字符串是否全为数字的相关文章

oracle中如何判断一个字符串是否含有汉字

oracle中如何判断一个字符串是否含有汉字 一.1 BLOG文档结构图 一.2 前言部分 一.2.1 导读 各位技术爱好者,看完本文后,你可以掌握如下的技能,也可以学到一些其它你所不知道的知识,~O(∩_∩)O~: ①全角字符的判断,或者是含有汉字的字符串的判断 本文如有错误或不完善的地方请大家多多指正,ITPUB留言或QQ皆可,您的批评指正是我写作的最大动力. 一.2.2 实验环境介绍 11.2.0.3  RHEL6.5 一.2.3 本文简介 看到网友问,怎么查询表中某个字段数据是不是包含了

js判断字符串是否全为空(使用trim函数/正则表达式)

我们需要判断用户输入的是否全是空格,可以使用以下方法: 方法一: 使用trim() /* 使用String.trim()函数,来判断字符串是否全为空*/ function kongge1(test) { let str = test.trim(); if (str.length == 0) { console.log('字符串全是空格'); } else { console.log('输入的字符串为:' + test); } } 如果 trim() 不存在,可以在所有代码前执行下面代码 /* 给

PHP正则判断字符串是否全是中文

<?php /** *判断字符串是否全是中文 */ function isAllChinese($str){ if(preg_match('/^[\x7f-\xff]+$/', $str)){ return true;//全是中文 }else{ return false;//不全是中文 } } var_dump(isAllChinese('你好')); ?> 来自微信公众号:编程社 程序员日常进阶宝典,欢迎关注! 原文地址:https://www.cnblogs.com/ai10999/p/1

Oracle中查询一个字符串的长度的函数

Oracle取字符串长度的函数length()和lengthb() lengthb(string)计算string所占的字节长度:返回字符串的长度,单位是字节 length(string)计算string所占的字符长度:返回字符串的长度,单位是字符 对于单字节字符,lengthb()和length()是一样的 可以用lengthb('string')=length('string') 判断字符串是否含有中文

Oracle中如何判断SQL是否真正做了排序

在Oracle中,有时候在执行计划中看到sort关键字,就有人认为是做了排序,其实不一定.可以用下面的方法实验: drop table test purge; create table test as select * from dba_objects; exec dbms_stats.gather_table_stats(user,'test'); select /*+gg_test*/* from test order by object_id; select /*+gg_test*/* f

判断是否输入全角数字,解决部分客户银行账号输入的问题

修改js脚本文件: 在函数 verifyNodeDataType 里增加 :         if (Node.getAttribute("datatype") == 'english') {             if (!issbccase(v)) {                 if (Node.getAttribute('name') != null) {                     if (v.toString().trim() == '' &&am

java判断字符串是否可以转为数字

java运算中,常涉及将String 型的字符串转为int 型数字的情况. 哪些字符串可以转为数字,哪些不可以呢,不能总以Integer.parseInt() 是否抛出异常来判断. 刚好碰到了转换情况,就总结了下,分享出来. 定义方法签名 /** * 查看一个字符串是否可以转换为数字 * @param str 字符串 * @return true 可以; false 不可以 */ public static boolean isStr2Num(String str) { } 方法体该如何实现呢?

JavaScript判断字符串能否转化为数字

判断一个字符串能否转化为数字 我们常常使用parseInt函数. 不过该函数的适用范围是很小的. 一般说来对于 如下类似 var myStr = "123hello"; 使用parseInt 或者isNaN(myStr)并不能确定整个字符串是不是数字. 这个时候需要用正则表达式来完成. var pattern = /^[0-9]/; pattern.test(myStr); 静态变量 每个事例对象公用一个变量.在类的层次上操作,不是在实例的层次上操作. 私有静态变量的创建可以采用闭包的

iOS判断字符串是否为手机号,iOS判断字符串是是否为字符串,iOS判断字符串是否为纯数字

#pragma 正则匹配手机号 + (BOOL)isPhoneNumber:(NSString *)str { if ([str length] == 0) { UIAlertView* alert = [[UIAlertView alloc] initWithTitle:@"提示"message:@"请输入手机号码" delegate:nil cancelButtonTitle:@"确定" otherButtonTitles:nil, nil]