T-SQL 获取数据库中每行的第 5 个单词

T-SQL to get the 5th word in each row in a database(T-SQL 获取数据库中每行的第 5 个单词)
本文介绍了T-SQL 获取数据库中每行的第 5 个单词的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我需要找出如何编写 T-SQL 来获取数据库中每一行中的第 5 个单词

I need to find out how to code T-SQL that gets the 5th word in each row in a database

推荐答案

确保顺序的一个选项是使用一点 XML

One option which will ensure sequence is to use a bit of XML

示例

Declare @YourTable table (ID int, SomeCol varchar(100))
Insert into @YourTable Values
 (1,'Some text that needs to be parsed')
,(2,'Only three words')

Select A.ID
      ,Pos5  =  cast('<x>' + replace(SomeCol,' ','</x><x>')+'</x>' as xml).value('/x[5]','varchar(50)')
 From  @YourTable A

退货

ID  Pos5
1   to
2   NULL

这篇关于T-SQL 获取数据库中每行的第 5 个单词的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!

本站部分内容来源互联网,如果有图片或者内容侵犯您的权益请联系我们删除!

相关文档推荐

Execute complex raw SQL query in EF6(在EF6中执行复杂的原始SQL查询)
Hibernate reactive No Vert.x context active in aws rds(AWS RDS中的休眠反应性非Vert.x上下文处于活动状态)
Bulk insert with mysql2 and NodeJs throws 500(使用mysql2和NodeJS的大容量插入抛出500)
Flask + PyMySQL giving error no attribute #39;settimeout#39;(FlASK+PyMySQL给出错误,没有属性#39;setTimeout#39;)
auto_increment column for a group of rows?(一组行的AUTO_INCREMENT列?)
Sort by ID DESC(按ID代码排序)