SQL查找字符串中的第一个非数字字符 [英] SQL to find first non-numeric character in a string

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

问题描述

我继承了一个表,该表的标识符格式为[nonnumericprefix] [number].例如(ABC123; R2D2456778;等).我想知道是否有个好方法可以在SQL中将其分为两个字段,即从右侧形成的最大整数和前缀(例如,ABC,123,R2D,2456778等).我知道我可以使用游标,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查找字符串中的第一个非数字字符的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆