SqlServer中以xml作为参数创建表格的存储过程

用到的工具:

  • SqlServer
  • java
  • mybatis

第一步:创建function,用于获取xml中的数据

 CREATE function create_table (@str xml)
 returns @tb table(sourceId varchar(20))
 as
 begin
      insert into @tb 
         SELECT
         v.value('@sourceId[1]','VARCHAR(20)') AS sourceId
        FROM @str.nodes('/RSSsources/rssSource') x(v)
    return   
 end

第二步:用存储过程调用上面的函数创建表格

CREATE PROCEDURE T_PRO(@doc xml)
 AS
 BEGIN
    
     CREATE TABLE tbl(sourceId varchar(20))
     INSERT INTO tbl
     select b.sourceId from 
     create_table(@doc) b
 END

第三步:在数据库中调用存储过程

 DECLARE @doc xml 
 SET @doc = '<RSSsources><rssSource sourceId="1"/><rssSource sourceId="2"/><rssSource sourceId="3"/><rssSource sourceId="4"/></RSSsources>'

 EXEC T_PRO @doc

第四步:mybatis调用存储过程

<select id="createTable" statementType="CALLABLE" resultType="string">
        {call T_PRO(#{xml})}
</select>

第五步:java程序中调用存储过程

SqlSessionFactory factory = GetSqlSessionFactory.getInstance();
SqlSession sqlSession = factory.openSession();
NewsInfoMapper mapper = sqlSession.getMapper(NewsInfoMapper.class);
String sourceXml = "<RSSsources><rssSource sourceId=\"1\"/><rssSource sourceId=\"2\"/><rssSource sourceId=\"3\"/><rssSource sourceId="4"/></RSSsources>";
mapper.createTable(sourceXml);
sqlSession.commit();
sqlSession.close();

 

转载于:https://www.cnblogs.com/hzwl-2015/p/4228914.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值