检查字符串是否包含任何数值

时间:2018-12-21 17:36:01

标签: sql oracle plsql

我有下表:

create table students
(
    stuName varchar2(100),
    cgpa number
);

我的目标是创建一个PL / SQL触发器,如果​​有人尝试输入包含任何数字值的名称,该触发器将触发。我的尝试:

create or replace trigger invalid_name
before insert
on students
for each row
declare
    vName varchar2(100);
begin
    vName := :new.stuName;
    if upper(vName) like upper(vName) then
        vName := initcap(vName);
    end if;
exception
    when value_error then
        dbms_output.put_line('ERROR: Name contains numeric value(s).');
end;

我认为,如果upper函数要作用于其中包含任何数字值的字符串,它将引发异常。但这并没有发生,insert操作正在执行。

2 个答案:

答案 0 :(得分:5)

我建议使用约束而不是触发器。

create table foo (
    name varchar2(100) NOT NULL
    constraint name_non_numeric check ( not regexp_like( name, '[0-9]' ) )
);

Table created.

insert into foo ( name ) values ( 'Andy' );

1 row created.

> insert into foo ( name ) values ( 'Logan 5' );

insert into foo ( name ) values ( 'Logan 5' )
*
ERROR at line 1:
ORA-02290: check constraint (NAMESPACE.NAME_NON_NUMERIC) violated

答案 1 :(得分:0)

如果您不想替换,而是检查并引发错误,则可以使用this trick并在结果不为null时引发错误:

SELECT LENGTH(TRIM(TRANSLATE('123b', ' +-.0123456789',' '))) FROM dual;
Result: 1

SELECT LENGTH(TRIM(TRANSLATE('a123b', ' +-.0123456789',' '))) FROM dual;
Result: 2

SELECT LENGTH(TRIM(TRANSLATE('1256.54', ' +-.0123456789',' '))) FROM dual;
Result: null

SELECT LENGTH(TRIM(TRANSLATE ('-56', ' +-.0123456789',' '))) FROM dual;
Result: null