zoukankan      html  css  js  c++  java
  • 一个字段串拆分成多行显示或者多行数据合并成一个字符串

    DECLARE @table1 TABLE
        (
          ID INT ,
          Col1 NVARCHAR(50) ,
          Col2 NVARCHAR(50)
        );
    INSERT  INTO @table1
    VALUES  ( 1, 'a,b,c', '诶,必,塞,地,伊' );
    INSERT  INTO @table1
    VALUES  ( 2, 'w', N'三四,不知道咧' ); 
    --方式一
    SELECT  a.ID ,
            a.Col1 ,
            a.Col2 ,
            v1 ,
            v2
    FROM    ( SELECT    ID ,
                        Col1 ,
                        Col2 ,
                        CONVERT(XML, '<n>' + REPLACE(REPLACE(Col1, '', ','), ',',
                                                     '</n><n>') + '</n>') AS xmlval1 ,
                        CONVERT(XML, '<n>' + REPLACE(REPLACE(Col2, '', ','), ',',
                                                     '</n><n>') + '</n>') AS xmlval2
              FROM      @table1
            ) a
            CROSS APPLY ( SELECT    k.n.value('.', 'nvarchar(80)') v1
                          FROM      a.xmlval1.nodes('n') k ( n )
                        ) bs
            CROSS APPLY ( SELECT    k.n.value('.', 'nvarchar(80)') v2
                          FROM      a.xmlval2.nodes('n') k ( n )
                        ) ns;
      --方式二
    SELECT  ID ,
            t.Col1 ,
            t.Col2 ,
            v1 ,
            v2
    FROM    @table1 AS t
            CROSS APPLY ( VALUES
            ( CONVERT(XML, '<n>' + REPLACE(REPLACE(Col1, '', ','), ',', '</n><n>')
            + '</n>'), CONVERT(XML, '<n>' + REPLACE(REPLACE(Col2, '', ','), ',',
                                                    '</n><n>') + '</n>')) ) a ( xmlval1, xmlval2 )
                                                                  CROSS APPLY ( SELECT
                                                                  k.n.value('.',
                                                                  'varchar(80)') AS v1
                                                                  FROM
                                                                  a.xmlval1.nodes('n') k ( n )
                                                                  ) bs
            CROSS APPLY ( SELECT    k.n.value('.', 'varchar(80)') AS v2
                          FROM      a.xmlval2.nodes('n') k ( n )
                        ) ns;

     转自:https://www.cnblogs.com/springsnow/p/10289104.html

  • 相关阅读:
    Kafka 配置说明
    Ubuntu中网络配置问题
    vuecli全家桶搭建个人博客并迁移nuxtjs由后端服务渲染页面
    记录vim模式快捷键
    开发常用mac软件推荐(JetBrains IntelliJ IDEA 2019 for Mac, Parallels Desktop 15 for Mac,cleanmymac, MindNode 7 for mac 思维导图软件)
    gulp4 多页面项目管理打包(html, es6,less编译压缩版本控制)
    Adobe Photoshop 2021 for mac(PS 2020) v22.0.0中文激活破解版
    git 常用命令使用,git bash通用命令
    mac百度网盘破解版免费
    好久木来了,一直忙于项目太忙(tailan),今天讲讲vuecli3.0的使用
  • 原文地址:https://www.cnblogs.com/yyl001/p/13522571.html
Copyright © 2011-2022 走看看