当前位置: 首页 > news >正文

SQL优化:SQL模拟Split二维数组

文章目录

  • 1、需求
  • 2、落地
  • 3、实现
  • 4、总结

1、需求

有一个excel,读取到datatable后,需要通过id,获取name,并替换到excel的对应列。
那么可能查询需求有10行,返回只有9行。
为了替换的1对1匹配,查询和结果的key(行号)一致就很主要了。

2、落地


11[A]‘‘AA’’ [T] 22[A]‘‘BB’’ [T] 33[A]‘‘CC’’
// 仿 [{Row:‘11’,Id=‘AA’},{Row:‘22’,Id=‘BB’},{Row:‘33’,Id=‘CC’}]
转换为
(SELECT Top 1 11 as ROW, Name From TableA Where Id=‘AA’) UNION ALL
(SELECT Top 1 22 as ROW, Name From TableA Where Id=‘BB’ ) UNION ALL
(SELECT Top 1 33 as ROW, Name From TableA Where Id=‘CC’ )

不能使用STRING_SPLIT,有点打脑壳。
但是查了要改到前端,所以必须锁定数据和查询的1对1关系。

3、实现

-- =============================================
ALTER FUNCTION  [dbo].[F_OptimizeOr]
(    @WhereStr NVARCHAR(MAX)
)
RETURNS  NVARCHAR(MAX) 
AS BeginDECLARE @Delimiter1 NVARCHAR(3)='[A]'DECLARE @Delimiter2 NVARCHAR(3)='[T]'DECLARE @StartIndex INT= 1; -- 子字符串起始索引DECLARE @EndIndex INT; -- 子字符串结束索引DECLARE @Substring NVARCHAR(MAX) -- 提取的子字符串  DECLARE @Result NVARCHAR(MAX)='' --结果DECLARE @DoCount INT= 1 --循环次数 WHILE @StartIndex > 0BEGINIF (@DoCount%2=1)--奇次-- 找到下一个分隔符的位置SET @EndIndex = CHARINDEX(@Delimiter1, @WhereStr, @StartIndex);--[A]到[T]止ELSE   SET @EndIndex = CHARINDEX(@Delimiter2, @WhereStr, @StartIndex);--[T]到[A]止-- 如果未找到分隔符,则设置结束位置为字符串长度加一IF (@EndIndex = 0)SET @EndIndex = LEN(@WhereStr) + 1;-- 提取当前子字符串SET @Substring = SUBSTRING(@WhereStr,@StartIndex,@EndIndex - @StartIndex);-- 更新起始索引至下一位置之后SET @StartIndex = @EndIndex + LEN(@Delimiter2);-- 将子字符串插入结果表中IF(@EndIndex>LEN(@WhereStr))BEGINSET @Result+= ' Id='+@Substring+' ) ';BREAK;--中止循环ENDIF (@DoCount%2=1)--奇次--[A]到[T]止SET @Result+= ' (SELECT Top 1 '+ @Substring +' as ROW, Name From TableA Where ';ELSE --偶次--[T]到[A]止SET @Result+= ' Id='+@Substring+' ) UNION ALL';Set  @DoCount+=1 --循环次数ENDRETURN @Result
ENDGO

4、总结

问题主要在于前端拼接SQL后,传输的不安全(注入)、长字符不稳定(语句过长可能…)。
而逻辑放在SQL又过于难实现,毕竟逻辑确实是SQL的短板。

本次记录主要是split的挨个、循环截取,将11[A]‘‘AA’’ [T] 22[A]‘‘BB’’ [T] 33[A]‘‘CC’’
转换为 11 ‘‘AA’’ 22 ‘BB’’ 33 ‘‘CC’’ ,并穿插入SQL的巧思。

http://www.dtcms.com/a/354068.html

相关文章:

  • Linux 基础开发工具
  • django-redis 使用类实现和使用
  • React(面试)
  • JUC之异步编程理论总结
  • 实现基于数据库 flag 状态的消息消费控制
  • 【docker】P1 虚拟化与容器化
  • 全球协作无障碍:cpolar+Nextcloud实现跨国文件共享
  • 通过远程桌面横向移动(破解凭证)
  • 【51单片机】【protues仿真】 基于51单片机出租车计价器系统
  • 三轴云台之动态性能篇
  • 数字化时代催生变革,楼宇自控系统成为建筑管理新潮流的引领者
  • ESP32S3:开发环境搭建、VSCODE 单步调试、Systemview 分析任务运行情况
  • 北斗导航|接收机自主完好性监测算法综述
  • 【C++】类和对象 --- 类中的6个默认成员函数
  • CAS 浅析
  • 视觉语言模型应用开发——Qwen 2.5 视觉语言模型的零样本学习能力在多模态内容审核中的实践研究
  • 把CentOS 7默认yum源改成腾讯云镜像
  • 阿里云——云存储与数据库服务
  • RustFS架构解密:零GC设计如何实现12μs级存储延迟?
  • 【lucene】SpanNearQuery中的slop
  • 【lucene】SpanFirstQuery的end参数
  • 【Python】包管理,弄明白import,package,module
  • 复杂网络环境实测:主流云VR产品性能对比——平行云LarkXR突破网络限制 引领云VR技术新高度
  • 记住密码管理器
  • 在Eclipse中配置Tomcat
  • 终端美化:Windows11 下 安装 WSL 并使用好看的的 zsh 主题
  • 【图论】最短路算法
  • 802.11ax上行OFDMA接入机制:技术原理与实现细节
  • 流水线用到的Dockerfile和构建脚本build.sh
  • Python电影票房预测模型研究——贝叶斯岭回归Ridge、决策树、Adaboost、KNN分析猫眼豆瓣数据