拆分字段并将单词插入表格

时间:2015-07-21 13:38:36

标签: sql-server sql-server-2008 tsql

我有一张桌子

Create Table Keywords (keyword nvarchar(100))

我想拆分所有电子邮件主题并将其插入我的关键字表格。

This is an email
The cats and Dogs mailing

我希望每个单词都以行的形式返回。

3 个答案:

答案 0 :(得分:1)

你可以使用这样的功能:

CREATE FUNCTION [dbo].[fnSplit] 
( 
    @string NVARCHAR(MAX), 
    @delimiter CHAR(1) 
) 
RETURNS @output TABLE(splitdata NVARCHAR(MAX) 
) 
BEGIN 
    DECLARE @start INT, @end INT 
    SELECT @start = 1, @end = CHARINDEX(@delimiter, @string) 
    WHILE @start < LEN(@string) + 1 BEGIN 
        IF @end = 0  
            SET @end = LEN(@string) + 1

        INSERT INTO @output (splitdata)  
        VALUES(SUBSTRING(@string, @start, @end - @start)) 
        SET @start = @end + 1 
        SET @end = CHARINDEX(@delimiter, @string, @start)

    END 
    RETURN 
END

然后选择

select *
from dbo.fnSplit('This is an email
The cats and Dogs mailing',' ')

答案 1 :(得分:1)

这是一种不同的方法。它看起来很奇怪,但实际上它的执行速度比子串的速度快。

locManager.addProximityAlert(lat, lon, radius, expiration, pendingIntent);

答案 2 :(得分:1)

首先,您可能希望避免重复并在其中获取唯一字词或添加列并更新计数器以了解该字词出现在主题行中的次数。

This solution可以通过一些调整很好地为你工作。

有问题吗?