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

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 09: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
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 7月2日
  • 已采纳回答 6月24日
  • 修改了问题 6月24日
  • 创建了问题 6月24日

悬赏问题

  • ¥15 wegame打不开英雄联盟
  • ¥15 公司的电脑,win10系统自带远程协助,访问家里个人电脑,提示出现内部错误,各种常规的设置都已经尝试,感觉公司对此功能进行了限制(我们是集团公司)
  • ¥15 救!ENVI5.6深度学习初始化模型报错怎么办?
  • ¥30 eclipse开启服务后,网页无法打开
  • ¥30 雷达辐射源信号参考模型
  • ¥15 html+css+js如何实现这样子的效果?
  • ¥15 STM32单片机自主设计
  • ¥15 如何在node.js中或者java中给wav格式的音频编码成sil格式呢
  • ¥15 不小心不正规的开发公司导致不给我们y码,
  • ¥15 我的代码无法在vc++中运行呀,错误很多