加入收藏 | 设为首页 | 会员中心 | 我要投稿 湖南网 (https://www.hunanwang.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程 > 正文

SQL Server动态排序依据

发布时间:2021-01-12 22:10:38 所属栏目:编程 来源:网络整理
导读:我正在实行在存储进程中行使动态次序,因此我可以将我想要的数据作为参数转达给存储进程.这合用于VARCHAR字段可是假如我实行对int或datetime字段举办排序,则会使我的代码堕落,如下所示 DECLARE @ORDERBY INTSET @ORDERBY = 1SELECT TOP 10 * FROM TBL_LMS_USER

我正在实行在存储进程中行使动态次序,因此我可以将我想要的数据作为参数转达给存储进程.这合用于VARCHAR字段可是假如我实行对int或datetime字段举办排序,则会使我的代码堕落,如下所示

DECLARE @ORDERBY INT
SET @ORDERBY = 1
SELECT TOP 10 * FROM TBL_LMS_USERS_RECORDs_LAST_ATTEMPT
ORDER BY 
CASE 
    WHEN @OrderBy = 1 THEN s10_record_dow
    --WHEN @OrderBy = 2 THEN pk_big_record_id
    else s10_record_dow
END

假如我在case语句中打消注释第二个WHEN,则会堕落

“Error converting data type varchar to bigint.”

假如我不行使case语句,我可以通过这个字段订购.

有任何设法吗?

办理要领

把它改成这个:
SELECT TOP 10 * FROM TBL_LMS_USERS_RECORDs_LAST_ATTEMPT
ORDER BY 
    CASE WHEN @OrderBy = 1 THEN s10_record_dow ELSE NUll END,CASE WHEN @OrderBy = 2 THEN pk_big_record_id ELSE NULL END,CASE WHEN @OrderBy <> 1 AND  @OrderBy <> 2 THEN s10_record_dow 
         ELSE NULL 
    END

(编辑:湖南网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    热点阅读