设为首页收藏本站Access中国

Office中国论坛/Access中国论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

12
返回列表 发新帖
楼主: roych
打印 上一主题 下一主题

[模块/函数] 【新手入门】之六:“悲欢离合总无情”——浅谈Split和Join

[复制链接]
11#
发表于 2013-3-28 21:26:55 | 只看该作者
版主很会讲故事。
12#
发表于 2016-3-18 14:01:17 | 只看该作者
哈哈,ROYCH 和冬瓜有一拼  技术型加诗人
13#
发表于 2016-4-19 16:26:03 | 只看该作者
本帖最后由 wu8313 于 2016-5-9 10:30 编辑

1、使用自定义 sql 函数 也可以处理,编码量会少一些。(我没有写用户界面来呈现数据)

2、我直接抄袭别人的函数,稍微改动了一下,原作者返回值为 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

--创建字符串分拆的函数
create function [dbo].[fsplit_拆分短信](
@str varchar(8000)        --要分拆的字符串
,@spli varchar(10)        --字符串分隔符
)
returns @T_原始短信内容 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_原始短信内容 values(left(@str,@i-1))
select @str=substring(@str,@i+@splen,8000)
,@i=charindex(@spli,@str)
end
if @str<>'' insert into @T_原始短信内容 values(@str)
return
end

GO

--调用
select [被拆分的短信] from dbo.fsplit_拆分短信
('13021123456#我们已经完成了所有的工作,大家尽情的享受愉快的假期。#20120605083012#||'+
'14232345678#信息已经收到。#20120506083134#||'+
'13126666666#祝贺少年管弦乐团取得优异成绩,感谢辅导教师的努力。#20120605093012#||'+
'13888888888#近期暴雨频繁,请各位员工出行注意安全。#20120605093412#','#||')

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有帐号?注册

x
14#
发表于 2016-5-9 10:32:20 | 只看该作者
帖子已更新。修改了 函数 返回值 的数据类型,并贴上了 短信的原始内容。
15#
发表于 2023-12-11 22:43:41 | 只看该作者
谢谢分享
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则

QQ|站长邮箱|小黑屋|手机版|Office中国/Access中国 ( 粤ICP备10043721号-1 )  

GMT+8, 2024-5-1 00:09 , Processed in 0.092076 second(s), 28 queries .

Powered by Discuz! X3.3

© 2001-2017 Comsenz Inc.

快速回复 返回顶部 返回列表