亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

SQL語句優化(連續簽到獎勵疊加問題)

SQL語句優化(連續簽到獎勵疊加問題)

犯罪嫌疑人X 2018-08-13 07:10:04
查詢連續簽到日期,每次簽到獎勵加1,獎勵達到8個就不在增加(一直保持每次簽到給8個)。要求在sql語句中拼接出昨日,今日,以及后4日的簽到日期所對應的獎勵。目前的sql語句如下(這種寫法要創建和刪除臨時表有沒有好的寫法)DECLARE @now DATETIME = GETDATE() ,@count INT ,@i INT= 0;SELECT @count = COUNT(*)FROM ( SELECT DATEDIFF(DAY, CreateTime, @now) a , --簽到時間對比今天的差值ROW_NUMBER() OVER ( ORDER BY CreateTime DESC ) b --排序字段 FROM T_SignRecordWHERE UId = @UIdAND DATEDIFF(DAY, CreateTime, @now) > 0 --排除今天的簽到記錄 ) TWHERE a = b;CREATE TABLE #temp --創建臨時表(CreateTime DATETIME ,SignRewardCount INT);WHILE @i < 6BEGIN INSERT INTO #temp( CreateTime ,SignRewardCount)VALUES ( DATEADD(dd, @i, DATEADD(dd, -1, @now)) ,CASE WHEN @count = 0 THEN @iWHEN ( @count + @i ) > 8 THEN 8ELSE @count + @iEND);    SET @i = @i + 1;END;SELECT *FROM #temp;DROP TABLE #temp;--刪除臨時表
查看完整描述

1 回答

?
小唯快跑啊

TA貢獻1863條經驗 獲得超2個贊

換個思路吧,雖然sql可以做這個,但做起來會很吃力

你直接把相關簽到記錄取出來在程序里面掰不光在寫起來會簡單很多,性能也會好些


查看完整回答
反對 回復 2018-08-23
  • 1 回答
  • 0 關注
  • 1051 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號