設(shè)為首頁收藏本站Access中國

Office中國論壇/Access中國論壇

 找回密碼
 注冊

QQ登錄

只需一步,快速開始

12
返回列表 發(fā)新帖
樓主: roych
打印 上一主題 下一主題

[模塊/函數(shù)] 【新手入門】之六:“悲歡離合總無情”——淺談Split和Join

[復(fù)制鏈接]
11#
發(fā)表于 2013-3-28 21:26:55 | 只看該作者
版主很會講故事。
12#
發(fā)表于 2016-3-18 14:01:17 | 只看該作者
哈哈,ROYCH 和冬瓜有一拼  技術(shù)型加詩人
13#
發(fā)表于 2016-4-19 16:26:03 | 只看該作者
本帖最后由 wu8313 于 2016-5-9 10:30 編輯

1、使用自定義 sql 函數(shù) 也可以處理,編碼量會少一些。(我沒有寫用戶界面來呈現(xiàn)數(shù)據(jù))

2、我直接抄襲別人的函數(shù),稍微改動了一下,原作者返回值為 int ,我只是改為 nvarchar(4000) 而已。

============================================================

IF  EXISTS (SELECT * FROM sys.objects WHERE object_id = OBJECT_ID(N'[dbo].[fsplit_拆分短信]') AND type in (N'FN', N'IF', N'TF', N'FS', N'FT'))
DROP FUNCTION [dbo].[fsplit_拆分短信]
GO

--創(chuàng)建字符串分拆的函數(shù)
create function [dbo].[fsplit_拆分短信](
@str varchar(8000)        --要分拆的字符串
,@spli varchar(10)        --字符串分隔符
)
returns @T_原始短信內(nèi)容 table(被拆分的短信 nvarchar(4000))
as
begin
declare @i int,@splen int
select @splen=len(@spli)
,@i=charindex(@spli,@str)
while @i>0
begin
insert into @T_原始短信內(nèi)容 values(left(@str,@i-1))
select @str=substring(@str,@i+@splen,8000)
,@i=charindex(@spli,@str)
end
if @str<>'' insert into @T_原始短信內(nèi)容 values(@str)
return
end

GO

--調(diào)用
select [被拆分的短信] from dbo.fsplit_拆分短信
('13021123456#我們已經(jīng)完成了所有的工作,大家盡情的享受愉快的假期。#20120605083012#||'+
'14232345678#信息已經(jīng)收到。#20120506083134#||'+
'13126666666#祝賀少年管弦樂團(tuán)取得優(yōu)異成績,感謝輔導(dǎo)教師的努力。#20120605093012#||'+
'13888888888#近期暴雨頻繁,請各位員工出行注意安全。#20120605093412#','#||')

本帖子中包含更多資源

您需要 登錄 才可以下載或查看,沒有帳號?注冊

x
14#
發(fā)表于 2016-5-9 10:32:20 | 只看該作者
帖子已更新。修改了 函數(shù) 返回值 的數(shù)據(jù)類型,并貼上了 短信的原始內(nèi)容。
15#
發(fā)表于 2023-12-11 22:43:41 | 只看該作者
謝謝分享
回復(fù)

使用道具 舉報

您需要登錄后才可以回帖 登錄 | 注冊

本版積分規(guī)則

QQ|站長郵箱|小黑屋|手機(jī)版|Office中國/Access中國 ( 粵ICP備10043721號-1 )  

GMT+8, 2025-7-17 00:38 , Processed in 0.085026 second(s), 28 queries .

Powered by Discuz! X3.3

© 2001-2017 Comsenz Inc.

快速回復(fù) 返回頂部 返回列表