您可以执行以下步骤:
1) 为您的逗号分隔字符串创建一个拆分函数:
CREATE FUNCTION [dbo].[Split] (
@InputString VARCHAR(8000),
@Delimiter VARCHAR(50)
)
RETURNS @Items TABLE (
Item VARCHAR(8000)
)
AS
BEGIN
IF @Delimiter = ' '
BEGIN
SET @Delimiter = ','
SET @InputString = REPLACE(@InputString, ' ', @Delimiter)
END
IF (@Delimiter IS NULL OR @Delimiter = '')
SET @Delimiter = ','
DECLARE @Item VARCHAR(8000)
DECLARE @ItemList VARCHAR(8000)
DECLARE @DelimIndex INT
SET @ItemList = @InputString
SET @DelimIndex = CHARINDEX(@Delimiter, @ItemList, 0)
WHILE (@DelimIndex != 0)
BEGIN
SET @Item = SUBSTRING(@ItemList, 0, @DelimIndex)
INSERT INTO @Items VALUES (@Item)
SET @ItemList = SUBSTRING(@ItemList, @DelimIndex+1, LEN(@ItemList)-@DelimIndex)
SET @DelimIndex = CHARINDEX(@Delimiter, @ItemList, 0)
END
IF @Item IS NOT NULL
BEGIN
SET @Item = @ItemList
INSERT INTO @Items VALUES (@Item)
END
ELSE INSERT INTO @Items VALUES (@InputString)
RETURN
END
2) 创建一个接收逗号分隔字符串作为参数的过程。在此示例中,我使用的是您的固定字符串,但您应该修改它以使其与参数一起使用。
注意:我考虑到您的目标表总是有 3 列,并且逗号分隔的字符串的长度总是 3 的倍数......如果发生这种变化,您必须调整过程......
/* Get the length of the comma separated string */
DECLARE @ITEM_COUNT INT
SELECT @ITEM_COUNT = COUNT(*) FROM
(
SELECT item
FROM Split('"AccountType","contains","Customer","Balance","equals",250,"FirstName","like","John"',',')
) N
declare @x int
set @x = 1
/* Insert in your table every 3 columns... */
WHILE (@x < @ITEM_COUNT)
BEGIN
insert into test
select /* pivoting the sub-query */
fieldname = max(case when seq = @x then item end),
fieldcondition = max(case when seq = @x + 1 then item end),
fieldvalue = max(case when seq = @x + 2 then item end)
from
(
SELECT item
,row_number() OVER (ORDER BY (SELECT 1)) AS seq
FROM Split('"AccountType","contains","Customer","Balance","equals",250,"FirstName","like","John"',',')
) a
set @x = @x + 3
END
希望对你有帮助