sqlserver 分割字符串爲數組
---返回字符串按照指定分隔符分割後的數組的長度
CREATE function Get_StrArrayLength
(
@str varchar(1024), --要分割的字符串
@split varchar(10) --分隔符號
)
returns int
as
begin
declare @location int
declare @start int
declare @length int
set @str=ltrim(rtrim(@str))
set @location=charindex(@split,@str)
set @length=1
while @location<>0
begin
set @start=@location+1
set @location=charindex(@split,@str,@start)
set @length=@length+1
end
return @length
end ;
----按照指定的分隔符分割字符串爲數組形式,然後獲取指定元素。注: 元素個數從1開始
CREATE function Get_StrArrayStrOfIndex
(
@str varchar(1024), --要分割的字符串
@split varchar(10), --分隔符號
@index int --取第幾個元素
)
returns varchar(1024)
as
begin
declare @location int
declare @start int
declare @next int
declare @seed int
set @str=ltrim(rtrim(@str))
set @start=1
set @next=1
set @seed=len(@split)
set @location=charindex(@split,@str)
while @location<>0 and @index>@next
begin
set @start=@location+@seed
set @location=charindex(@split,@str,@start)
set @next=@next+1
end
if @location =0 select @location =len(@str)+1
--這兒存在兩種情況:1、字符串不存在分隔符號 2、字符串中存在分隔符號,跳出while循環後,@location爲0,那默認爲字符串後邊有一個分隔符號。
return substring(@str,@start,@location-@start)
end ;
---測試。注意: P_GET_HttpRequestData 爲sqlserver獲取http請求數據的存儲過程,在Sqlserver處理Http請求日誌中有講述。
CREATE PROCEDURE IPCC_IVR_QUERYCARDONECINFO(@dataStr VARCHAR(255),@dataIndex VARCHAR(4),@outText1 VARCHAR(255) OUT,@outText2 VARCHAR(255) OUT,@outText3 VARCHAR(255) OUT)
AS
BEGIN
DECLARE @returnText VARCHAR(500)
DECLARE @status int
DECLARE @urlStr VARCHAR(255)
SET @urlStr = 'http://172.17.5.14:9090/df/sendDataToIVR.action?parametersStr='+@dataStr +'#'+@dataIndex+'&ifaceType=2';
EXEC P_GET_HttpRequestData @urlStr, @status OUTPUT, @returnText OUTPUT;
SET @outText1 = dbo.Get_StrArrayStrOfIndex(@returnText,',',1);
SET @outText2 = dbo.Get_StrArrayStrOfIndex(@returnText,',',2);
SET @outText3 = dbo.Get_StrArrayStrOfIndex(@returnText,',',3);
END;
---返回字符串按照指定分隔符分割後的數組的長度
CREATE function Get_StrArrayLength
(
@str varchar(1024), --要分割的字符串
@split varchar(10) --分隔符號
)
returns int
as
begin
declare @location int
declare @start int
declare @length int
set @str=ltrim(rtrim(@str))
set @location=charindex(@split,@str)
set @length=1
while @location<>0
begin
set @start=@location+1
set @location=charindex(@split,@str,@start)
set @length=@length+1
end
return @length
end ;
----按照指定的分隔符分割字符串爲數組形式,然後獲取指定元素。注: 元素個數從1開始
CREATE function Get_StrArrayStrOfIndex
(
@str varchar(1024), --要分割的字符串
@split varchar(10), --分隔符號
@index int --取第幾個元素
)
returns varchar(1024)
as
begin
declare @location int
declare @start int
declare @next int
declare @seed int
set @str=ltrim(rtrim(@str))
set @start=1
set @next=1
set @seed=len(@split)
set @location=charindex(@split,@str)
while @location<>0 and @index>@next
begin
set @start=@location+@seed
set @location=charindex(@split,@str,@start)
set @next=@next+1
end
if @location =0 select @location =len(@str)+1
--這兒存在兩種情況:1、字符串不存在分隔符號 2、字符串中存在分隔符號,跳出while循環後,@location爲0,那默認爲字符串後邊有一個分隔符號。
return substring(@str,@start,@location-@start)
end ;
---測試。注意: P_GET_HttpRequestData 爲sqlserver獲取http請求數據的存儲過程,在Sqlserver處理Http請求日誌中有講述。
CREATE PROCEDURE IPCC_IVR_QUERYCARDONECINFO(@dataStr VARCHAR(255),@dataIndex VARCHAR(4),@outText1 VARCHAR(255) OUT,@outText2 VARCHAR(255) OUT,@outText3 VARCHAR(255) OUT)
AS
BEGIN
DECLARE @returnText VARCHAR(500)
DECLARE @status int
DECLARE @urlStr VARCHAR(255)
SET @urlStr = 'http://172.17.5.14:9090/df/sendDataToIVR.action?parametersStr='+@dataStr +'#'+@dataIndex+'&ifaceType=2';
EXEC P_GET_HttpRequestData @urlStr, @status OUTPUT, @returnText OUTPUT;
SET @outText1 = dbo.Get_StrArrayStrOfIndex(@returnText,',',1);
SET @outText2 = dbo.Get_StrArrayStrOfIndex(@returnText,',',2);
SET @outText3 = dbo.Get_StrArrayStrOfIndex(@returnText,',',3);
END;
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.