博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
使用XML在MSSQL把字串分解
阅读量:6503 次
发布时间:2019-06-24

本文共 1512 字,大约阅读时间需要 5 分钟。

今天要在mssql里处理一串Email地址。以分号分开的。以前自己写过一个split函数的。这次想使用xml来处理。

mssql 2000和mssql 2005数据库对xml的支持有些不同。至少mssql 2005的功能多些。

 

代码一:

这个代码在MSSQL 2005测试成功, 在mssql 2000不通过。最后生成一个表变量。使用者可以把表变量转成需要的数据

--定义一个拿来测试的字串declare @cc varchar(1000)set @cc = 'hello@163.com;world@hotmail.com;iloveyou@yahoo.com'--定义一个表变量declare @emailtable table(    email varchar(50))--定义一个XML变量declare @xml xmlset @xml = cast('
'+replace(@cc,';','
')+'
' as xml)insert into @emailtable (email)select t.i.value('.', 'varchar(50)') from @xml.nodes('email') t(i)select * from @emailtable

代码二:
这个代码在MSSQL 2005测试成功, 在mssql 2000没有时间测试。下星期测试再修改这里。最后生成一个表变量。使用者可以把表变量转成需要的数据

--定义一个拿来测试的字串declare @cc varchar(1000)set @cc = 'hello@163.com;world@hotmail.com;iloveyou@yahoo.com'--定义一个表变量declare @emailtable table(    email varchar(50))--XML字串变量declare @xml2 varchar(1000)--XML handlerdeclare @xmlid int/*   这里要注意。不知道为什么,    
Email1
Email2
格式是只能处理一个email地址。
Email1
Email2
可以处理全部的emails。*/set @xml2 = '
'+replace(@cc,';','
')+'
'exec sp_xml_preparedocument @xmlid output, @xml2insert into @emailtable select * from openxml(@xmlid, '/root/data', 2) with(email varchar(50) 'email')select * from @emailtablesp_xml_removedocument @xmlid

使用XML的方法,比我以前写的那个痛快多了。如果MSSQL 2000能通过,要修改一下就代码。

转载于:https://www.cnblogs.com/jianfangkk/archive/2011/12/17/2291458.html

你可能感兴趣的文章
我的友情链接
查看>>
【Visual C++】游戏开发笔记十三 游戏输入消息处理(二) 鼠标消息处理
查看>>
我的友情链接
查看>>
Java 使用 Redis
查看>>
JPA常用注解
查看>>
Java基础学习总结(1)——equals方法
查看>>
Maven学习总结(6)——Maven与Eclipse整合
查看>>
HTML5:理解head
查看>>
oracle
查看>>
java SpringUtil获取bean
查看>>
Centos6.4最小化安装系统初始化脚本
查看>>
PaaS变厚了
查看>>
赛门铁克开启“容灾即服务”时代
查看>>
复杂度归纳--小结
查看>>
PHP学习笔记 第八讲 Mysql.简介和创建新的数据库
查看>>
【git】git入门之把自己的项目上传到github
查看>>
js获取鼠标位置
查看>>
2016.8.11 DataTable合并及排除重复方法
查看>>
php 魔术方法 说明
查看>>
Mysql
查看>>