sql 截取域名的问题_MsSql

最近由于对数据库的域名要排重,因为sql直接使用起来方便一些,就整理下

A.截取从字符串左边开始N个字符

复制代码 代码如下:

   Declare @S1 varchar(100)
   Select @S1='http://www.jb51.net'
   Select Left(@S1,4)

   ------------------------------------
   显示结果: http

B.截取从字符串右边开始N个字符(例如取字符www.jb51.net)

复制代码 代码如下:

   Declare @S1 varchar(100)
   Select @S1='http://www.jb51.net'
   Select right(@S1,11) 

   ------------------------------------
   显示结果: www.jb51.net

C.截取字符串中任意位置及长度(例如取字符www)

复制代码 代码如下:

   Declare @S1 varchar(100)
   Select @S1='http://www.jb51.net'
   Select SUBSTRING(@S1,8,3) 

   ------------------------------------
   显示结果: www.jb51.net

   以上例子皆是已知截取位置及长度,下面介绍未知位置的例子

2.截取未知位置的函数

A.截取指定字符串后的字符串(例如截取http://后面的字符串)

   方法一:

复制代码 代码如下:

   Declare @S1 varchar(100)
   Select @S1='http://www.jb51.net' 
   Select Substring(@S1,CHARINDEX('www',@S1)+1,Len(@S1))
   /*此处也可以这样写:Select Substring(@S1,CHARINDEX('//',@S1)+2,Len(@S1))*/

   ------------------------------------
   显示结果: www.jb51.net

   需要注意:CHARINDEX函数搜索字符串时,不区分大小写,因此CHARINDEX('www',@S1)也可以写成CHARINDEX('WWW',@S1)

   方法二:(与方法一类似)

复制代码 代码如下:

   Declare @S1 varchar(100)
   Select @S1='http://www.jb51.net' 
   Select Substring(@S1,PATINDEX('%www%',@S1)+1,Len(@S1))
   --此处也可以这样写:Select Substring(@S1,PATINDEX('%//%',@S1)+2,Len(@S1))

   ------------------------------------
   显示结果: www.jb51.net  

   函数PATINDEX与CHARINDEX区别在于:前者可以参数一些参数,增加查询的功能

   方法三:

复制代码 代码如下:

   Declare @S1 varchar(100)
   Select @S1='http://www.jb51.net' 
   Select REPLACE(@S1,'http://','')

   ------------------------------------
   显示结果: www.jb51.net

   利用字符替换函数REPLACE,将除需要显示字符串外的字符替换为空

   方法四:

复制代码 代码如下:

   Declare @S1 varchar(100)
   Select @S1='http://www.jb51.net' 
   Select STUFF(@S1,CHARINDEX('http://',@S1),Len('http://'),'')

   ------------------------------------
   显示结果: www.jb51.net  

   函数STUFF与REPLACE区别在于:前者可以指定替换范围,而后者则是全部范围内替换

B.截取指定字符后的字符串(例如截取C:\Windows\test.txt中文件名)
   与A不同的是,当搜索对象不是一个时,利用上面的方法只能搜索到第一个位置

   方法一:

复制代码 代码如下:

   Declare @S1 varchar(100)
   Select @S1='C:\Windows\test.txt'
   select right(@S1,charindex('\',REVERSE(@S1))-1)

   -------------------------------------
   显示结果: text.txt

利用函数REVERSE获取需要截取的字符串长度

上面的这些方法能解决基本问题,但当本身数据库中的域名不是标准的域名整体(例:http://a.com、http://a.com/a.aspx、http://www.a.com/www/a.aspx)
这个时候截取的sql就要复杂点了,最终的关键还是在于善用 Substring,charindex两个函数,基本都可以解决

时间: 2025-01-29 17:45:24

sql 截取域名的问题_MsSql的相关文章

sql 截取域名的问题

最近由于对数据库的域名要排重,因为sql直接使用起来方便一些,就整理下 A.截取从字符串左边开始N个字符 复制代码 代码如下:   Declare @S1 varchar(100)   Select @S1='http://www.jb51.net'   Select Left(@S1,4) ------------------------------------   显示结果: http B.截取从字符串右边开始N个字符(例如取字符www.jb51.net) 复制代码 代码如下:   Decl

SQL 截取字符串应用代码_MsSql

SUBSTRING 返回字符.binary.text 或 image 表达式的一部分.有关可与该函数一起使用的有效 Microsoft SQL Server 数据类型的更多信息,请参见数据类型. 语法 SUBSTRING ( expression , start , length ) 参数 expression 是字符串.二进制字符串.text.image.列或包含列的表达式.不要使用包含聚合函数的表达式. start 是一个整数,指定子串的开始位置. length 是一个整数,指定子串的长度(

SQL截取字符串函数分享_MsSql

A.截取从字符串左边开始N个字符 Declare @S1 varchar(100) Select @S1='http://www.xrss.cn' Select Left(@S1,4) ------------------------------------ 显示结果: http B.截取从字符串右边开始N个字符(例如取字符www.163.com) Declare @S1 varchar(100) Select @S1='http://www.163.com' Select right(@S1,

sql server-怎么用sql截取一篇文章中的每一句话?

问题描述 怎么用sql截取一篇文章中的每一句话? 我觉得是按句号截取 但是我只能做的算出每个句号的位置 求指教怎么截取每一句话且显示的时候是每一行一句 谢谢 解决方案 通过split('.')来分割,然后遍历输出,每输出一句后,添加一个换行符就行啦 解决方案二: spilt ( ) 按内容分割 今天刚在js看到··· 解决方案三: 你可以用多维数组,比如,String[] str=内容.spilt("."); 这是截取句号的内容,如果不够,再生成下一个数组,就这样就好了啊 解决方案四:

oracle中sql 截取字段中的数字按条件排序

问题描述 oracle中sql 截取字段中的数字按条件排序 请教各位,这个sql怎么拼,我的字段(code)规则是:备案事项[2014]1,前面中文是固定的,然后是括起来的年份(可能是2013,2014,2015等等),后面是流水号(从1,2,3,...,10,..递增的),我想查出所有2013年的数据,要求按后面的流程号数字倒叙排列.恳求大神帮忙,谢谢! 解决方案 假设字段名是code SELECT code, substr(code,INSTR(code,'[', 0, 1)+1,INSTR

深入SQL截取字符串(substring与patindex)的详解_MsSql

首先学习两个函数1.substring  返回字符.binary.text 或 image 表达式的一部分.基本语法:SUBSTRING ( expression , start , length ) expression:字符串.二进制字符串.text.image.列或包含列的表达式start:整数,指定子串的开始位置      注:SQL中"1"表示字符串中的第一个字符,而.NET中"0"表示第一个字符length:整数,指定子串的长度(要返回的字符数或字节数)

MySQL 及 SQL 注入与防范方法_MsSql

所谓SQL注入,就是通过把SQL命令插入到Web表单递交或输入域名或页面请求的查询字符串,最终达到欺骗服务器执行恶意的SQL命令. 我们永远不要信任用户的输入,我们必须认定用户输入的数据都是不安全的,我们都需要对用户输入的数据进行过滤处理. 1.以下实例中,输入的用户名必须为字母.数字及下划线的组合,且用户名长度为 8 到 20 个字符之间: if (preg_match("/^\w{8,20}$/", $_GET['username'], $matches)) { $result =

详解SQL Server中的数据类型_MsSql

前言 前面几篇文章我们讲解了索引有关知识,这一节我们再继续我们下面内容讲解,简短的内容,深入的理解. 数据类型 SQL Server支持两种字符数据类型,一种是常规,另外一种则是Unicode.常规数据类型包括CHAR和VARCHAR,Unicode数据类型包括NCAHR和NVARCHAR.常规字符的每个字符使用1个字节存储,而Unicode数据的每个字符要求2个字节.常规字符列限制为仅仅只针对于英语,而Unicode则是针对于多种语言.两种字符数据类型的文本表示方式也不相同,在表示常规字符文本

如何远程连接SQL Server数据库图文教程_MsSql

一.设置客户端网络实用工具点击"开始"-"程序",在"Microsoft SQL Server"菜单中选择"客户端网络实用工具". 在"别名"选项中点击"添加".在"服务器别名"中,填入您网站域名,在"网络库"区域中点击"TCP/IP",在"连接参数"区域取消"动态决定端口",指定&quo