首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >校验和(NEWID())负值

校验和(NEWID())负值
EN

Stack Overflow用户
提问于 2018-06-28 00:19:21
回答 2查看 408关注 0票数 0

我需要用随机的int值更新Auftrag表中的记录

代码语言:javascript
复制
UPDATE Auftrag SET Dauer = ((CHECKSUM(NEWID()) % 10)+0.5), Anfahrt = ((CHECKSUM(NEWID()) % 70)+1), Beschreibung= 'Auto filled' WHERE Dauer IS NULL AND MitID IS NOT NULL

但是为什么我在DauerAnfahrt上也得到了负值,我如何解决这个问题呢?

EN

回答 2

Stack Overflow用户

发布于 2018-06-28 00:25:38

您可以使用abs()函数返回checksum(...)的绝对值:

代码语言:javascript
复制
UPDATE Auftrag SET 
  Dauer = ABS(CHECKSUM(NEWID())) % 10 + 0.5, 
  Anfahrt = ABS(((CHECKSUM(NEWID())) % 70 + 1, 
  Beschreibung= 'Auto filled'
WHERE 
  Dauer IS NULL 
  AND MitID IS NOT NULL

我删除了不必要的圆括号,因为这里的操作顺序会解决这个问题。

票数 0
EN

Stack Overflow用户

发布于 2018-06-28 00:26:03

我通常将函数包装在rand()

代码语言:javascript
复制
UPDATE Auftrag
    SET Dauer = floor(rand(checksum(newid())) * 10) + 0.5,
        Anfahrt = floor(rand(checksum(newid())) * 70) + 1,
        Beschreibung= 'Auto filled'
    WHERE Dauer IS NULL AND MitID IS NOT NULL;
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/51067377

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档