2013-05-03 90 views
0

這是情景:轉換字符串轉換成int SQL服務器

我的應用程序將具備以下條件:

  1. 一個列表框(啓用複選框屬性),將顯示一些列表。
  2. 用戶將通過使用複選框從列表框(多選)中進行選擇。
  3. 我將循環進入所有選中的項目並將ID存儲到數組中。我將ID存儲爲類似這樣的內容,用逗號(1,2,3,4)分隔ID,然後使用長度-1來刪除最後一個逗號。

如何將字符串1,2,3,4轉換爲整數類型的數據,如果我的存儲過程是這樣的?

Select * from tblSomething Where ID in (1,2,3,4) 
+0

[Split in SQL]可能的重複(http://stackoverflow.com/questions/2647/split-string-in-sql) – 2013-05-03 08:36:50

+0

在整個過程中使用適當的數據類型會更好。 SQL Server提供了一種用於存儲多個值的類型 - 表。您可以使用[Table-Valued Parameters](http://msdn.microsoft.com/zh-cn/library/bb510489.aspx)將表格數據從客戶端應用程序傳遞到SQL Server,當然,它可以輕鬆地將表格數據結果。 – 2013-05-03 08:36:51

回答

1

您可以使用以下SQL函數。

SET ANSI_NULLS ON 
GO 

SET QUOTED_IDENTIFIER ON 
GO 

CREATE FUNCTION [dbo].[CommaSeparatedToString] 
(
    @psCSString VARCHAR(8000) 
) 

RETURNS @otTemp TABLE(sID VARCHAR(20)) 
AS 
BEGIN 
DECLARE @sTemp VARCHAR(50) 
WHILE LEN(@psCSString) > 0 
BEGIN 
SET @sTemp = LEFT(@psCSString, ISNULL(NULLIF(CHARINDEX(',', @psCSString) - 1, -1), 
       LEN(@psCSString))) 
SET @psCSString = SUBSTRING(@psCSString,ISNULL(NULLIF(CHARINDEX(',', @psCSString), 0), 
          LEN(@psCSString)) + 1, LEN(@psCSString)) 
INSERT INTO @otTemp VALUES (@sTemp) 
END 
RETURN 
END 

並調用存儲過程像

Select * from tblSomething 
Where ID in (SELECT * FROM CommaSeparatedToString('1,2,3,4')) 
+0

哇!完美,簡單,易於重複使用。非常感謝你@Mukesh – user2059064 2013-05-03 08:49:22

0

您需要的值的@values這個

如你所得到列表中創建動態查詢放慢參數,以便準備和運行動態像這樣的查詢

DECLARE @query NVARCHAR(500) 
    DECLARE @values VARCHAR(200) 
    SET @values='1,2' 

    SET @query =N'Select * from tblSomething Where ID in (' + @values + ')' 
    SELECT @query 
    EXEC @Query 
0

使用此功能分割值:

CREATE FUNCTION [dbo].[udfSplitCSV] 
(
@String varchar (max), 
@Delimiter varchar (10) = ',' 
) 

RETURNS @ValueTable TABLE ([Row] int IDENTITY(1,1), [Value] varchar(max), [Length] int, [Duplicate] int NULL) 

BEGIN 

DECLARE @NextString varchar(max) 
DECLARE @Pos int 
DECLARE @NextPos int 

IF @String IS NULL RETURN 

--Initialize 
SET @NextString = '' 
SET @String = @String + @Delimiter 

--Get position of first Comma 
SET @Pos = charindex(@Delimiter,@String) 
SET @NextPos = 1 

--Loop while there is still a comma in the String 
WHILE (@Pos <> 0) 
    BEGIN 
    SET @NextString = RTrim(LTrim(SubString(@String,1,@Pos - 1))) 
    INSERT INTO @ValueTable ([Value], [Length]) VALUES (@NextString, Len(@NextString)) 
    SET @String = SubString(@String,@Pos+1,Len(@String)) 
    SET @NextPos = @Pos 
    SET @Pos = CharIndex(@Delimiter,@String) 
    END 

UPDATE @ValueTable 
    SET [Duplicate] = X.Duplicate 
    FROM @ValueTable VT 
    INNER JOIN (Select [Row], [Value], Row_Number() OVER (Partition By [Value] ORDER BY [Value], [Row]) as Duplicate FROM @ValueTable) X 
     ON X.[Row] = VT.[Row] 

RETURN 
END 

-- Select * from dbo.udfSplitCSV('a , c b,c, a', ',') 
0

當您將一堆ID存儲到數組中時,請使用單引號存儲。 所以它會是('1','2','3')。

然後你不需要將ID轉換爲整數。