第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號(hào)安全,請及時(shí)綁定郵箱和手機(jī)立即綁定
已解決430363個(gè)問題,去搜搜看,總會(huì)有你想問的

解析逗號(hào)分隔的字符串以在Where子句中生成IN字符串列表

解析逗號(hào)分隔的字符串以在Where子句中生成IN字符串列表

蝴蝶不菲 2019-11-02 10:06:36
我的存儲(chǔ)過程收到一個(gè)參數(shù),該參數(shù)是逗號(hào)分隔的字符串:DECLARE @Account AS VARCHAR(200)SET @Account = 'SA,A'我需要從中作出這樣的陳述:WHERE Account IN ('SA', 'A')最佳做法是什么?
查看完整描述

3 回答

?
心有法竹

TA貢獻(xiàn)1866條經(jīng)驗(yàn) 獲得超5個(gè)贊

創(chuàng)建此函數(shù)(sqlserver 2005+)


CREATE function [dbo].[f_split]

(

@param nvarchar(max), 

@delimiter char(1)

)

returns @t table (val nvarchar(max), seq int)

as

begin

set @param += @delimiter


;with a as

(

select cast(1 as bigint) f, charindex(@delimiter, @param) t, 1 seq

union all

select t + 1, charindex(@delimiter, @param, t + 1), seq + 1

from a

where charindex(@delimiter, @param, t + 1) > 0

)

insert @t

select substring(@param, f, t - f), seq from a

option (maxrecursion 0)

return

end

使用此語句


SELECT *

FROM yourtable 

WHERE account in (SELECT val FROM dbo.f_split(@account, ','))

比較我的split函數(shù)和XML split:


測試數(shù)據(jù):


select top 100000 cast(a.number as varchar(10))+','+a.type +','+ cast(a.status as varchar(9))+','+cast(b.number as varchar(10))+','+b.type +','+ cast(b.status as varchar(9)) txt into a 

from master..spt_values a cross join master..spt_values b

XML:


 SELECT count(t.c.value('.', 'VARCHAR(20)'))

 FROM (

     SELECT top 100000 x = CAST('<t>' + 

           REPLACE(txt, ',', '</t><t>') + '</t>' AS XML)

           from a

 ) a

 CROSS APPLY x.nodes('/t') t(c)


Elapsed time: 1:21 seconds

f_split:


select count(*) from a cross apply clausens_base.dbo.f_split(a.txt, ',')


Elapsed time: 43 seconds

這會(huì)隨著時(shí)間的流逝而變化,但是您會(huì)明白


查看完整回答
反對(duì) 回復(fù) 2019-11-02
?
慕田峪7331174

TA貢獻(xiàn)1828條經(jīng)驗(yàn) 獲得超13個(gè)贊

最有效的方法是對(duì)拆分字符串使用CLR函數(shù)。請參閱本文以獲取示例和性能比較


查看完整回答
反對(duì) 回復(fù) 2019-11-02
  • 3 回答
  • 0 關(guān)注
  • 818 瀏覽
慕課專欄
更多

添加回答

舉報(bào)

0/150
提交
取消
微信客服

購課補(bǔ)貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動(dòng)學(xué)習(xí)伙伴

公眾號(hào)

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號(hào)