志铭-2021年10月10日 23:56:04

0. 加号(+)

SELECT 'abc'+'123'结果:abc123

注意若是varchar 类型+int 类型,需要将int类型转换为varchar类型,方能作为字符串相加

SELECT 'abc' + CAST(18 AS VARCHAR(10)) 结果:abc18

1. LEFT和RIGHT

  • 【定义】

    LEFT()返回从左往右指定长度的子字符串。

    RIGHT()返回从右往左指定长度的子字符串。

  • 【语法】

    LEFT(expressionString,lengthInt)

    RIGHT(expressionString,lengthInt)

    • 注意第二个参数是期望保留的长度
  • 【示例】

    SELECT LEFT('abc',2)返回ab

    SELECT RIGHT('abc',2)返回bc

2. SUBSTRING

  • 【定义】 SUBSTRING()函数用于从字符串中提取子串

  • 【语法】 SUBSTRING(expressionString,startInt,lengthInt)

    对字符串string,从start索引位置开始,返回length长度的子字符串

    注意这里的索引是从1开始数的

  • 【示例】 SELECT SUBSTRING('abcdef',2,3)结果:bcd

  • 【注意】 若是期望从某个起始位置开始获取直到结尾的所有字符,可以使用一个比目标字符串长度还大的值作为截取子串的长度参数,SUBSTRING将返回最大起始位置到目标字符串的结尾,而不会将多出的长度以空格填充。

    SELECT SUBSTRING('abc',1,9)结果是:"abc",而不是"abc "

3. LEN和DATALENGTH

  • 【定义】

    LEN函数返回指定字符串的字符数

    DATALENTH返回的是指定字符串的字节数

  • 【语法】

    LEN(expressionString)

    DATALENGTH(expressionString)

  • 【示例】

    SELECT LEN('abc')结果:3

    SELECT LEN('张三')结果:2

    SELECT DATALENGTH('abc')结果:3

    SELECT DATALENGTH(N'abc')结果:6

    SELECT DATALENGTH('张三')结果:4

  • 【注意】

    LEN函数是计算的是不包含尾随的空格,而DATALENGTH是会包含尾随的空格

    SELECT LEN('ab ')结果:2

    SELECT DATALENGTH('ab ')结果:3

4. CHARINDEX和PATINDEX

  • 【定义】

    CHARINDEX用于寻找某一个字符在目标字符串第一次出现的起始位置(从1开始数

    PATINDEX用于寻找某个模式的子字符串在目标字符串中第一次出现的起始位置

  • 【语法】

    • CHARINDEX(str2Find,str2Search)

      • 注意第一个参数是待寻找的子串
    • PATINDEX('%pattern%',str2Search)
  • 【示例】

    SELECT CHARINDEX('ab','abcab')结果:1

    • 这里'ab'在‘abcab'中出现两次,但是CHARINDEX函数返回的是第一次出现的位置

    SELECT PATINDEX('%[0-9]%','abc123abc')结果:4

    SELECT PATINDEX('a%','abc123')结果:1

    SELECT PATINDEX('a_c%','abc123')结果:1

    • 这里的第一个参数是和LIKE谓词后的模式规则相同

5. REPLACE

  • 【定义】REPLACE函数可以将目标字符串中所有出现的某个子字符串替换为指定的字符串

  • 【语法】

    REPLACE(expressionString,patternString,replacementString)

  • 【示例】

    • 将字符串中的'ab'替换为'AB'

      • SELECT REPLACE('ab222ab333ab444','ab','AB')结果:AB222AB333AB444
    • 将字符串中的'ab'全部删除(即全部替换为空格)
      • SELECT REPLACE('ab222ab333ab444','ab','')结果:222333444

6. REPLICATE和SAPCE

  • 【定义】

    REPLICATE用于将指定的字符串复制指定的次数

    SPACE用于返回指定长度的空格

  • 【语法】

    REPLICATE(expressString,nInt)

    SPACE(nInt)

  • 【示例】

    SELECT REPLICATE('abc',3)结果:abcabcabc

    SELECT DATALENGTH(SPACE(10))结果:10

7. STUFF

  • 【定义】

    将字符串中的一部分替换为另外一个子字符串。

    用于替换的子字符串不需要和被替换的部分长度一样。

  • 【语法】

    STUFF(expressionString,startInt,lengthInt,expressionString2)

  • 【示例】

    • 将目标字符串中从第4个字符之后的三个字符替换为指定的字符串

      SELECT STUFF('abc123def',4,3,'66666666')结果:abc66666666def

    • 将目标字符串中的第一个字符替换为空格(相当于删除目标字符串的第一个字符)

      SELECT STUFF(',a,b,c',1,1,'')结果:a,b,c

8. REVERSE

  • 【定义】用于将指定的字符串中的字符颠倒过来

  • 【语法】

    REVERSE(expressionString)

  • 【示例】

    SELECT REVERSE('abc')结果:cba

9. UPPER和LOWER

  • 【定义】将指定的字符串全部转换为大写或小写

  • 【语法】

    UPPER(expressionString)

    LOWER(expressionString)

  • 【示例】

    SELECT UPPER('aBc')结果:ABC

    SELECT LOWER('aBc')结果:abc

10. LTRIM和RTRIM

  • 【定义】用于将指定的字符串的前导空格和尾随空格删除

  • 【语法】

    LTRIM(expressionString)

    RTRIM(expressionString)

  • 【示例】

    • 删除字符串前端的空格

      SELECT LTRIM(' abc')结果:abc
    • 删除字符串后端的空格

      SELECT RTRIM('abc ')结果:abc
    • 同时删除字符串前后的空格

      SELECT LTRIM(RTRIM(' abc '))结果:abc

11. QUOTENAME

  • 【定义】默认用于给指定的字符串外加一个方括号

    这个函数的第二个参数是可选的,第二个参数只能是英文逗号(,)、英文引号(")或默认的方括号(])

  • 【语法】

    QUOTENAME(expressionString,[character])

  • 【示例】

    SELECT QUOTENAME('Name')结果:[Name]

    SELECT QUOTENAME('Name',')')结果:(Name)

    SELECT QUOTENAME('Name','"')结果:"Name"

12. 综合使用示例

删除字符串最后一位

DECLARE @a VARCHAR(100)='a,b,c,'
--SELECT LEN(@a)--结果:6 --法1
SELECT LEFT(@a,LEN(@a)-1)
--结果:a,b,c --法2
SELECT STUFF(@a,LEN(@a),1,'')
--结果:a,b,c

计算某个字符串出现的次数

  • 实现思路:将需要计算特定子串出现的次数,全部替换为空格,之后使原始长度减去替换后的长度,即为特定子串出现的次数
DECLARE @str VARCHAR(100)='abcabc'
DECLARE @oldLength INT =LEN(@str)--@oldLength=6
DECLARE @newStr VARCHAR(100)=REPLACE(@str,'a','')--@newStr=bcbc
DECLARE @newLength INT=LEN(@newStr)--@newLength=4
SELECT @oldLength-@newLength--结果:2

字符串统一长度,不足则前面补零

  • 实现思路:甭管当前的长度,一律在该字符串前面加上9个0,之后在从右往左截取指定长度的子串作为结果值
DECLARE @tableVar TABLE
(
No VARCHAR(100) NOT NULL
);
INSERT INTO @tableVar
(
No
)
VALUES
('1'),
('12'),
('123'),
('1234'),
('1234'); --字符串统一长度为10,不足则前位补0
SELECT RIGHT(REPLICATE('0', 9) + No, 10)FROM @tableVar;--法1
SELECT REPLICATE('0', 10 - LEN(No)) + No AS NO FROM @tableVar;--法2 --结果
--0000000001
--0000000012
--0000000123
--0000001234
--0000001234 --字符串统一长度,不足则使用空格在后面补足
SELECT No + SPACE(10 - LEN(No)) FROM @tableVar;--法1
SELECT LEFT(NO+SPACE(10),10) FROM @tableVar;--法2 --验证上述操作:
SELECT DATALENGTH(No + SPACE(10 - LEN(No))) FROM @tableVar--验证法1
SELECT DATALENGTH( LEFT(NO+SPACE(10),10)) FROM @tableVar --验证法2 --结果:
--10
--10
--10
--10
--10

积累待补充中……

T-SQL——函数——字符串操作函数的更多相关文章

  1. Sql字符串操作函数

    1.去空格函数 (1).LTRIM() 把字符串头部的空格去掉. (2).RTRIM() 把字符串尾部的空格去掉. 2.字符转换函数(1).ASCII()返回字符表达式最左端字符的ASCII 码值.在 ...

  2. SQL 字符串操作函数

    SQL 字符串操作函数 学习了: https://www.cnblogs.com/wangzhe688/p/6046654.html 一.字符转换函数 1.ASCII() 返回字符表达式最左端字符的A ...

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

    select语句中只能使用sql函数对字段进行操作(链接sql server), select 字段1 from 表1 where 字段1.IndexOf("云")=1;这条语句不 ...

  4. Postgresql 字符串操作函数

    样例测试: update property set memorial_no = btrim(memorial_no, ' ') where memorial_no like ' %' 或:update ...

  5. Postgresql数据库的一些字符串操作函数

    今天做项目遇到客户反映了一个麻烦的事情,有一些数据存在,但就是在程序中搜索不出来,后来分析,发现问题为数据前面有几个空白字符,后来用SQL查询了一下,发现八九个数据表中,数千万条数据中有将近三百万条数 ...

  6. JavaScript中常见的字符串操作函数及用法

    JavaScript中常见的字符串操作函数及用法 最近几次参加前端实习生招聘的笔试,发现很多笔试题都会考到字符串的处理,比方说去哪儿网笔试题.淘宝的笔试题等.如果你经常参加笔试或者也是一个过来人,相信 ...

  7. 转:C语言字符串操作函数 - strcpy、strcmp、strcat、反转、回文

    转自:C语言字符串操作函数 - strcpy.strcmp.strcat.反转.回文 C++常用库函数atoi,itoa,strcpy,strcmp的实现 作者:jcsu C语言字符串操作函数 1. ...

  8. C语言的常用字符串操作函数(一)

    一直做的是单片机相关的程序设计,所以程序设计上更偏向底层,对于字符串的操作也仅限于液晶屏幕上的显示等工作,想提高下字符串操作的水平,而不是笨拙的数组替换等方式,翻看帖子发现C语言的字符串操作函数竟然这 ...

  9. sql server 字符串替换函数REPLACE

    sql server 字符串替换函数REPLACE函数的使用 <pre name="code" class="sql">--参数1:需要替换字符的母 ...

随机推荐

  1. Java中Byte类型数据在运算中的问题

    比如: byte a=1; byte b=2; byte c; c=a+b; //这样是计算不出c,是错误的 c=a+1; //这样也是不能计算c的 c=64+1; //为什么这样就能计算c,在Jav ...

  2. 「萌新指南」SOA vs. 微服务:What’s the Difference?

    实话实说,在我还没有实习之前,我是连 SOA 是啥都不知道的,只听说过微服务,毕竟微服务实在太火了,想不知道都难,我觉得实习的时候肯定也是微服务,进组之后发现是 SOA 架构,当时都懵了,看了很多文档 ...

  3. linux多次登录失败锁定账户

    2021-07-22 1.配置对系统进行失败的ssh登录尝试后锁定用户帐户 # 配置登录访问的限制 vi /etc/pam.d/system-auth 或者 vi etc/pam.d/password ...

  4. MeteoInfo-Java解析与绘图教程(四)

    MeteoInfo-Java解析与绘图教程(四) 上文我们说到,将地图叠加在色斑图上,但大部分都是卫星绘图,现在开始讲解micaps数据绘图,同样也是更多自定义配置 首先我们解析micaps数据,将之 ...

  5. github搜索技巧小结

    欢迎访问我的GitHub https://github.com/zq2599/blog_demos 内容:所有原创文章分类汇总及配套源码,涉及Java.Docker.Kubernetes.DevOPS ...

  6. Nginx:常用基本命令与异常处理

    Nginx日志 - ./nginx-1.6.0-ems/logs/nginx.pid Nginx启动时应该使用cmd等命令行工具启动,双击启动同样会产生进程但会造成异常,判断条件是 ./nginx-1 ...

  7. VUE002. 动态使用webpack打包处理后的静态图片路径({ img: require('xxx.png') })

    案例摘要 需求是通过v-for循环渲染数组中数据,其中包括本地包的图片文件.话不多说直接上代码: <a-radio-group class="template-radio"& ...

  8. aes加解密前后端-后台

    一.web.xml: <filter> <filter-name>fastLoginFilter</filter-name> <filter-class> ...

  9. git config 选项

    git config  --global -- global 写入选项:写入全局的 ~/.gitconfig 文件而不是版本库的 .git/config,如果 ~/.gitconfig 文件不存在,则 ...

  10. freeswitch编译安装依赖

    ncurses:提供字符界面 zlib:数据压缩 libjpeg:JPEG图片格式数据的解码/编码/其他. lua:lua解释器 libedit:一种编辑操作的库,对一些可以交互操作的场景,或转为了自 ...