zoukankan      html  css  js  c++  java
  • SQL中的charindex函数与reverse函数用法

       ----------------------首先介绍charindex函数-----------------------------                                                                                                                                                                                                               
       CHARINDEX函数返回字符或者字符串在另一个字符串中的起始位置。
       CHARINDEX函数调用方法如下:

           CHARINDEX ( expression1 , expression2 [ , start_location ] )

           Expression1是要到expression2中寻找的字符中,start_location是CHARINDEX函数开始在expression2中找expression1的位置。

           CHARINDEX函数返回一个整数,返回的整数是要找的字符串在被找的字符串中的位置。假如CHARINDEX没有找到要找的字符串,那么函数整数“0”。让我们看看下面的函数命令执行的结果:

          CHARINDEX('SQL', 'Microsoft SQL Server')

          这个函数命令将返回在“Microsoft SQL Server”中“SQL”的起始位置,在这个例子中,CHARINDEX函数将返回“S”在“Microsoft SQL Server”中的位置11。
    接下来,我们看这个CHARINDEX命令:

          CHARINDEX('7.0', 'Microsoft SQL Server 2000')

          在这个例子中,CHARINDEX返回零,因为字符串“7.0” 不能在“Microsoft SQL Server”中被找到。接下来通过两个例子来看看如何使用CHARINDEX函数来解决实际的T-SQL问题。

     ------------------------这里是reverse函数------------------------------

       REVERSE函数返回字符串str的字符颠倒顺序。

       REVERSE函数调用方法如下:

        SQL--> select reverse('abcd');

         --->REVERSE('abcd')

         --->dcba

      --------------------charindex,reverse,substring函数综合运用:MS_SQL获取字符串最后出现的字符串及位置-----------------

      

    一.如:'6.7.8.2.3.4.x'得到最后一个'.'后面的字符串:

    declare @str1 varchar(50)

    set @str1='6.7.8.2.3.4.x'

    select REVERSE(SUBSTRING(REVERSE(@str1),1,CHARINDEX('.',REVERSE(@str1))-1)) -------- string:'x'--

    ------>>>----

    二.如:'6.7.8.2.3.4.x'得到最后一个'.'前面的字符串:

    declare @str2 varchar(50)

    set @str2='6.7.8.2.3.4.x'

    SELECT substring(@str2,1,(LEN(@str2)-CHARINDEX('.',REVERSE(@str2)))) -------- string:'6.7.8.2.3.4'--

    ------->>>----

    三.如:'6.7.8.2.3.4.x'得到最后一个'.'在字符串的位置:

    declare @str3 varchar(50)

    set @str3='6.7.8.2.3.4.x'

    SELECT LEN(@str3)-CHARINDEX('.',REVERSE(@str3))+1 --------Integer:12--

  • 相关阅读:
    解决 Windows Server 2008 R2 上 Windows Update 无法失败,提示 8024402F
    【UWP】实现 FindAncestor 绑定
    实现在 .net 中使用 HttpClient 下载文件时显示进度
    【UWP】手动实现 WebAuthenticationBroker
    记录使用 Cake 进行构建并制作 nuget 包
    w筛选系数=(1+错次)/(1+总次)
    WZP身份溯源策略(World Zero Protection),宜分宜合、自主可控的实名认证体系
    WZP报文封装协议(Web Zip Protocol),安全可嵌套的传输协议
    WZP安全配置方案,针对通讯技术的安全措施
    WZP网络结构模型,对OSI参考模型和TCP/IP模型的改进
  • 原文地址:https://www.cnblogs.com/Annayang/p/3809978.html
Copyright © 2011-2022 走看看