SQLServer解析JSON字符串-創(chuàng)新互聯(lián)

--------------------------------------------------- -----           解析字符串函數(shù)                ----- --------------------------------------------------- CREATE FUNCTION [dbo].[fn_split](@p_str VARCHAR(8000), @p_split VARCHAR(10)) RETURNS @tab TABLE(tid VARCHAR(2000)) AS BEGIN DECLARE @idx INT DECLARE @len INT SELECT @len = LEN(@p_split), @idx = CHARINDEX(@p_split, @p_str, 1) WHILE(@idx >= 1) BEGIN INSERT INTO @tab SELECT LEFT(@p_str, @idx - 1) SELECT @p_str = RIGHT(@p_str, LEN(@p_str) - @idx - @len + 1), @idx = CHARINDEX(@p_split, @p_str, 1) END if(@p_str <> '') INSERT INTO @tab SELECT @p_str RETURN END;------------------------------- --  解析JSON字符串  -- ------------------------------- --p_jsonstr json字符串 --p_key 鍵 --返回p_key對(duì)應(yīng)的值 CREATE FUNCTION [dbo].[fn_parsejson](@p_jsonstr VARCHAR(8000),                                  @p_key VARCHAR(200))  RETURNS VARCHAR(3000) AS       BEGIN DECLARE @rtnVal VARCHAR(3000);   DECLARE @i INT;   DECLARE @jsonkey VARCHAR(200);   DECLARE @jsonvalue VARCHAR(1000);   DECLARE @json VARCHAR(8000);   DECLARE @tmprow VARCHAR(2000);   DECLARE @tmpval VARCHAR(2000);      IF(@p_jsonstr IS NOT NULL) BEGIN      SET @json = REPLACE(@p_jsonstr, '{', '');      SET @json = REPLACE(@json, '}', '');      SET @json = REPLACE(@json, '"', ''); DECLARE @json_cur CURSOR;  -- 聲明外層游標(biāo) SET @json_cur = CURSOR FOR SELECT tid FROM fn_split(@json, ','); OPEN @json_cur-- 打開游標(biāo)(外層游標(biāo)) FETCH NEXT FROM @json_cur INTO @tmprow-- 提取外層游標(biāo)行 WHILE(@@FETCH_STATUS = 0) BEGIN IF(@tmprow IS NOT NULL) BEGIN SET @i = 0; SET @jsonkey = ''; SET @jsonvalue = ''; DECLARE @str_cur CURSOR;-- 聲明內(nèi)層游標(biāo) SET @str_cur = CURSOR FOR SELECT tid FROM fn_split(@tmprow, ':');--第二次拆分后的游標(biāo)(內(nèi)層游標(biāo)) OPEN @str_cur  -- 打開游標(biāo) FETCH NEXT FROM @str_cur INTO @tmpval-- 提取內(nèi)層游標(biāo)行 WHILE(@@FETCH_STATUS = 0) BEGIN IF(@i = 0)  BEGIN SET @jsonkey = @tmpval END IF(@i = 1) BEGIN SET @jsonvalue = @tmpval END SET @i = @i + 1 FETCH NEXT FROM @str_cur into @tmpval-- 內(nèi)層游標(biāo)下移一行 END CLOSE @str_cur-- 關(guān)閉內(nèi)層游標(biāo) DEALLOCATE @str_cur -- 釋放內(nèi)層游標(biāo) IF(@jsonkey = @p_key) BEGIN SET @rtnVal = @jsonvalue END END FETCH NEXT FROM @json_cur INTO @tmprow-- 內(nèi)層游標(biāo)結(jié)束后,外層游標(biāo)下移一行 END CLOSE @json_cur-- 關(guān)閉外層游標(biāo) DEALLOCATE @json_cur-- 釋放外層游標(biāo) END       RETURN @rtnVal   END

使用示例:

創(chuàng)新互聯(lián)公司-專業(yè)網(wǎng)站定制、快速模板網(wǎng)站建設(shè)、高性價(jià)比景縣網(wǎng)站開發(fā)、企業(yè)建站全套包干低至880元,成熟完善的模板庫(kù),直接使用。一站式景縣網(wǎng)站制作公司更省心,省錢,快速模板網(wǎng)站建設(shè)找我們,業(yè)務(wù)覆蓋景縣地區(qū)。費(fèi)用合理售后完善,十余年實(shí)體公司更值得信賴。Select dbo.fn_parsejson( '{"billPrice":"1.67","buyDate":"2009-12-30","currentStatus":"有租約", "decoration":"精裝","empCode":"174999",","houseId":"F20BEBE259794C858C76122BCBACC71F", "id":"36398","isAccompany":"0","isCollect":"1","isOnlyOne":"1", "isShotProperty":"1","noCollectReason":"","parking":"0","propertyNo":"5885109", "recordDate":"2017-06-08","recordRemark":"啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊"}' ,'buyDate')

另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)cdcxhl.cn,海內(nèi)外云服務(wù)器15元起步,三天無(wú)理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國(guó)服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡(jiǎn)單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢(shì),專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場(chǎng)景需求。

分享文章:SQLServer解析JSON字符串-創(chuàng)新互聯(lián)
文章來(lái)源:http://muchs.cn/article2/pepoc.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供外貿(mào)建站、外貿(mào)網(wǎng)站建設(shè)、Google、微信小程序網(wǎng)站排名、用戶體驗(yàn)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

成都定制網(wǎng)站建設(shè)