Home » RDBMS Server » Server Administration » CHECK CONSTRAINT - HARD FOR ME, EASY FOR YOU
CHECK CONSTRAINT - HARD FOR ME, EASY FOR YOU [message #374284] Mon, 04 June 2001 10:31 Go to next message
LEVIATHAN
Messages: 8
Registered: June 2001
Junior Member
I'M NEW TO SQL ORACLE, I HAVE 2 PROBLEMS
FIRSTLY, IS THERE A WAY WHEN CREATING A DATA TYPE SO THAT THE FIRST 3 CHARACTERS ARE NUMBER AND THE LAST 3 CHARCTERS ARE LETTERS, WITHOUT EXCEPTIONS.
IE. 999BUS

SECONDLY I WANT TO CREATE A CONSTRAINT SO THAT A DATE CAN ONLY BE AFTER A CERTAIN DATE AND BEFORE THE PRESENT DATE. I SUSPECT IT USES CHECK BUT I CANT QUITE GET IT RIGHT.
Re: CHECK CONSTRAINT - HARD FOR ME, EASY FOR YOU [message #374287 is a reply to message #374284] Mon, 04 June 2001 12:13 Go to previous message
Andrew again...
Messages: 270
Registered: July 2000
Senior Member
You could do this with a trigger too, but try something like this:

alter table ABC add constraint CK_ABC_COL1 check
(
substr(COL1, 1, 1) <= '9' and
substr(COL1, 1, 1) >= '0' and
substr(COL1, 2, 1) <= '9' and
substr(COL1, 2, 1) >= '0' and
substr(COL1, 3, 1) <= '9' and
substr(COL1, 3, 1) >= '0' and
substr(COL1, length(COL1) - 1, 1) <= 'Z'
substr(COL1, length(COL1) - 1, 1) >= 'A'
substr(COL1, length(COL1) - 2, 1) <= 'Z'
substr(COL1, length(COL1) - 2, 1) >= 'A'
etc...
);

You could also create a function to check that a part of a string is numeric and use that to avoid the repetitive substr checks for each character.

CREATE OR REPLACE FUNCTION to_num (v_value IN VARCHAR2)
RETURN NUMBER
IS
v_retval NUMBER;
BEGIN
v_retval := TO_NUMBER (v_value);-- try to convert it!
RETURN v_retval;-- return the number!
EXCEPTION
WHEN OTHERS
THEN
RETURN NULL;-- cant convert!
END to_num;
/

then ...
nvl(to_num(substr(COL1, 1, 3)), 123) = substr(COL1, 1, 3)

Make sure that you have a not null constraint too
Previous Topic: Input truncated to 9 characters
Next Topic: updating values in primary key column
Goto Forum:
  


Current Time: Sat Jan 11 05:17:12 CST 2025