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

sql server 之动态sql

需求:写动态SQL 实现 最后的and 限制 查找所有字段含01HX970,实现效果如下

SELECT * FROM [dbo].[AIO_Consumption_report] WHERE VALID = 'Y' AND LOCATION_NAME LIKE '%VN%'  AND (CAST([DATA_FROM_KEY] AS VARCHAR(50)) = '01HX970'   OR CAST([iwoow] AS VARCHAR(50)) = '01HX970' OR ……OR CAST([iwoow_RMK] AS VARCHAR(50)) = '01HX970')

实现代码:


DECLARE @sql NVARCHAR(MAX);  
SET @sql = N'SELECT * FROM [dbo].[AIO_Consumption_report] WHERE VALID = ''Y'' AND LOCATION_NAME LIKE ''%VN%'' ';  
  
-- 初始化一个临时变量来存储条件  
DECLARE @conditions NVARCHAR(MAX);  
SET @conditions = N'';  
  
-- 获取所有非日期/时间字段名并构建动态条件  
SELECT @conditions = @conditions +   
    CASE   
        WHEN DATA_TYPE IN ('int', 'bigint', 'smallint', 'tinyint', 'decimal', 'numeric', 'float', 'real') THEN  
            'CAST(' + QUOTENAME(COLUMN_NAME) + ' AS VARCHAR(50)) = ''01HX970'' OR '  
        ELSE  
            -- 排除日期/时间类型,只保留字符型数据或不确定类型(如sql_variant)  
            CASE WHEN DATA_TYPE IN ('char', 'varchar', 'nchar', 'nvarchar', 'text', 'ntext', 'sql_variant') THEN  
                'CAST(' + QUOTENAME(COLUMN_NAME) + ' AS VARCHAR(50)) = ''01HX970'' OR '  
            ELSE  
                ''  -- 对于其他类型,不添加条件  
            END  
    END  
FROM INFORMATION_SCHEMA.COLUMNS  
WHERE TABLE_NAME = 'AIO_Consumption_report' AND TABLE_SCHEMA = 'dbo';  


-- 如果有生成条件,则移除最后的 ' OR ' 并拼接到主SQL语句中  
IF LEN(@conditions) > 0   
BEGIN  
    -- 去掉最后的 ' OR ' 并加上括号  
    SET @conditions = LEFT(@conditions, LEN(@conditions) - 3);  -- 去除最后的 ' OR '  
    SET @sql = @sql + ' AND (' + @conditions + ')';  -- 拼接到主SQL语句中  
END  
ELSE  
BEGIN  
    -- 如果没有条件,则保持当前的 SQL 不变  
    SET @sql = @sql + ';';  
END  
  
-- 打印 SQL 语句以进行调试  
SELECT @sql;

-- 执行动态 SQL
EXEC sp_executesql @sql;

注意:

SQL Server Management Studio(SSMS)限制:有时,SSMS 的 PRINT 命令只会输出部分内容。它最多可以打印 4000 个字符(如果是 NVARCHAR(MAX)),因此如果你使用 PRINT 来调试长 SQL 语句,它可能被截断。你可以尝试将结果输出到临时表或文件,而不是直接 PRINT

替代方法:可以通过 SELECT 而不是 PRINT 来输出 SQL 语句。


http://www.kler.cn/a/369519.html

相关文章:

  • InnoDB存储引擎对MVCC实现
  • Linux 命令行查看当前目录的总大小/总磁盘空间/磁盘清理
  • VGG16
  • XQT_UI 组件|03 |加载组件 XQtLoading
  • 基于Python的B站视频数据分析与可视化
  • Python4
  • python学习笔记:___getattr__
  • Unity 实现音频进度条(可控制)
  • iframe里放的视频,如何采用纯css适配
  • 完美结局 ubuntu开机卡在等待网络连接
  • 【深度学习】合合信息:生成式AI时代的内容安全与系统构建
  • Linux运行时动态库搜索路径优先级
  • 偷懒总结篇|贪心算法|动态规划|单调栈|图论
  • Mqtt协议快速入门Demo
  • RK3568 android11 usb接口TP与电磁笔触点上报优先级问题
  • HCIP-HarmonyOS Application Developer 习题(十八)
  • Unity URP ShaderGraph 基本设置
  • [论文阅读]Detecting Pretraining Data from Large Language Models
  • Windows服务器如何远程登录 #服务器远程教程#
  • 大数据-192 DataX - 异构数据源的同步工具 核心模块 Reader Writer
  • 【微服务】Nacos 注册中心
  • 实时面部情绪识别技术解析
  • 大券商和小券商开户,哪个更划算?
  • 算法:利用前序序列和中序序列构造二叉树
  • Spring常见面试题总结
  • java程序,生成mysql测试数据