Select max int from varchar column

2019-04-04 06:35发布

问题:

I am trying to retrieve the largest number from a varchar column that includes both numbers and strings. An example of the data I'm working with:

BoxNumber
123
A5
789
B1

I need to return the largest number (789 in this case) from the column while ignoring the non-numeric values of A5 and B1.

I have found solutions that use custom functions to solve the problem, but I need something that can be executed ad-hoc query without relying on custom functions or procs.

回答1:

you need a combination because of the fact that isnumeric returns 1 for the following things

select isnumeric('+'),isnumeric('5d2') 

your where clause would be like this

WHERE VALUE NOT LIKE '%[a-z]%'
        AND ISNUMERIC(VALUE) = 1

create table #bla (value varchar(50))
insert #bla values('123')
insert #bla values('a5')
insert #bla values('789')
insert #bla values('b1')

SELECT MAX(CAST(value AS Int)) FROM #bla
WHERE VALUE NOT LIKE '%[a-z]%'
    AND ISNUMERIC(VALUE) = 1

I wrote about this here ISNUMERIC Trouble



回答2:

You might try

Select MAX(BoxNumber) from {table} where IsNumeric(BoxNumber) = 1


回答3:

Why not

SELECT MAX(CAST(Value AS Int)) FROM #bla 
WHERE ISNUMERIC(Value)=1 
    AND Value LIKE '%[0-9]%' 

then you're only dealing with numeric strings. In this case you may not need ISNUMERIC()



回答4:

The selected answer worked for me until I added this value to the temp table along with the others in the sample:

insert #bla values('1234')

I expected my max() result to now be 1234, but it remained at 789. Perhaps this is due to some collation setting, but I was able to reproduce on multiple databases. I found this query below worked for me, but I'd certainly be interested to hear if there is a more efficient way of doing this. Also, I did not want to include any decimal values, so I excluded anything with a period as well.

SELECT MAX(CAST(Value AS Int)) FROM #bla 
WHERE ISNUMERIC(Value)=1 
    AND Value NOT LIKE '%[a-z]%' 
    AND Value NOT LIKE '%.%'


回答5:

You should check this solution out for values like '+' and '-' as I think the IsNumeric function may return 1 for these values



回答6:

Look into casting the column to an int, then selecting the MAX(). I don't know what it will do to columns that contain letters, but it's worth exploring.

http://doc.ddart.net/mssql/sql70/ca-co_1.htm



回答7:

These answers are only half right. They succeed in isolating numeric values, but don't realize that when the underlying field is a number the Max function evaluates as characters (regardless of casting), reading left to right, so that 789 > 1000 because 7 > 1. A way around this might be to forget about casting and left pad the numbers with zeros to a common length, when Max in character mode should work.