使用XML在MSSQL把字串分解
今天要在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('<email>'+replace(@cc,';','</email><email>')+'</email>' 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/* 这里要注意。不知道为什么, <root><email>Email1</email><email>Email2</email><root>格式是只能处理一个email地址。 <root><data><email>Email1</email></data><data><email>Email2</email></data><root> 可以处理全部的emails。*/set @xml2 = '<root><data><email>'+replace(@cc,';','</email></data><data><email>')+'</email></data></root>'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能通过,要修改一下就代码。