今天要在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('代码二:这个代码在MSSQL 2005测试成功, 在mssql 2000没有时间测试。下星期测试再修改这里。最后生成一个表变量。使用者可以把表变量转成需要的数据'+replace(@cc,';',' ')+' ' as xml)insert into @emailtable (email)select t.i.value('.', 'varchar(50)') from @xml.nodes('email') t(i)select * from @emailtable
--定义一个拿来测试的字串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/* 这里要注意。不知道为什么,使用XML的方法,比我以前写的那个痛快多了。如果MSSQL 2000能通过,要修改一下就代码。Email1 Email2 格式是只能处理一个email地址。 Email1 Email2 可以处理全部的emails。*/set @xml2 = ' '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 '+replace(@cc,';',' ')+'