我有一个存储过程,可以接受诸如A,B,C等的字符串。我想分割字符串并将每个字母作为一条记录插入到表中。结果应为:
col1 col2
1 A
2 B
3 C
我可以使用游标,但是如果我从网页上调用此存储过程,游标有点慢。有没有更好的解决方案?
而不是传递逗号分隔的字符串,而是传递一个表值参数。首先,在数据库中创建一个表类型:
CREATE TYPE dbo.Strings AS TABLE(String NVARCHAR(32));
然后您的存储过程:
CREATE PROCEDURE dbo.InsertStrings
@Strings dbo.Strings READONLY
AS
BEGIN
SET NOCOUNT ON;
INSERT dbo.Table(Col2) -- assuming col1 is an IDENTITY column?
SELECT String FROM @Strings;
END
GO
然后,在您的C#代码或任何其他代码中,您只需传递aDataTable
作为Structured
参数。这里的例子和背景。
如果您真的不想这样做,因为它太难了,那么您可以使用效率低得多的字符串拆分功能,例如
CREATE FUNCTION [dbo].[SplitString]
(
@List NVARCHAR(MAX),
@Delim VARCHAR(255)
)
RETURNS TABLE
AS
RETURN ( SELECT [Value] FROM
(
SELECT
[Value] = LTRIM(RTRIM(SUBSTRING(@List, [Number],
CHARINDEX(@Delim, @List + @Delim, [Number]) - [Number])))
FROM (SELECT Number = ROW_NUMBER() OVER (ORDER BY name)
FROM sys.all_objects) AS x
WHERE Number <= LEN(@List)
AND SUBSTRING(@Delim + @List, [Number], LEN(@Delim)) = @Delim
) AS y
);
然后,您的过程是:
CREATE PROCEDURE dbo.InsertStrings
@Strings NVARCHAR(MAX)
AS
BEGIN
SET NOCOUNT ON;
INSERT dbo.Table(Col2) -- assuming col1 is an IDENTITY column?
SELECT [Value] FROM dbo.SplitString(@Strings, ',');
END
GO
本文收集自互联网,转载请注明来源。
如有侵权,请联系[email protected] 删除。
我来说两句