我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Sql Server 数据把列根据指定的内容拆分数据

短信预约 信息系统项目管理师 报名、考试、查分时间动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Sql Server 数据把列根据指定的内容拆分数据

Sql Server 数据把列根据指定的内容拆分数据

今天由于工作需要,需要把数据把列根据指定的内容拆分数据

其中一条数据实例

 select id , XXXX FROM BIZ_PAPER where  id ="4af210ec675927fa016772bf7dd025b0"

 

 

 

拆分方法:

select t3.id ,t3.XXXX as XXXX from (
select A.id , B.XXXX  from (
SELECT id, XXXX = CONVERT(xml,"" + REPLACE(XXXX , ",", "") + "") FROM BIZ_PAPER) A
outer apply(
SELECT XXXX = N.v.value(".", "varchar(100)") FROM A.XXXX .nodes("/root/v") N(v)) B) t3 where t3.id ="4af210ec675927fa016772bf7dd025b0"

结果

 

 

 在自己研究这行代码之后,做出如下讲解,如果有错误的地方还请指教

SELECT id, XXXX = CONVERT(xml,"" + REPLACE(XXXX , ",", "") + "") FROM BIZ_PAPER
这一行的重点在于CONVERT,XML是指类型,xml 数据类型实例拆分为关系数据,则 nodes() 方法非常有用,至于XML类型的数据,我后面进行补充

REPLACE 指按照 " , " 进行替换,并且按照指定的内容进行拼接

最后的结果为

 

outer apply

这个就是表的关联,就像是left join ,但是没有on 作为关联条件,所以通过拆分之后多出来的数据就是通过这个进行关联后产生的

 SELECT XXXX = N.v.value(".", "varchar(100)") FROM A.XXXX .nodes("/root/v") N(v)

N.v.value(".","varchar(100)"),N是表,别名,v是列,value函数是读取标签之间的值,对于这个列子,读取的为中间的值;这个可以去了解 xml类型的常用的三个方法 :value()、nodes()、exist()

value的第一个参数是一个字符串文字,从 XML 实例内部检索数据。 XQuery 必须最多返回一个值。 否则,将返回错误;

value的第二个参数是指将查询结果转化为何种类型的数据。

此处,"."表示当前目录,即目录,另外".."表示上级目录,"/"表示根目录,这个跟Linux是一样的

 

 

 总的来说,这个语句的重点在于xml类型的使用和outer apply的使用,其他的都很好理解。这个就是我自己理解后的讲解,部分位置我自己也还没有理解透

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Sql Server 数据把列根据指定的内容拆分数据

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Sql Server 数据把列根据指定的内容拆分数据

今天由于工作需要,需要把数据把列根据指定的内容拆分数据其中一条数据实例 select id , XXXX FROM BIZ_PAPER where  id ="4af210ec675927fa016772bf7dd025b0"   拆分方法: select t
Sql Server 数据把列根据指定的内容拆分数据
2020-11-04

Oracle根据逗号拆分字段内容转成多行的函数说明

目录使用场景1.业务表A2.实现拆分SQL3.REGEXP_SUBSTR函数1)参数说明2)案例4.REGEXP_REPLACE函数1)参数说明5.CONNECT BY函数1)基本语法2)案例6.LENGTH函数1)参数说明2)案例总结使用
2023-04-12

使用jdbc将mysql数据库中的内容封装为指定对象的list集合

使用jdbc将mysql数据库中的内容封装为指定对象的list集合public List findAll() { private JdbcTemplate template = new JdbcTemplate(JdbcUtils.getDataSour
使用jdbc将mysql数据库中的内容封装为指定对象的list集合
2017-09-23

MYSQL: sql中某一个字段内容为用逗号分割的字符串转换成多条数据(适用于部分树机构)

1.创建表的示例 CREATE TABLE tbl_name( id int(11) not null auto_increment, userName varchar(100) not null,
2023-08-17

SQLServer 错误 1204 SQL Server 数据库引擎的实例此时无法获得 LOCK 资源。 请在活动用户较少时重新运行该语句。 请询问数据库管理员,检查此实例的锁定和内存配置,或检查是否

详细信息 Attribute 值 产品名称 SQL Server 事件 ID 1204 事件源 MSSQLSERVER 组件 SQLEngine 符号名称 LK_OUTOF 消息正文 SQL Server ...
SQLServer 错误 1204 SQL Server 数据库引擎的实例此时无法获得 LOCK 资源。 请在活动用户较少时重新运行该语句。 请询问数据库管理员,检查此实例的锁定和内存配置,或检查是否
2023-11-05

编程热搜

目录