从 MySQL 数据库里面截取出文章的简介,文章里面难免会有一些 HTML 标签,如果直接按照字数截取,就会出现标签的不完整导致页面错位,所以我们需要一个处理 HTML 标签的函数。
SET GLOBAL log_bin_trust_function_creators=1;
DROP FUNCTION IF EXISTS fnStripTags;
DELIMITER |
CREATE FUNCTION fnStripTags( Dirty text(0) )
RETURNS text(0)
DETERMINISTIC
BEGIN
DECLARE iStart, iEnd, iLength int;
WHILE Locate( '<', Dirty ) > 0 And Locate( '>', Dirty, Locate( '<', Dirty )) > 0 DO
BEGIN
SET iStart = Locate( '<', Dirty ), iEnd = Locate( '>', Dirty, Locate('<', Dirty ));
SET iLength = ( iEnd - iStart) + 1;
IF iLength > 0 THEN
BEGIN
SET Dirty = Insert( Dirty, iStart, iLength, '');
END;
END IF;
END;
END WHILE;
RETURN Dirty;
END;
|
DELIMITER ;
可以用批量修改的脚本加这个函数,将所有的 HTML 标签去掉。
对于 这样转码的特殊字符串,我们可以使用 replace(enterprise_profile,' ','') 来替换掉。

