首页 > 数据库 >SqlServer的substring用法

SqlServer的substring用法

时间:2023-01-03 22:23:12浏览次数:49  
标签:返回 SUBSTRING abcde 截取 SqlServer 用法 substring start select

SUBSTRING ( expression, start, length )

 

参数

expression

字符串、二进制字符串、文本、图像、列或包含列的表达式。请勿使用包含聚合函数的表达式。

 

start

整数或可以隐式转换为 int 的表达式,指定子字符串的开始位置,索引是从1开始。

 

length

整数或可以隐式转换为 int 的表达式,指定子字符串的长度。经测试,暂且发现只能是非负数。

返回值

1.如果 expression 是一种支持的二进制数据类型,则返回二进制数据,这种情况我们暂且不讨论。

2.如果 expression 是一种支持的字符数据类型,则返回字符数据。

(1)如果 start的索引是从1开始,则从表达式的第一个字符开始进行字符串截取,从2开始就从表达式的第二个字符开始截取,以此类推。

例如:

select SUBSTRING('abcde',1,2) 返回结果 ab

select SUBSTRING('abcde',2,3) 返回结果 bcd

select SUBSTRING('abcde',1,0) 返回结果为空

select SUBSTRING('abcde',0,8) 返回结果为abcde,注意后面没有空格了。

(2) 如果start的索引是从小于1(0或负数)开始,则返回长度等于从1开始,截取长度为 length - ((start - 1)的绝对值), 如果这个差为负数就返回空。

画个图理解这种情况(比如SUBSTRING('abcde',0,2)返回a):

坐标:0       1         2     3     4    5

内容:空      a     b    c     d    e

截取:从此截取 截取到这里结束

 

例如:下面的 || 表示绝对值计算

select SUBSTRING('abcde',0,2) 返回结果为 a , 计算公式为SUBSTRING(1,2-|2-1|)

select SUBSTRING('abcde',0,-1) 返回错误提示“传递到 substring 函数的长度参数无效”

select SUBSTRING('abcde',-1,2) 返回结果为空, 计算公式为SUBSTRING(1,2-|-1-1|)

select SUBSTRING('abcde',-5,3) 返回结果为空, 计算公式为SUBSTRING(1,3-|-5-1|)

select SUBSTRING('abcde',-1,4) 返回结果为ab, 计算公式为SUBSTRING(1,4-|-1-1|)

select SUBSTRING('abcde',-2,8) 返回结果为abcde, 计算公式为SUBSTRING(1,8-|-2-1|)

 

 原文地址:https://www.cnblogs.com/zyadmin/p/10431397.html

 

 

标签:返回,SUBSTRING,abcde,截取,SqlServer,用法,substring,start,select
From: https://www.cnblogs.com/songjuntao/p/17023527.html

相关文章

  • 【C++】万能头文件 bits/stdc++.h 的用法和优缺点
    一.使用方法1#include<bits/stdc++.h>23intmain()4{5//writecodehere67return08}二、头文件内容1//C++includesusedforpr......
  • 图片验证码kaptcha基本用法
    本文主要内容Kaptcha在SpringBoot环境下的用法实例后端生成的验证码图片以Base64和流的形式响应给前端,渲染到HTML内容导览Kaptcha配置参数说明配置类KaptchaConf......
  • flutter系列之:flutter中listview的高级用法
    目录简介ListView的常规用法创建不同类型的items总结简介一般情况下,我们使用Listview的方式是构建要展示的item,然后将这些item传入ListView的构造函数即可,通常情况下这样......
  • redis高级用法
    1高级用法之慢查询#讲5大数据类型,O(n),命令执行时间很长,redis命令操作单线程架构,阻塞-单线程架构:并发操作不需要锁-mysql:行锁,表锁,并发操作数据错乱的问题......
  • C++数据结构map中的begin()和rbegin()具体区别及erase()具体用法
    1.前言 昨天写的LeetCode打卡题,用到了map数据结构,并且需要顺序和逆序遍历map并删除key对应value为0的这个对象。本以为begin()和rbegin()是一样的迭代器,只不过是一个指......
  • Java里if和else的用法
    前言在上一篇文章中,壹哥给大家讲解了Java里的输入与输出语句,现在你知道怎么用了吗?接下来我们继续往下学习Java里的流程控制语句,今天先给大家讲一下if和else这一对好基友,......
  • 简单聊聊:Stream.reduce()用法解析
    基本使用先举一个简单的例子:算法题:Words题目描述每个句子由多个单词组成,句子中的每个单词的长度都可能不一样,我们假设每个单词的长度Ni为该单词的重量,你需要做的就是给出......
  • SQLSERVER 居然也能调 C# 代码 ?
    一:背景1.讲故事前些天看到一个奇怪的Function函数,调用的是C#链接库中的一个UserLogin方法,参考代码如下:CREATEFUNCTIONdbo.clr_UserLogin(@name ASNVA......
  • Django框架:13、csrf跨站请求伪造、auth认证模块及相关用法
    Django框架目录Django框架一、csrf跨站请求伪造1、简介2、csrf校验策略form表单csrf策略ajax请求csrf策略3、csrf相关装饰器FBV添加装饰器方式CBV添加装饰器方式二、aut......
  • iView 树形组件 on-select-change 事件用法
    一、组件  <Tree:data="baseData"@on-select-change="checkBoxSel"show-checkbox></Tree>二、方法checkBoxSel(root,node){......