SQL Server动态排序应避免字符串拼接,改用白名单内字段的CASE表达式;升降序用BIT参数配合正负号控制;WHERE条件用OR+IS NULL保持索引Seek能力。SQL Server 里用 @order_by 参数做动态排序,别拼字符串直接拼接 ORDER BY 字段名进 SQL 字符串,是绝大多数人踩的第一个坑------不仅有注入风险,SQL Server 还会拒绝缓存执行计划,每次都是编译新计划,性能掉得明显。正确做法是用 CASE 表达式在 ORDER BY 中分支判断,把排序逻辑"硬编码"进语句结构里,让优化器能预编译。字段名必须限定在白名单内,参数只控制分支走向。@order_by 类型用 VARCHAR(32) 就够,值只能是 'name'、'created_at'、'status' 这类预设字段每个可排序字段对应一个 CASE 分支,类型要一致(比如都转成 VARCHAR 或都保持原类型),否则 SQL Server 会报 Conversion failed when converting the varchar value to data type int升序降序不能靠传 'ASC'/'DESC' 字符串来控制,得拆成两个参数:@sort_dir 是 BIT(0=ASC,1=DESC),再用 CASE 包两层:外层控制正负号,内层取字段值WHERE 条件动态过滤,IS NULL 比 = @param 更安全参数可能为空,想让它"不生效",很多人写 WHERE status = ISNULL(@status, status),看着简洁,实际会导致索引失效------SQL Server 无法对表达式列做 Seek。更稳妥的是用 OR 配合 IS NULL 判断,让优化器有机会走索引 Seek,尤其当 @status 有值时:WHERE (@status IS NULL OR status = @status) AND (@category IS NULL OR category = @category)注意:多个 OR 条件叠加后,执行计划可能退化成 Scan,如果过滤字段区分度低(比如 status 只有 3 个值),建议加 OPTION (RECOMPILE) 让每次执行都重生成计划。PostgreSQL 的 ORDER BY 动态写法和 SQL Server 不一样PostgreSQL 支持在 ORDER BY 里直接用变量做字段名,但仅限于 USING 子句或函数内;存储过程里仍得靠 CASE,不过语法稍松:字段类型不必强一致,它会自动隐式转换。 WisPaper 复旦大学研发的AI学术搜索工具,5分钟内筛选1000篇论文
相关推荐
dragen_light2 小时前
1.ROS2-Installm0_676544382 小时前
JavaScript中enumerable属性对对象遍历的影响Absurd5872 小时前
SQL如何用SQL子查询实现关联报表生成_嵌套逻辑关联多表m0_514520572 小时前
CSS如何解决Less与CSS兼容性问题_通过配置文件实现平滑过渡与混合开发xyghehehehe2 小时前
【MySQL深入详解】第03篇:事务的本质——ACID与隔离级别深度解读HHHHH1010HHHHH2 小时前
JavaScript中利用IIFE创建私有命名空间的经典方案yuezhilangniao2 小时前
Redis 哨兵高可用集群完整文档-容器部署reids集群Irene19912 小时前
(课堂笔记)Oracle 子查询与表操作干洋芋果果2 小时前
前端学python