SELECT * FROM table ORDER BY string_length(column);
是否有一个MySQL函数来做这个(当然不是string_length)?
SELECT * FROM table ORDER BY string_length(column);
是否有一个MySQL函数来做这个(当然不是string_length)?
当前回答
SELECT * FROM table
ORDER BY LENGTH(column);
关于LENGTH()函数以及所有其他字符串函数的文档可以在这里找到。
其他回答
在我的情况下,我得到的数据使用移动号码长度大于10位使用下面的查询
SELECT * FROM table_name WHERE CHAR_LENGTH(mobile) > 10;
SELECT * FROM table
ORDER BY LENGTH(column);
关于LENGTH()函数以及所有其他字符串函数的文档可以在这里找到。
您正在寻找CHAR_LENGTH()来获取字符串中的字符数。
对于多字节字符集,LENGTH()将给出字符串占用的字节数,而CHAR_LENGTH()将返回字符数。
看一下MySQL的字符串函数文档,我们也可以使用CHAR_LENGTH()和CHARACTER_LENGTH()。
我用来找到字符串长度的函数是length,使用如下:
SELECT * FROM table ORDER BY length(column);