当前位置:  数据库>sqlserver

sql字符串函数大全和使用方法示例

    来源: 互联网  发布时间:2014-10-13

    本文导语:  SQL SERVER支持的字符串函数内容: 代码如下:LEN(string)函数LOWER(string)函数UPPER (string)函数LTRIM(string)函数RTRIM (string)函数SUBSTRING(string,start_position,length)函数CHARINDEX(string,substring)函数LEFT (string,length)函数RIGHT (string,length) 函数ASCII(string)...

SQL SERVER支持的字符串函数内容:

代码如下:

LEN(string)函数
LOWER(string)函数
UPPER (string)函数
LTRIM(string)函数
RTRIM (string)函数
SUBSTRING(string,start_position,length)函数
CHARINDEX(string,substring)函数
LEFT (string,length)函数
RIGHT (string,length) 函数
ASCII(string)函数
ASCII(string)函数

(1)LEN(string)函数:此函数是用来计算一个字符串的长度,接受一个参数(可以为表里面的一个字符串字段,也可以为别的)。这里面,是没有区分大小写(下面的函数都一样)。LEN,len,还是Len都等同。例子如下:

SELECT FName, LEN(FName) FROM T_Person
注:如果给LEN函数传递的参数是一个时间字段的话,那么返回的结果就不对,比如一个DateTime。所以呢,这个函数是用来计算字符串的长度,别的类型参数也能返回结果,但是就不一定正确。

I、如果传进去的是NULL,那么返回出来的还是NULL。

II、对于一个字符串形如' a a ',返回的结果是4,而不是5。即计算的结果不包括右侧全为空格字符串部分。

(2)LOWER(string)函数:此函数是用来把一字符串都转换为小写字符串。跟LEN()函数一样,也接受一个参数。

代码如下:

SELECT FName, LOWER(FName) FROM T_Person

注:如果传进去的是NULL,那么返回出来的还是NULL。

(3)UPPER (string)函数:与LOWER()函数相反,此函数把字符串都转换为大写字符串。也同样接受一个参数。

代码如下:

SELECT FName, UPPER(FName) FROM T_Person

注:如果传进去的是NULL,那么返回出来的还是NULL。

(4)LTRIM(string)函数:此函数是去除字符串左边的空格(对于夹在字符串里面的空格则无能为力)。也同样接受一个参数。

代码如下:

SELECT FName,LTRIM(FName),LTRIM(' abc ') FROM T_Person

注:如果传进去的是NULL,那么返回出来的还是NULL。

(5)RTRIM (string)函数:此函数是去除字符串右边的空格(对于夹在字符串里面的空格则无能为力)。也同样接受一个参数。

代码如下:

SELECT FName,RTRIM(FName),RTRIM(' abc ') FROM T_Person

注:如果传进去的是NULL,那么返回出来的还是NULL。

如果需要去除两边的空格(对于夹在字符串里面的空格则无能为力),则需要联合来使用。

代码如下:

SELECT FName,LTRIM(RTRIM(FName)),LTRIM(RTRIM(' abc ')) FROM
T_Person

(6)SUBSTRING(string,start_position,length)函数:此函数是使用来获取子字符串。其中参数string为主字符串,start_position为子字符串在主字符串中的起始位置,length
为子字符串的最大长度。需要注意的是这里的start_position是从1开始,不同于数组是从0开始。如果给的是0的话,相当于取了一个''。

代码如下:

SELECT FName, SUBSTRING(FName,2,3) FROM T_Person

注:如果传进去的是NULL,那么返回出来的还是NULL。

(7)CHARINDEX(substring,string)函数:此函数是计算子字符串在主字符串中位置。其中参数substring为子字符串,string为主字符串。这个函数可以检测制定的子字符串是否存在于主字符串中,如果存在则还可以返回所在的位置。假如有匹配的话,结果大于0。也就是匹配成功的话,至少从1开始。

代码如下:

SELECT FName,CHARINDEX('m', FName), CHARINDEX('ly', FName)
FROM T_Person

注:如果传进去的是NULL,那么返回出来的还是NULL。

(8)LEFT (string,length)函数:此函数是实现从左侧开始取子字符串,其中参数string为主字符串,length为子字符串的最大长度。即取出来的结果是1至length范围内的子字符串。

代码如下:

SELECT FName, LEFT(FName,3) , LEFT(FName,2)
FROM T_Person

注:如果传进去的是NULL,那么返回出来的还是NULL。

这种方式等同于使用SUBSTRING(string,start_position,length)函数:

代码如下:

SELECT FName,SUBSTRING(FName, 1,3) FROM T_Person

(9)RIGHT (string,length) 函数:此函数是实现从右侧开始取子字符串,其中参数string为主字符串,length为子字符串的最大长度。即取出来的结果是1至length范围内的子字符串。

代码如下:

SELECT FName, RIGHT(FName,3) , RIGHT(FName,2)
F
ROM T_Person


注:如果传进去的是NULL,那么返回出来的还是NULL。

这种方式等同于使用SUBSTRING(string,start_position,length)函数,其中SUBSTRING(string, LEN(string)- length+1, length)等价于RIGHT (string,length)。

代码如下:

SELECT FName, SUBSTRING(FName,LEN(FNAME)-2,3) , SUBSTRING(FName,LEN(FNAME)-1,2)
FROM T_Person

(10)REPLACE(string,string_tobe_replace,string_to_replace)函数:此函数是实现字符串的替换功能,其中参数string 为要进行替换操作的主字符串,参数string_tobe_replace 为要被替换的字符串,即string_to_replace将替换string_tobe_replace中所有出现的地方。

代码如下:

select FName,REPLACE(FName,'i','e'),FIDNumber,
REPLACE(FIDNumber,'2345','abcd') FROM T_Person

借助替换为''来实现删除字符串的功能:
代码如下:

SELECT FName, REPLACE(FName,'m','') ,FIDNumber,
REPLACE(FIDNumber,'123','') FROM T_Person

前面介绍过LTRIM(string)函数和RTRIM(string)函数,两者最终只能删除两侧的空格,而对于在字符串里面的空格,则无能为力。而借助于REPLACE函数则可以轻松解决。

代码如下:

SELECT REPLACE(' abc 123 wpf',' ','') , REPLACE(' ccw enet wcf f',' ','')

(11)ASCII(string)函数:此函数用来得到一个字符的ASCII 码,它有且只有一个参数,这个参数为待求ASCII码的字符,如果参数为一个字符串则函数返回第一个字符的ASCII码。
代码如下:

SELECT ASCII('a') , ASCII('abc')

注:如果传进去的是NULL或者是'',那么返回出来的是NULL。

(12)CHAR(string)函数:与(11)相反,此函数用来得到一个字符的ASCII 码。

代码如下:

SELECT CHAR(56) , CHAR(90) ,'a', CHAR( ASCII('a') )

注:如果传进去的是NULL,那么返回出来的是NULL。

(13)DIFFERENCE(string)函数:此函数用来比较两个字符串的发音相似度,它可以计算两个字符串的发音特征值,并且比较它们,然后返回一个0至4 之间的一个值来反映两个字符串的发音相似度,这个值越大则表示两个字符串发音相似度越大。

代码如下:

SELECT DIFFERENCE(FName,'Merry') FROM T_Person

注:如果传进去的是NULL,那么返回出来的是NULL。

    
 
 

您可能感兴趣的文章:

  • t-sql/mssql用命令行导入数据脚本的SQL语句示例
  • 拼接SQL字符串方法示例
  • sql 行转列示例代码
  • sql中count或sum为条件的查询示例(sql查询count)
  • sql 取代游标的写法示例
  • sql使用cast进行数据类型转换示例
  • sql 语句插入结果为select和值混合示例
  • sql2005统计技巧示例
  • sql函数实现递归查询示例
  • sql递归函数示例
  • java实现简单的给sql语句赋值的示例
  • sql多表行转列、级联行转列示例代码
  • sql级联删除与级联更新方法示例
  • t-sql清空表数据的两种方式示例(truncate and delete)
  • sql server 临时表的删除示例
  • php导入SQL文件(示例代码)
  • SQL 分布式查询、插入递增列示例
  • sql四舍五入函数示例
  • sql带分隔符的截取字符串示例
  • sql2005 存储过程分页示例代码
  • SqlServer中用exec处理sql字符串中含有变量的小例子
  • 将一个字符串分成多列的Sql
  • sqlserver中求字符串中汉字的个数的sql语句
  • SQLServer中字符串左对齐或右对齐显示的sql语句
  • 去除字符串中的相同的字符串的sql函数
  • 在SQL中获取一个长字符串中某个字符串出现次数的实现方法
  • C处理SQL命令字符串的函数哪里有?
  • Oracle中SQL语句连接字符串的符号使用介绍
  • C#检测是否有危险字符的SQL字符串过滤方法
  • sql函数实现去除字符串中的相同的字符串
  • 拼接SQL字符串与日期模糊查询的例子
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • C#使用带like的sql语句时防sql注入的方法
  • SQL高级应用之使用SQL查询Excel表格数据的方法
  • sql中varchar和nvarchar的区别与使用方法
  • Discuz批量替换帖子内容的方法(使用SQL更新数据库)
  • 在linux中导入sql文件的方法分享(使用命令行转移mysql数据库)
  • SQL Server中使用Linkserver连接Oracle的方法
  • 使用T-SQL的Split拆分字符串的方法
  • 在SQL Server中使用命令调用SSIS包的具体方法
  • 使用SQL Server数据库嵌套子查询的方法
  • sql server 还原数据库时提示数据库正在使用,无法进行操作的解决方法
  • sql server 在32位机器上使用AWE访问4GB以上内存的方法
  • 使用sql语句分离和附加数据库的方法
  • sql集合运算符使用方法
  • 使用sql语句在指定字段前面插入新的字段的方法
  • sql表连接查询使用方法(sql多表连接查询)
  • sql 中 case when 语法使用方法
  • 如何使用java连接到sql server数据库?任何方法均可!
  • SQL Server遍历表中记录的2种方法(使用表变量和游标)
  • sql server中使用Split()的方法介绍
  • 在SQL查询中使用LIKE来代替IN查询的方法
  • java命名空间java.sql接口statement的类成员方法: executeupdate定义及介绍
  • 请问,这是什么错误!java.sql.SQLException: [Microsoft][ODBC SQL Server Driver][Named Pipes]??????? SQL Server?虽然分少,但一定给,只要您是前5名回复者中最好的以为!
  • java命名空间java.sql接口connection的类成员方法: nativesql定义及介绍
  • SQL查询分析工具 SQL Workbench/J
  • java命名空间java.sql接口preparedstatement的类成员方法: executeupdate定义及介绍
  • oracle导出sql语句的结果集和保存执行的sql语句(深入分析)
  • java命名空间java.sql接口rowid的类成员方法: getbytes定义及介绍
  • SQL Server统计SQL语句执行时间的脚本
  • java命名空间java.sql接口ref的类成员方法: getbasetypename定义及介绍
  • SQL客户端软件 PKLite SQL Client
  • java命名空间java.sql接口databasemetadata的类成员方法: getsqlkeywords定义及介绍


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3