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

文章目录

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、实现

sql 复制代码
-- =============================================
ALTER FUNCTION  [dbo].[F_OptimizeOr]
(    @WhereStr NVARCHAR(MAX)
)
RETURNS  NVARCHAR(MAX) 
AS Begin
 DECLARE @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 > 0
	BEGIN
		 IF (@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))
		BEGIN
			SET @Result+= ' Id='+@Substring+' ) ';
			BREAK;--中止循环
		END

		IF (@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 --循环次数
    END
  RETURN @Result
END


GO

4、总结

问题主要在于前端拼接SQL后,传输的不安全(注入)、长字符不稳定(语句过长可能...)。

而逻辑放在SQL又过于难实现,毕竟逻辑确实是SQL的短板。

本次记录主要是split的挨个、循环截取,将11[A]''AA'' [T] 22[A]''BB'' [T] 33[A]''CC''

转换为 11 ''AA'' 22 'BB'' 33 ''CC'' ,并穿插入SQL的巧思。

相关推荐
高梦轩2 小时前
MySQL高可用
android·运维·数据库
紫金修道4 小时前
【DeepAgent】概述
开发语言·数据库·python
孟章豪5 小时前
《SQL拼接 vs 参数化,为什么公司禁止拼接SQL?(附真实案例)》
服务器·数据库·sql
荒川之神5 小时前
ORACLE LEVEL函数练习
数据库·oracle
·云扬·5 小时前
【MySQL】实战:用pt-table-sync修复主从数据一致性问题
数据库·mysql·ffmpeg
swIn KWAL5 小时前
【MySQL】环境变量配置
数据库·mysql·adb
shark22222226 小时前
【JOIN】关键字在MySql中的详细使用
数据库·mysql
RATi GORI6 小时前
MySQL中的CASE WHEN语句:用法、示例与解析
android·数据库·mysql
坊钰6 小时前
Java 死锁问题及其解决方案
java·开发语言·数据库
onebound_noah6 小时前
【实战教程】如何通过API快速获取淘宝/天猫商品评论数据(含多语言Demo)
大数据·数据库