首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Server中有LastIndexOf吗?

Server中有LastIndexOf吗?
EN

Stack Overflow用户
提问于 2016-08-17 16:38:34
回答 8查看 123.3K关注 0票数 101

我正在尝试从一个字符串中解析一个值,该字符串涉及到获取一个最后的 索引字符串。目前,我正在进行一次可怕的黑客攻击,其中涉及反转字符串:

代码语言:javascript
复制
SELECT REVERSE(SUBSTRING(REVERSE(DB_NAME()), 1, 
    CHARINDEX('_', REVERSE(DB_NAME()), 1) - 1))

对我来说,这段代码几乎是不可读的。我刚刚升级到Server 2016,我希望有一个更好的方法。在那里吗?

EN

回答 8

Stack Overflow用户

回答已采纳

发布于 2016-08-17 16:46:02

如果您希望在上一次_之后的所有内容,那么使用:

代码语言:javascript
复制
select right(db_name(), charindex('_', reverse(db_name()) + '_') - 1)

如果您之前想要所有的东西,那么使用left()

代码语言:javascript
复制
select left(db_name(), len(db_name()) - charindex('_', reverse(db_name()) + '_'))
票数 251
EN

Stack Overflow用户

发布于 2018-01-18 08:24:02

编写了2个函数,1用于返回所选字符的LastIndexOf

代码语言:javascript
复制
CREATE FUNCTION dbo.LastIndexOf(@source nvarchar(80), @pattern char)
RETURNS int
BEGIN  
       RETURN (LEN(@source)) -  CHARINDEX(@pattern, REVERSE(@source)) 
END;  
GO

并在此LastIndexOf之前返回一个字符串。也许它会对某人有用。

代码语言:javascript
复制
CREATE FUNCTION dbo.StringBeforeLastIndex(@source nvarchar(80), @pattern char)
RETURNS nvarchar(80)
BEGIN  
       DECLARE @lastIndex int
       SET @lastIndex = (LEN(@source)) -  CHARINDEX(@pattern, REVERSE(@source)) 

     RETURN SUBSTRING(@source, 0, @lastindex + 1) 
     -- +1 because index starts at 0, but length at 1, so to get up to 11th index, we need LENGTH 11+1=12
END;  
GO
票数 27
EN

Stack Overflow用户

发布于 2016-08-17 16:47:28

不,server没有LastIndexOf。

这是可用的字符串函数

但是您可以始终创建自己的函数。

代码语言:javascript
复制
CREATE FUNCTION dbo.LastIndexOf(@source text, @pattern char)  
RETURNS 
AS       
BEGIN  
    DECLARE @ret text;  
    SELECT into @ret
           REVERSE(SUBSTRING(REVERSE(@source), 1, 
           CHARINDEX(@pattern, REVERSE(@source), 1) - 1))
    RETURN @ret;  
END;  
GO 
票数 8
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/39002025

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档