sql >> Databáze >  >> RDS >> Sqlserver

Jak odstranit značky HTML z řetězce na serveru SQL?

Existuje UDF, které provede to, co je popsáno zde:

Uživatelem definovaná funkce pro odstranění HTML

CREATE FUNCTION [dbo].[udf_StripHTML] (@HTMLText VARCHAR(MAX))
RETURNS VARCHAR(MAX) AS
BEGIN
    DECLARE @Start INT
    DECLARE @End INT
    DECLARE @Length INT
    SET @Start = CHARINDEX('<',@HTMLText)
    SET @End = CHARINDEX('>',@HTMLText,CHARINDEX('<',@HTMLText))
    SET @Length = (@End - @Start) + 1
    WHILE @Start > 0 AND @End > 0 AND @Length > 0
    BEGIN
        SET @HTMLText = STUFF(@HTMLText,@Start,@Length,'')
        SET @Start = CHARINDEX('<',@HTMLText)
        SET @End = CHARINDEX('>',@HTMLText,CHARINDEX('<',@HTMLText))
        SET @Length = (@End - @Start) + 1
    END
    RETURN LTRIM(RTRIM(@HTMLText))
END
GO

Edit:toto je pro SQL Server 2005, ale pokud změníte klíčové slovo MAX na něco jako 4000, bude fungovat i v SQL Server 2000.



  1. MySQL, je lepší vložit NULL nebo prázdný řetězec?

  2. jak změnit postgresql naslouchací port v systému Windows?

  3. Snažím se zkopírovat soubor, ale zobrazuje se chybová zpráva

  4. Přesun do MariaDB Backup