sqlserver repalce模糊替换

由于SQL Server的REPLACE函数用于替换字符串中的指定子字符串。它执行的是精确替换,所以想进行模糊替换或基于模式的替换,需要结合REPLACE使用CHARINDEX和SUBSTRING函数。

简单的介绍一下CHARINDEX函数和SUBSTRING函数:

  • CHARINDEX(substring, string, start_location)
    CHARINDEX(要查找的子字符串, 要查找的子字符串, (可选)是开始查找的位置。)
    【一般用于提取或搜索数据。】
    【查找一个子字符串在另一个字符串中的位置的函数。】
SELECT CHARINDEX('apple', 'I like apples and bananas.');
-- 返回结果为 8
  • STUFF(string1, start, length, string2)
    SUBSTRING(主字符串, 起始位置 起始位置是从1开始计数的, 要删除的字符数量,插入到 string1 中的新字符串)
    【用于从文本字段中提取部分数据】例如提取名字或地址的一部分。
    【它也可用于修改或处理字符串数据。】
SELECT STUFF('Hello, World!', 7, 5, 'SQL') AS Result;
-- 返回结果为  "Hello, SQL!"STUFF 函数将从第 7 个字符位置开始(即逗号后面),删除长度为 5 的字符(包括空格),然后插入字符串 "SQL"。
  • LEN 函数
    LEN(string)
    【用于检查字符串的长度以进行有效性验证或数据处理】
	SELECT FirstName, LastName, LEN(FirstName + ' ' + LastName) AS FullNameLength
FROM Employees;FirstName   LastName   FullNameLengthJohn        Doe        8Jane        Smith      10Mike        Johnson    12

repalce模糊替换

  • 字符串

    • 将B替换成D,ABC——>ADC
DECLARE @OriginalString NVARCHAR(MAX) = 'This is a test string with typos.'
DECLARE @SearchString NVARCHAR(MAX) = 'typos'
DECLARE @ReplaceString NVARCHAR(MAX) = 'errors'-- 查找搜索字符串的位置
DECLARE @StartPosition INT = CHARINDEX(@SearchString, @OriginalString)-- 检查是否找到了搜索字符串,然后进行替换
IF @StartPosition > 0
BEGINSET @OriginalString = STUFF(@OriginalString, @StartPosition, LEN(@SearchString), @ReplaceString)
ENDSELECT @OriginalString
  • 将A后4位替换成1234 ABCDE——>A1234
DECLARE @OriginalString NVARCHAR(MAX) = N'<div style="background-color:#E9F4FF;width:100%;'-- 查找 'width' 的位置
DECLARE @WidthStartPosition INT = CHARINDEX('width:', @OriginalString)-- 如果找到 'width',则进行替换
IF @WidthStartPosition > 0
BEGIN-- 取 'width' 后面的 4 位字符并替换为 '102%'SET @OriginalString = STUFF(@OriginalString, @WidthStartPosition + 6, 4, '102%')
ENDSELECT @OriginalString
  • 在A和C之间替换成1 ABC——>A1C
DECLARE @OriginalString NVARCHAR(MAX) = N'<div style="background-color:#E9F4FF;width:100%;'-- 找到 'width' 和 '%' 的位置
DECLARE @WidthStartPosition INT = CHARINDEX('width:', @OriginalString)
DECLARE @PercentageEndPosition INT = CHARINDEX('%;', @OriginalString)-- 如果找到 'width' 和 '%',则进行替换
IF @WidthStartPosition > 0 AND @PercentageEndPosition > 0
BEGIN-- 计算要替换的内容的起始位置和长度DECLARE @ReplaceStartPosition INT = @WidthStartPosition + 6DECLARE @ReplaceLength INT = @PercentageEndPosition - @ReplaceStartPosition-- 将内容替换为 '102'SET @OriginalString = STUFF(@OriginalString, @ReplaceStartPosition, @ReplaceLength, '102')
ENDSELECT @OriginalString
  • 在1234567的第二位之后插入ABC,1234567——>1ABC234567
DECLARE @OriginalString NVARCHAR(MAX) = '1234567';-- 在字符串的第二位之后插入指定的内容
SET @OriginalString = STUFF(@OriginalString, 2, 0, 'ABC');SELECT @OriginalString;
  • 字段

    • 将表A中的column字段中的从width到%之间替换成102
-- 更新表 A 中的 column 字段
UPDATE A
SET column = REPLACE(column,SUBSTRING(column, CHARINDEX('width', column), CHARINDEX('%', column) - CHARINDEX('width', column) + 1),'width:102%'
)
WHERE CHARINDEX('width', column) > 0 AND CHARINDEX('%', column) > CHARINDEX('width', column);

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/114926.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Openssl数据安全传输平台006:粘包的处理-代码框架及实现-TcpSocket.cpp

文章目录 0. 代码仓库1. TCP通信粘包问题2. 粘包、拆包表现形式2.1 正常情况2.2 两个包合并成一个包2.3 出现了拆包 3. 粘包的处理-参考仓库中的文件TcpSocket.cpp3.1 发送数据时候的处理3.2 接收数据时候的处理 0. 代码仓库 https://github.com/Chufeng-Jiang/OpenSSL_Secure_…

Node学习笔记之Express框架

一、express 介绍 express 是一个基于 Node.js 平台的极简、灵活的 WEB 应用开发框架&#xff0c;官方网址&#xff1a;https://www.expressjs. com.cn/ 简单来说&#xff0c;express 是一个封装好的工具包&#xff0c;封装了很多功能&#xff0c;便于我们开发 WEB 应用&…

局域网下多台windows电脑时间同步

windows时间同步 最近在项目中遇见了多台windows电脑的时间同步问题。在这个项目中&#xff0c;有五台电脑&#xff0c;五台电脑处于同一局域网下&#xff0c;其中有一台可以连接互联网&#xff08;A电脑&#xff09;。我需要将其他四台电脑&#xff08;B、C、D、E电脑&#xf…

fail-fast 和 fail-safe 迭代器

fail-fast 和 fail-safe 迭代器是两种不同的迭代器设计策略&#xff0c;用于在遍历集合&#xff08;如 ArrayList、HashMap&#xff09;时处理并发修改的情况。它们的行为和应对策略有所不同&#xff1a; Fail-Fast 迭代器&#xff1a; Fail-Fast 迭代器在遍历集合期间&#x…

连接Mumu模拟器使用ADB

要连接Mumu模拟器使用ADB&#xff0c;您可以按照以下详细步骤进行操作&#xff1a; 安装ADB驱动程序&#xff1a;在您的计算机上安装ADB驱动程序。ADB是Android Debug Bridge的缩写&#xff0c;它允许您与Android设备进行通信。您可以从Android开发者网站&#xff08;https://d…

图论03-【无权无向】-图的深度优先DFS遍历-路径问题/检测环/二分图

文章目录 1. 代码仓库2. 单源路径2.1 思路2.2 主要代码 3. 所有点对路径3.1 思路3.2 主要代码 4. 路径问题的优化-提前结束递归4.1 思路4.2 主要代码 5. 检测环5.1 思路5.2 主要代码 6. 二分图6.1 思路6.2 主要代码6.2.1 遍历每个联通分量6.2.2 递归判断相邻两点的颜色是否一致…

Jenkins 相关内容

Jenkins 相关内容 什么是 Jenkins&#xff0c;它是如何工作的&#xff1f;Jenkins 中自由式项目和管道之间的区别什么是Jenkins管道&#xff0c;它们如何工作&#xff1f;第一次如何安装Jenkins并进行设置&#xff1f;什么是 Jenkins 插件&#xff0c;如何安装它们&#xff1f;…

julia 笔记:复合类型 struct

1 struct关键字 1.1 声明 struct关键字与复合类型一起引入&#xff0c;后跟一个字段名称的块&#xff0c;可选择使用 :: 运算符注释类型 struct Foobarbaz::Intqux::Float64end 没有类型注释的字段默认为 Any 类型&#xff0c;所以可以包含任何类型的值。 1.2 创建新对象 …

IO/NIO交互模拟及渐进式实现

IO IO Server public class SocketServer {public static void main(String[] args) {//server编号和client编号对应&#xff0c;优缺点注释在server端//server1();//server2();server3();}/*** server1的缺点&#xff1a;* 1、accept()方法阻塞了线程&#xff0c;要等客户端…

2023年09月青少年软件编程C语言二级真题答案——持续更新.....

数组指定部分逆序重放 将一个数组中的前k项按逆序重新存放。例如,将数组8,6,5,4,1前3项逆序重放得到5,6,8,4,1。 时间限制:1000 内存限制:65536 输入 输入为两行: 第一行两个整数,以空格分隔,分别为数组元素的个数n(1 < n < 100)以及指定的k(1 <= k <= n)。…

【Qt之JSON文件】QJsonDocument、QJsonObject、QJsonArray等类介绍及使用

Qt之JSON相关类介绍 QJsonDocument常用函数枚举类型 QJsonDocument::DataValidation枚举类型 QJsonDocument::JsonFormat构造函数静态函数成员函数示例 QJsonObject常用函数构造函数&#xff1a;成员函数&#xff1a; QJsonObject 与 QVariantMap 相互转换 QJsonArray常用函数构…

无论有没有按钮,iPhone都可以进行截屏操作!如何在iPhone上截屏

通过简单的按键组合&#xff0c;可以很容易地将iPhone屏幕的图片捕获到图像文件中&#xff0c;并保存到照片库中。以下是操作方法。 什么是屏幕截图 屏幕截图是指通常包含你在设备屏幕上看到的内容的精确副本的图像。在设备内拍摄的数字屏幕截图通常使用相机拍摄物理屏幕的照…

AD9371 官方例程HDL详解之JESD204B TX_CLK生成 (二)

AD9371 系列快速入口 AD9371ZCU102 移植到 ZCU106 &#xff1a; AD9371 官方例程构建及单音信号收发 ad9371_tx_jesd -->util_ad9371_xcvr接口映射&#xff1a; AD9371 官方例程之 tx_jesd 与 xcvr接口映射 AD9371 官方例程 时钟间的关系与生成 &#xff1a; AD9371 官方…

HTTPS、SSL/TLS,HTTPS运行过程,RSA加密算法,AES加密算法

1、为什么网站要使用安全证书 我们所处的网络环境是复杂多样的&#xff0c;大致分为两类&#xff0c;一类是可信的网络服务商&#xff0c;比如直接连的电信运营商的网络&#xff0c;网线&#xff0c;4G&#xff0c;5G&#xff1b;另一类是不可信的网络&#xff0c;比如WIFI&am…

Linux笔记之diff工具软件P4merge的使用

Linux笔记之diff工具软件P4merge的使用 code review! 文章目录 Linux笔记之diff工具软件P4merge的使用1.安装和配置2.使用&#xff1a;p4merge a.cc b.cc3.配置git 参考博文: Ubuntu Git可视化比较工具 P4Merge 的安装/配置及使用 1.安装和配置 $ wget https://cdist2.per…

仿CSGO盲盒开箱源码 盲盒商城源码 盲盒开箱源码 潮物盲盒商城源码

仿CSGO盲盒开箱源码 盲盒商城源码 盲盒开箱源码 潮物盲盒商城源码 测试环境&#xff1a;宝塔、Linux、PHP7.2、MySQL5.6 根目录 public&#xff0c;伪静态 thinkphp&#xff0c;php需要Redis扩展 后台&#xff1a;/stf 账号&#xff1a;admin 密码&#xff1a;123123 *后台…

数据结构: map与set的简单实现

目录 map与set的模拟实现 1.基本框架 2.模拟实现map与set所需要做的事 1.使用模板 , 达到泛性编程 2.比较问题 3.迭代器 RBTree中: operator operator-- 4.map [ ] 的实现 5.使用普通迭代器构造const迭代器 效果 map与set的模拟实现 1.基本框架 map set 2.模拟实…

【iOS】MVC模式

MVC&#xff08;Model-View-Controller&#xff0c;模型-视图-控制器&#xff09;模式是相当古老的设计模式之一&#xff0c;ta最早出现在SmallTalk语言中。现在&#xff0c;很多计算机语言和架构都采用了MVC模式。 MVC模式概述 MVC模式是一种设计模式&#xff0c;由3部分组成…

【Spring Cloud】如何确定微服务项目的Spring Boot、Spring Cloud、Spring Cloud Alibaba的版本

文章目录 1. 版本选择2. 用脚手架快速生成微服务的pom.xml3. 创建一个父工程4. 代码地址 本文描述如何确定微服务项目的Spring Boot、Spring Cloud、Spring Cloud Alibaba的版本。 1. 版本选择 我们知道Spring Boot、Spring Cloud、Spring Cloud Alibaba的版本选择一致性非常重…

【ML】cheatsheet

LR 原理与面试题目DT, Adaboost, GBDT, xgboost 原理 细节 与 例子 https://www.cnblogs.com/createMoMo/p/12635709.html xgboost挺详细的算法原理与例子 https://zhuanlan.zhihu.com/p/660468945 着重lightgbm就xgboost的改善方向 https://zhuanlan.zhihu.com/p/366952043机器…