如何在SQL中操作select查询的结果?

时间:2013-06-03 07:50:29

标签: mysql sql

我正在尝试操纵我的sql select结果。我以这种方式<p>asd</p>将变量存储在数据库中,因此它将被识别为我的应用程序中的段落,但我想在我的应用程序的其他功能中使用它。 我想以这种方式展示它&#39; asd&#39;。

有没有办法在sql中做到这一点?任何帮助都会得到满足 我正在使用phpmyadmin

3 个答案:

答案 0 :(得分:2)

如果您正在运行MySQL 5.1.5 or above,那么您可以使用XPath函数ExtractValue(),就像这样......

SELECT ExtractValue(col1, '/p') FROM xml_test;

Click here to see it in action at SQL Fiddle

答案 1 :(得分:2)

是的,您可以使用select replace,如下所示:

select replace(replace("<p>asd</p>",'<p>',''),'</p>','')

See it in action: SQL fiddle

答案 2 :(得分:0)

试试这个solution

SET GLOBAL log_bin_trust_function_creators=1;
DROP FUNCTION IF EXISTS fnStripTags;
DELIMITER |
CREATE FUNCTION fnStripTags( Dirty varchar(4000) )
RETURNS varchar(4000)
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 ;
SELECT fnStripTags('this <html>is <b>a test</b>, nothing more</html>');