SQL动态ORDER BY使用别名
发布时间:2021-05-06 09:35:48 所属栏目:MsSql教程 来源:网络整理
导读:使用SQL Server,我可以使用别名来命令正常的SELECT查询: SELECT u.FirstName + ' ' + u.LastName as PhysicianName,COUNT(r.Id) as ReferralsCountFROM Referrals r INNER JOIN Users u ON r.PhysicianId = u.IdGROUP BY r.PhysicianId,u.FirstName,u.Las
使用SQL Server,我可以使用别名来命令正常的SELECT查询: SELECT u.FirstName + ' ' + u.LastName as PhysicianName,COUNT(r.Id) as ReferralsCount FROM Referrals r INNER JOIN Users u ON r.PhysicianId = u.Id GROUP BY r.PhysicianId,u.FirstName,u.LastName ORDER BY PhysicianName 但是,尝试使用动态ORDER BY执行相同的操作: SELECT u.FirstName + ' ' + u.LastName as PhysicianName,COUNT(r.Id) as ReferralsCount FROM Referrals r INNER JOIN Users u ON r.PhysicianId = u.Id GROUP BY r.PhysicianId,u.LastName ORDER BY CASE WHEN @orderby = 'PhysicianName' THEN PhysicianName END,CASE WHEN @orderby = 'ReferralsCount' THEN ReferralsCount END 产生以下错误:
解决方法SELECT中定义的列别名只能在ORDER BY中单独使用.不在表达中.您可以按如下方式调整原始尝试. ;WITH T AS (SELECT u.FirstName + ' ' + u.LastName AS PhysicianName,COUNT(r.Id) AS ReferralsCount FROM Referrals r INNER JOIN Users u ON r.PhysicianId = u.Id GROUP BY r.PhysicianId,u.LastName) SELECT * FROM T ORDER BY CASE WHEN @orderby = 'PhysicianName' THEN PhysicianName END,CASE WHEN @orderby = 'ReferralsCount' THEN ReferralsCount END (编辑:永州站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
相关内容
- 初学者SQL问题:具有多个COUNT(*)结果的算术
- sql-server-2008 – “无法找到存储过程”,即使已在MS SQL
- sql-server-2008-r2 – 使用sp_启动用户存储过程的名称仍然
- sql-server – Transact-SQL查询中字符串前的N前缀
- sql – 如何组合来自两个存储过程调用的结果集?
- sql 中rand函数怎样用?sql怎样获取区间随机数?
- sql-update – 从另一个表更新多个列 – 需要Oracle格式
- SqlDateTime溢出是什么原因?如何解决?
- sql-server – 安全地移动和创建新的tempdb文件
- sql-server – 触发无限期WAITFOR会增加日志文件的大小吗?
站长推荐
热点阅读