首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >PL/SQL: UPDATE is,但某些数据为空

PL/SQL: UPDATE is,但某些数据为空
EN

Stack Overflow用户
提问于 2009-03-26 13:55:29
回答 3查看 1.9K关注 0票数 0

我还在学习PL/SQL的一些区别,所以这可能是一个简单的问题,但是...开始吧。

我有一个光标,它可以抓取一堆具有多个字段的记录。然后,我在游标结果的循环中运行两个单独的SELECT语句,以获取一些距离并计算这些距离。这些都能完美地工作。

当我使用新值更新表时,我的问题是有四个特定的条件。

代码语言:javascript
复制
update work
        set kilometers = calc_kilo,
            kilo_test = test_kilo                                  
        where lc = rm.lc
        AND ld = rm.ld
        AND le = rm.le
        AND lf = rm.lf
        AND code = rm.code
        AND lcode = rm.lcode
        and user_id = username;

我的问题是这很少更新,因为rm.lf和rm.le在数据库中有空值。我如何才能解决这个问题,并创建正确的更新。

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2009-03-26 14:10:58

如果我没有理解错的话,您希望将lfrm.lf进行匹配,包括当它们都为空时?如果这就是你想要的,那么这个就可以了:

代码语言:javascript
复制
...
AND (lf = rm.lf 
  OR (lf IS NULL AND rm.lf IS NULL)
)
... 

它比较lfrm.lf的值,如果两者都为null,则返回false,因此如果两者都为null,则OR条件返回true。

票数 2
EN

Stack Overflow用户

发布于 2009-03-26 17:52:31

我有一个光标,它可以抓取一堆有多个字段的记录。然后,我在游标结果的循环中运行两个单独的SELECT语句,以获取一些距离并计算这些距离。这些都能完美地工作。

当我使用新值更新表时,我的问题是有四个特定的条件。

我首先要考虑的不是使用游标来读取数据,然后进行计算,然后执行更新。在99%的情况下,只需运行一个步骤即可完成所有这些任务的更新会更快、更容易

票数 1
EN

Stack Overflow用户

发布于 2012-08-15 09:15:25

代码语言:javascript
复制
update work 
        set kilometers = calc_kilo, 
            kilo_test = test_kilo                                   
        where lc = rm.lc 
        AND ld = rm.ld 
        AND NVL(le,'x') = NVL(rm.le,'x') 
        AND NVL(lf,'x') = NVL(rm.lf,'x') 
        AND code = rm.code 
        AND lcode = rm.lcode 
        and user_id = username;
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/685902

复制
相关文章

相似问题

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