Tek-Tips is the largest IT community on the Internet today!

Members share and learn making Tek-Tips Forums the best source of peer-reviewed technical information on the Internet!

  • Congratulations SkipVought on being selected by the Tek-Tips community for having the most helpful posts in the forums last week. Way to Go!

Return field data where number begins 1

Status
Not open for further replies.

mgallot

MIS
Jan 22, 2001
93
0
0
US
I need to return data from an address field (address1) starting where a number exists.
Example:

Sunny Hill Gardens 1601 Sunshine Lane - data in field

1601 Sunshine Lane - data that needs to be returned

The numbers are always in different positions in the field.

Thanks for your help.
 
Use some views:
[tt]create view v1 (id,pos) as
select id, position('0' in addrcol) from addrtab
union
select id, position('1' in addrcol) from addrtab
...
select id, position('9' in addrcol) from addrtab[/tt]

and
[tt]create view v2 as
select id, min(pos) as pos
from v1
where pos > 0
group by id[/tt]

And finally:
[tt]select substring(addrcol from (select pos from v2 where v2.id = addrtab.id))
from addrtab[/tt]


My own test:
[tt]SQL>select addrcol,
SQL&substring(addrcol from (select pos from v2 where v2.id = addrtab.id))
SQL&from addrtab;
addrcol

========================================
Sunny Hill Gardens 1601 Sunshine Lane
1601 Sunshine Lane
===
Somewhere Else 4 Lost Place
4 Lost Place
===
40 Sutton Place
40 Sutton Place
===
Ending number 6
6
===
[/tt]
 
Status
Not open for further replies.

Part and Inventory Search

Sponsor

Back
Top