Sql Server 字符串操作总结

SQL Server 支持两种字符数据类型---常规和Unicode;常规类型包括char 和varchar;unicode包括nchar 和nvarchar。常规的每个字符占用一个字节存储,而unicode数据类型每个字符占用2个字节,并且需要一个代理项对时需要4个字节。如果为列选择了常规字符类型,会被限制除英文外只能使用一种语言。使用unicode数据类型可以支持多种语言。如果需要存储多种语言的字符数据,应该使用unicode字符类型。

-- 1、字符串连接 使用“+”运算符

select empid,firstname + ‘ ‘ + lastname as fullname from HR.Employees

-- 连接null的结果直接输出null

select custid,country,region,city, country +‘ ‘ +region +‘ ‘ +city as location from sales.Customers

-- 2、substring函数 substring(string,start,length)此处需要注意sql的开始位置是从1开始的; substring函数可以从字符串中提取一个新的字符串

select SUBSTRING(‘abcd‘,1,2) --返回ab

select SUBSTRING(‘abcd‘,1,6) --如果长度超出字符串长度不报错,而是输出到字符串的最后一位

-- 3、left 和right 函数;这两个函数是substring的简化形式,可以从指定字符串的左边或者右边返回指定长度的新字符串 left(string,n) right(string,n)

select LEFT(‘abcd‘,1) --返回a

select RIGHT(‘abcd‘,2) --返回cd

-- 4、len和datalength函数;len函数返回指定字符串的长度;datalength返回指定字符串的字节长度;

-- 在常规数据类型中每个字符需要一个字节存储,所以两个函数返回值是一样的;
-- unicode字符,每个字符需要两个存储字节(大部分情况下)

select LEN(‘abcd‘) --返回4

select DATALENGTH(‘abcd‘) --返回4

select DATALENGTH(N‘abcd‘) --返回8

-- 5、charindex函数;返回子字符串在字符串中第一次出现的位置

select charindex(‘abc‘,‘xyzabcdefabc‘) --返回4

-- 可以选择第三个参数 指定开始查找的位置

select charindex(‘abc‘,‘xyzabcdefabc‘,5) --返回10

-- 6、patindex函数;这个函数和sql中的like谓词类似

select PATINDEX(‘%1%‘,‘abcd1234abcd‘) --返回5

-- 7、replace(string,str1,str2)函数;在字符串中使用str2替换string中所有的str1;

select REPLACE(‘abcd1234abcd‘,‘a‘,‘#‘)

-- 该函数另外一个用法;计算某个字符在字符串中出现的次数

select len(‘abcde‘)- len(replace(‘abcde‘,‘a‘,‘‘)) --a在字符串中出现1次

select len(‘abcdeabcd‘)- len(replace(‘abcdeabcd‘,‘a‘,‘‘)) -- a在字符串中出现2次

-- 8、replicate函数;按照指定的次数重复出现一个字符串

select REPLICATE(‘abc#‘,3)

-- 实际应用 供应商编号固定位10位,不足10位在前面补0

select supplierid,RIGHT(REPLICATE(‘0‘,9) + cast(supplierid as varchar(10)),10) as strsupplierid from Production.Products

-- 9、stuff函数;允许从字符串中移除指定数量的字符串,并插入一个替代的新子字符串

-- stuff(string,index,delete_length,indertstring)
select STUFF(‘abc‘,1,2,‘12345‘) --返回12345c

select STUFF(‘abcd‘,4,1,‘123‘) -- 返回abc123

-- 10、upper和lower函数;返回大写和小写字符串

select UPPER(‘abCD‘) --返回‘ABCD’

select LOWER(‘abCD‘) --返回‘abcd’

-- 11、ltrim、rtrim函数去掉左边或者右边的空字符串
select LTRIM(‘ abc ‘) --返回‘abc ‘

select Rtrim(‘ abc ‘) --返回‘ abc‘

-- 12、Format函数;将输入的值按照指定格式返回 -注意这个函数只有在SQL Server2012以上才可以使用
-- 例8中返回指定长度的字符串可以用format很简单的完成
select FORMAT(‘123‘,‘0000000000‘)

select FORMAT(getdate(),‘YYYY-MM-DD‘)

时间: 2024-12-27 01:05:59

Sql Server 字符串操作总结的相关文章

VS2010连接SQL Server 2008操作与编程 (笔记)

实现VS2010连接SQL Server 2008操作与编程,主要记录的是一个学习的过程. 实现VS2010连接SQL Server 2008:逗逗飞的专栏 实现VS2010连接SQL Server 2008代码:点击打开链接 ADO的三个指针: _ConnectionPtr:用于建立数据库的连接. _RecordsetPtr:它是专门为通过记录集操作数据库而设立的指针,通过该接口可以对数据库的表内的记录.字段等进行各种操作. _CommandPtr:提交的sql查询字符串指针 目的:连接数据库

VBA连接SQL SERVER数据库操作Excel

 VBA连接SQL SERVER数据库操作Excel. Sub 按钮1_Click() Dim i As Integer, j As Integer, sht As Worksheet 'i,j为整数变量:sht 为excel工作表对象变量,指向某一工作表 'Dim cn As New ADODB.Connection '定义数据链接对象 ,保存连接数据库信息:请先添加ADO引用 'Dim rs As New ADODB.Recordset '定义记录集对象,保存数据表 '工具 ---〉引用

[转]SQL Server字符串处理函数大全

select语句中只能使用sql函数对字段进行操作(链接sql server), select 字段1 from 表1 where 字段1.IndexOf("云")=1;这条语句不对的原因是indexof()函数不是sql函数,改成sql对应的函数就可以了.left()是sql函数.select 字段1 from 表1 where charindex('云',字段1)=1; 字符串函数对二进制数据.字符串和表达式执行不同的运算.此类函数作用于CHAR.VARCHAR. BINARY.

SQL SERVER 时间相关操作笔记

1.DATEADD函数: A.  MSDN上的示例:http://msdn.microsoft.com/zh-cn/library/ms186819%28v=sql.90%29.aspx B. SQL2005上的示例 1 ----定义变量 2 DECLARE @start DATETIME,@end DATETIME 3 SET @start='2014-01-01' 4 SET @end='2014-06-16' 5 6 ---- 计算月份 7 SELECT DATEADD(YEAR,-6,@

SQL Server字符串左匹配

在SQL Server中经常会用到模糊匹配字符串的情况,最简单的办法就是使用like关键字(like语法http://msdn.microsoft.com/en-us/library/ms179859.aspx).但是如果我们使用的前后都加%的方式,是没办法用到索引进行快速查询的,所以很多情况下我们使用左匹配的方式.最常见的一个例子就是在搜索框中,用户输入了一部分关键字,系统可以通过用户的输入进行左匹配,找出相关的结果列出来.使用左匹配的好处是可以使用到SQL Server中对该字段建立的索引,

sql server字符串的类型

sql server字符串分为不同的类型,下面就将为您介绍几个sql server字符串的常见类型,希望对您学习sql server字符串能有所帮助. nchar 此数据类型可存储1~4000个定长Unicode字符串,字符串长度在创建时指定:如未指定,默认为nchar(1).每个字符占用2bytes存储空间. varchar 此数据类型可存储最大值为8000个字符的可变长字符串.可变长字符串的最大长度在创建时指定,如varchar(50),每个字符占用1byte存储空间. nvarchar 此

SQL Server 字符串处理

DECLARE @str VARCHAR(50) SET @str='AP-FQC-2014072300004' --获取指定字符第一次出现的位置 SELECT PATINDEX('%-%',@str) --返回:3 --获取指定字符第一次出现的位置之前的字符串 SELECT SUBSTRING(@str,1,CHARINDEX('-',@str)-1) --返回:AP --获取指定字符最后一次出现的位置 SELECT LEN(@str)-CHARINDEX('-',REVERSE(@str))

sql server 字符串替换 1992-2008 '-'替换为@

if exists (select* from 某表名 where SUBSTRING(主题词, PATINDEX('%[0-9]%', 主题词) + 4, 1) = '-') UPDATE 某表名 SET 主题词 =STUFF (主题词,PATINDEX('%[0-9]%', 主题词) + 4 , 1 ,'@' ) where(主题词 like '%[0-9]%-%[0-9]%') 主题词1998-fmkgm先-天性-1992@2015-畸形:新-生-儿-疾病-预防(卫生) sql serve

sql server C#操作。原文在收藏页面

C#操作SQL Server数据库 1.概述 2.连接字符串的写法 3.SqlConnection对象 4.SqlCommand对象 5.SqlDataReader对象 6.DataSet对象 7.释放资源 1.概述 ado.net提供了丰富的数据库操作,这些操作可以分为三个步骤: 第一,使用SqlConnection对象连接数据库: 第二,建立SqlCommand对象,负责SQL语句的执行和存储过程的调用: 第三,对SQL或存储过程执行后返回的“结果”进行操作. 对返回“结果”的操作可以分为两