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 gkittelson on being selected by the Tek-Tips community for having the most helpful posts in the forums last week. Way to Go!

Split Text into char and int 1

Status
Not open for further replies.
Oct 17, 2006
227
HI Guys

I'm struggling at the monment separting txt


WITH t(hours) AS (
Select '3WH' UNION ALL
Select '3WH ' UNION ALL
Select '4WH' UNION ALL
Select '3 WH' UNION ALL
Select '3 ' UNION ALL
Select '4' UNION ALL
Select '3 W' UNION ALL
Select 'WH3 ' UNION ALL
Select 'W 3' )

SELECT PATINDEX('%[0-9]%', hours + '0') FROM t

you can see in the results there is a lot of 1's ideally what I would like to see is (col 1 3, col 2 WH)


any help would be great thanx


 
What is the "hours + '0'" about?

Think this is close.

Simi


WITH t(hours) AS (
Select '3WH' UNION ALL
Select '3WH ' UNION ALL
Select '4WH' UNION ALL
Select '3 WH' UNION ALL
Select '3 ' UNION ALL
Select '4' UNION ALL
Select '3 W' UNION ALL
Select 'WH3 ' UNION ALL
Select 'W 3'
)
select substring(hours,PATINDEX('%[0-9]%', hours),1)
, ltrim(replace(hours,substring(hours,PATINDEX('%[0-9]%', hours),1),'')) from t
 
Nice I ve never thought of using substring however what happens if the 3 becomes 30 ?
 
Sorry also

Select '30 ' UNION ALL Select '4.5' UNION ALL
 
I favour a user-defined function

Code:
CREATE Function [StripField](@strNum VARCHAR(1000))
RETURNS VARCHAR(1000)
AS
BEGIN
    WHILE PATINDEX('%[^0-9.]%', @strNum) > 0
       BEGIN
          SET @strNum = STUFF(@strNum, PATINDEX('%[^0-9.]%', @strNum), 1, '')
       END
    RETURN @strNum
END

The 'WH' part can then be added on
e.g.
SELECT dbo.stripfield([data]), 'WH' from SOURCE

soi là, soi carré
 
Code:
WITH t(Id, hours) AS (
Select 1, '3WH'   UNION ALL
Select 2, '3WH  ' UNION ALL
Select 3, '4WH'   UNION ALL
Select 4, '3 WH'  UNION ALL
Select 5, '3 '    UNION ALL
Select 6, '4'     UNION ALL
Select 7, '3 W'   UNION ALL
Select 8, 'WH3 '  UNION ALL
Select 9, 'W 3'   UNION ALL
Select 10,'WW'    UNION ALL
Select 11,'W33W'
)
select  CASE WHEN PATINDEX('%[0-9]%', hours) = 0
                  THEN '0'
             WHEN PATINDEX('%[^0-9]%', hours+'W') = 0
                  THEN hours
             ELSE
                SUBSTRING(hours, PATINDEX('%[0-9]%', hours),
                                 PATINDEX('%[0-9][^0-9]%', hours+'W')+1-
                                 PATINDEX('%[0-9]%', hours))
            END AS TestNumber,
        CASE WHEN PATINDEX('%[0-9]%', hours) = 0
                  THEN Hours
             WHEN PATINDEX('%[^0-9]%', hours) = 0
                  THEN ''
             ELSE
             STUFF(hours, PATINDEX('%[0-9]%', hours),
                          PATINDEX('%[0-9][^0-9]%', hours+' ')-
                          PATINDEX('%[0-9]%', hours)+1,'')
             END AS TestString,
                  
            *
 from t
Not tested for every occasions though :)

Borislav Borissov
VFP9 SP2, SQL Server 2000,2005 & 2008.
 
So Close !!!



WITH t(hours) AS (

Select '3.5ZH' UNION ALL

Select '3WH ' UNION ALL

Select '4WH' UNION ALL

Select '3 WH' UNION ALL

Select '3 ' UNION ALL

Select '4.5' UNION ALL

Select '3 W' UNION ALL

Select 'WH3.5 ' UNION ALL

Select 'W 30' )

select substring(hours,patindex('%[0-9]%',hours),

CASE patindex('%.%',hours)

WHEN 0 THEN patindex('%[0-9]%',hours)

ELSE patindex('%[0-9]%',hours) + 2 END) AS Other

,
CASE WHEN PATINDEX('%[0-9]%', hours) = 0
THEN Hours
WHEN PATINDEX('%[^0-9]%', hours) = 0 THEN '' ELSE
STUFF(hours, PATINDEX('%[0-9]%', hours),
PATINDEX('%[0-9][^0-9]%', hours+' ')-
PATINDEX('%[0-9]%', hours)+1 , '')
END AS TestString ,
hours
FROM t

I just need to try and handle the decimals

 
Code:
WITH t(hours) AS (

Select '3.5ZH' UNION ALL

Select '3WH ' UNION ALL

Select '4WH' UNION ALL

Select '3 WH' UNION ALL

Select '3 ' UNION ALL

Select '4.5' UNION ALL

Select '3 W' UNION ALL

Select 'WH3.5 ' UNION ALL

Select 'W 30' ) 

select  CASE WHEN PATINDEX('%[0-9.]%', hours) = 0
                  THEN '0'
             WHEN PATINDEX('%[^0-9]%', hours+'W') = 0
                  THEN hours
             ELSE
                SUBSTRING(hours, PATINDEX('%[0-9]%', hours),
                                 PATINDEX('%[0-9.][^0-9.]%', hours+'W')+1-
                                 PATINDEX('%[0-9]%', hours))
            END AS TestNumber,
        CASE WHEN PATINDEX('%[0-9.]%', hours) = 0
                  THEN Hours
             WHEN PATINDEX('%[^0-9.]%', hours) = 0
                  THEN ''
             ELSE
             STUFF(hours, PATINDEX('%[0-9.]%', hours),
                          PATINDEX('%[0-9.][^0-9.]%', hours+' ')-
                          PATINDEX('%[0-9]%', hours)+1,'')
             END AS TestString,
                  
            *
 from t

Borislav Borissov
VFP9 SP2, SQL Server 2000,2005 & 2008.
 
Status
Not open for further replies.

Part and Inventory Search

Sponsor

Back
Top