如何查询varchar类型的get max id和numeric中的值?

N4t*_*ata 5 php mysql max

我有表和列id,值为1,2,3,...,10,11,12,13.如何从varchar类型查询get max id?我试过了

select MAX(id) from table
Run Code Online (Sandbox Code Playgroud)

但结果是9,请帮帮忙?

Ben*_*Lee 7

看起来值是字符串,它选择最大字符串.如果您希望它们按数字排序,则必须先将它们转换为数字.您可以使用CONVERT执行此操作:

SELECT MAX(CONVERT(id, SIGNED)) FROM table
Run Code Online (Sandbox Code Playgroud)

您也可以使用CAST:

SELECT MAX(CAST(id AS SIGNED)) FROM table
Run Code Online (Sandbox Code Playgroud)

它们几乎完全相同,除非CONVERT你需要它们,否则有一些额外的选择.