SQL 查找字符串中的第一个非数字字符

2023-10-09数据库问题
79

本文介绍了SQL 查找字符串中的第一个非数字字符的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着跟版网的小编来一起学习吧!

问题描述

我继承了一个带有 [nonnumericprefix][number] 格式标识符的表格.例如(ABC123;R2D2456778;等等).我想知道是否有一种很好的方法可以将 SQL 中的它分成两个字段,从右侧形成的最大整数和前缀,例如 (ABC, 123; R2D, 2456778; etc).我知道我可以使用游标、C# 代码等来做到这一点——如果必须的话,我会这样做——但我不会经常遇到我在 SQL 中无法快速轻松地完成的事情,所以我想我会发布它在这里.

I inherited a table with identifiers in a format [nonnumericprefix][number]. For example (ABC123; R2D2456778; etc). I was wondering if there was a good way to split this in SQL into two fields, the largest integer formed from the right side, and the prefix, for example (ABC, 123; R2D, 2456778; etc). I know I can do this with a cursor, C# code, etc - and I will if I have to - but I don't run into things I cannot do fast and easily in SQL very often, so I thought I'd post it here.

推荐答案

  1. 反转字符串
  2. 使用 PATINDEX 查找第一次出现的非数字字段
  3. 使用 LEFT 函数返回字符串的数字部分

代码示例

DECLARE @myString varchar(100);
DECLARE @largestInt int;

SET @myString = 'R2D2456778'

SET @mystring = REVERSE(@myString);
SET @largestInt = LEFT(@myString, PATINDEX('%[a-z]%', @myString) - 1)

PRINT ( CONVERT(varchar(100), @largestInt) )

这篇关于SQL 查找字符串中的第一个非数字字符的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持跟版网!

The End

相关推荐

按天分组的 SQL 查询
SQL query to group by day(按天分组的 SQL 查询)...
2024-04-16 数据库问题
77

在 Group By 查询中包含缺失的月份
Include missing months in Group By query(在 Group By 查询中包含缺失的月份)...
2024-04-16 数据库问题
12

sql group by 与不同
sql group by versus distinct(sql group by 与不同)...
2024-04-16 数据库问题
37

如何在SQL中返回每个组的增量组号
How to return a incremental group number per group in SQL(如何在SQL中返回每个组的增量组号)...
2024-04-16 数据库问题
8

统计分组返回的记录数
Count number of records returned by group by(统计分组返回的记录数)...
2024-04-16 数据库问题
10

带聚合函数的 SQL GROUP BY CASE 语句
SQL GROUP BY CASE statement with aggregate function(带聚合函数的 SQL GROUP BY CASE 语句)...
2024-04-16 数据库问题
23