周周粥. 2022-06-24 00:45 采纳率: 50%
浏览 35
已结题

SqlServer存储问题

1.请按如图建立该表 插入如图数据

img

2.新建存储usp_getjh ,要求通过计算,获得 "jd"(进度)字段的值
判断标准 若bz=0 限制时间小于当前 则 jd赋值“超时未完成”;若bz=0 限制时间大于等于当前 则 jd赋值“未完成”;若bz=1 完成时间小于限制时间 则 jd赋值“已完成”;若bz=1 完成时间大于限制时间 则 jd赋值“超时已完成”
注:不可单独对数据进行计算,应通过一套算法,该算法试用于所有该类型数据,不局限于此表4条数据

  • 写回答

1条回答 默认 最新

  • foreverliuyin 2022-06-24 01:44
    关注
    create PROCEDURE [usp_getjh]
    AS
    BEGIN
        declare r cursor for select id,bz,xzsj,wcsj from dbo.jh
        open r
        declare    @id int,@bz nvarchar(50),@xzsj date,@wcsj date
        fetch next from r into @id,@bz,@xzsj,@wcsj
        while @@FETCH_STATUS = 0
            begin
                update dbo.jh set jd = case
                when @bz=0 and @xzsj<CONVERT (date, GETDATE()) then '超时未完成'
                when @bz=0 and @xzsj>CONVERT (date, GETDATE()) then '未完成'
                when @bz=1 and @wcsj<@xzsj then '已完成'
                when @bz=1 and @wcsj>@xzsj then '超时已完成'
                end
                where id=@id
                fetch next from r into @id,@bz,@xzsj,@wcsj
            end
        close r
        deallocate r
    END
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
    周周粥. 2022-06-24 02:02

    jb 那列的空值没有显示是什么原因呢?

    回复
    foreverliuyin 回复 周周粥. 2022-06-24 02:05

    jd列?你运行完这个存储过程就没空值了

    回复
    周周粥. 回复 foreverliuyin 2022-06-24 02:08

    好的 已经显示出来了 谢谢大佬大佬大佬大佬大佬大佬

    img


    大佬

    img


    图片表情

    img


    图片表情

    回复
编辑
预览

报告相同问题?

问题事件

  • 系统已结题 7月1日
  • 已采纳回答 6月24日
  • 修改了问题 6月24日
  • 创建了问题 6月24日
手机看
程序员都在用的中文IT技术交流社区

程序员都在用的中文IT技术交流社区

专业的中文 IT 技术社区,与千万技术人共成长

专业的中文 IT 技术社区,与千万技术人共成长

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

客服 返回
顶部