MySQL用省略号截断文本

MySQL用省略号截断文本

问题描述:

假设我有一列的MySQL表:“消息”。它是TEXT类型的。 我现在想要查询所有行,但文本可能很大(不是非常大但很大),我只想得到它们的摘要。例如,结果可以填充到列表中。MySQL用省略号截断文本

是否有办法将文本修剪为特定的长度(比如10个字符),如果文本被修剪,还可以添加省略号?

例如:

Message 
----------- 
123456789
1234567890 
12345 
12345678901 

查询结果:

1234567... 
1234567890 
12345 
1234567... 

谢谢!

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

测试/确认:

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 
+0

真棒。谢谢! – javic 2011-06-17 15:51:32

+0

我想知道是否LEFT会比SUBSTRING更快 – Helto 2013-07-18 18:53:26

看看MySQL的字符串函数,记录在here。您应该可以使用substringconcat的某种组合来实现您的预​​期行为。

或...

SELECT CONCAT(LEFT(message, 7), IF(LENGTH(message)>7, "…", "")) 
FROM table 

这里有一个简单的在线解决方案:

IF(CHAR_LENGTH(message) > 7, CONCAT(LEFT(message, 7),"..."), message)