189 8069 5689

oracle如何判断数字,oracle判断字段是不是数字

oracle判断字符串是否为数字

1、通过ASCII码判断是否数字,介于[48, 57]之间,(ascii('0') = 48, ascii('9') = '57')

创新互联主要为客户提供服务项目涵盖了网页视觉设计、VI标志设计、全网整合营销推广、网站程序开发、HTML5响应式重庆网站建设公司成都做手机网站、微商城、网站托管及成都网站维护、WEB系统开发、域名注册、国内外服务器租用、视频、平面设计、SEO优化排名。设计、前端、后端三个建站步骤的完善服务体系。一人跟踪测试的建站服务标准。已经为成都建筑动画行业客户提供了网站营销服务。

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;

在Oracle中,如何判断一个字符串是否为数字

oracle本身没有,得自定义一个函数

create or replace function isNumber(p in varchar2)

return number

is

result number;

begin

result := to_number(p);

return 1;

exception

when VALUE_ERROR then return 0;

end;

调用

select isNumber('abc123') from dual

或者

select isNumber('123') from dual

返回值为1,说明是数字,返回值是0,说明里边包含非数字的字符

oracle 如何判断数字字串中是否含有英文字母 如题!

简单的:一条语句搞定,SqlPlus里面select decode(length(replace(translate('字符串的值','0123456789.',' '),' ','')),0,'is number','is not a number') from dual; 麻烦点的:写function在oracle数据库中,create or replace function f_str_or_num(str varchar2) return varchar2 is

2 v_num number;

3 v_return varchar2(60);

4 begin

5 v_num:=to_number(str);

6 v_return:=str||' is a number string!';

7 return v_return;

8 exception when others then

9 v_return:=str||' is not a number string!';

10 return v_return;

11 end f_str_or_num; 然后调用select f_str_or_num('字符串的值) from dual;

oracle 中怎么判断是否为数字?

CREATE OR REPLACE Function Isnumeric(Str In Varchar2)

Return Number

Is

Begin

If Str Is Null

Then

Return 0;

Else

If Regexp_Like(Str, '^(-{0,1}+{0,1})[0-9]+(.{0,1}[0-9]+)$') --数值

/*(str, '^[0-9]*[1-9][0-9]*$') --正整数*/

Then

Return 1;

Else

Return 0;

End If;

End If;

End Isnumeric;

创建上面的函数,然后判断返回值是否是1,1则表示是数值,0则表示非数值

oracle如何判断某个字段的值是不是数字

1、创建测试表,

create table test_isnum(id number, value varchar2(20));

2、插入测试数据,

insert into test_isnum values(1,'a');

insert into test_isnum values(2,329);

insert into test_isnum values(4,'15');

insert into test_isnum values(6,'2c');

commit;

3、查询表中所有记录,select t.*, rowid from test_isnum t,

4、编写sql,判断value字段,记录为数字的内容,

select t.*,

 case

   when not regexp_like(value, '\D') then

    '是'

   else

    '否'

 end as "是否数字"

from test_isnum t;


网站栏目:oracle如何判断数字,oracle判断字段是不是数字
文章源于:http://cdxtjz.cn/article/hdcdcp.html

其他资讯