MySQL用省略号截断文本

jav*_*vic 13 mysql text trim ellipsis

假设我有一个列为一列的MySQL表:"消息".它是TEXT类型.我现在想查询所有行,但文本可能很大(不是很大但很大),我只想得到它们的摘要.例如,结果可以填充到列表中.

有没有办法将文本修剪为特定长度(例如,10个字符),如果文本被修剪,则添加省略号?

例如:

Message
-----------
12345678901234
1234567890
12345
12345678901
Run Code Online (Sandbox Code Playgroud)

查询结果:

1234567...
1234567890
12345
1234567...
Run Code Online (Sandbox Code Playgroud)

谢谢!

dav*_*vek 22

select case when length(message) > 7 
then concat(substring(message, 1, 7), '...')
else message end as adapted_message
from ...
Run Code Online (Sandbox Code Playgroud)

测试/确认:

SELECT CASE WHEN LENGTH('1234567890') > 7 
THEN CONCAT(SUBSTRING('1234567890', 1, 7), '...') 
ELSE '1234567890' END AS adapted_message

UNION  

SELECT CASE WHEN LENGTH('12345') > 7 
THEN CONCAT(SUBSTRING('12345', 1, 7), '...') 
ELSE '12345' END AS adapted_message
Run Code Online (Sandbox Code Playgroud)

  • 这个答案有一个非常常见但很烦人的错误。当“长度(消息)> 10”时应为。否则,产生的“截断”文本可能比原始文本长。我一直在所有应用程序(甚至Facebook)中看到这一点。您不讨厌只单击“更多”即可看到两个字母吗?“更多”有4个! (2认同)

小智 6

要么...

SELECT CONCAT(LEFT(message, 7), IF(LENGTH(message)>7, "…", ""))
FROM table
Run Code Online (Sandbox Code Playgroud)

  • 这是一个很好的方法,但是当字段长度在7到10个字符之间时,它将无法正常工作。 (4认同)

小智 5

这是一个简单的单行解决方案:

IF(CHAR_LENGTH(message) > 10, CONCAT(LEFT(message, 7),"..."), message)
Run Code Online (Sandbox Code Playgroud)