data:image/s3,"s3://crabby-images/835f0/835f0183d68360e38201c0eea348393d05ddc0cf" alt="" |
data:image/s3,"s3://crabby-images/fedd4/fedd46b5eddfc5d215c8fcb543c21c47cbcce0b1" alt="" |
Archives of the TeradataForum
Message Posted: Tue, 24 Apr 2007 @ 21:42:34 GMT
Subj: | | Re: Phone number character data cleaning? |
|
From: | | Curley, David |
I don't about clever, but this might work: for each position in the field, turn it into 1-9 or an empty string if not a number, concatenate the
results, and cast as integer.
Something like
Select cast(
case when substr(phone_number,1,1) between '1' and '9' then
substr(phone_number,1,1) else '' end
||
case when substr(phone_number,2,1) between '1' and '9' then
substr(phone_number,2,1) else '' end
case when substr(phone_number,3,1) between '1' and '9' then
substr(phone_number,3,1) else '' end
||
case when substr(phone_number,4,1) between '1' and '9' then
substr(phone_number,4,1) else '' end
||
... Etc....
case when substr(phone_number,,1) between '1' and '9'
then substr(phone_number,,1) else '' end
As integer)
Example:
select cast(
case when substr('1/2',1,1) between '1' and '9' then substr('1/2',1,1)
else '' end
||
case when substr('1/2',2,1) between '1' and '9' then substr('1/2',2,1)
else '' end
||
case when substr('1/2',3,1) between '1' and '9' then substr('1/2',3,1)
else '' end
as integer) as now_a_number;
now_a_number
12
Dave
| |