首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Oracle函数返回Null?

Oracle函数返回Null?
EN

Stack Overflow用户
提问于 2017-05-24 18:55:59
回答 1查看 1.2K关注 0票数 0

这开始把我逼疯了,我找不到为什么这个不起作用了!

表上有触发器,以便自动填充cityID和postcodeID。此函数的目的是查找同名的城市并返回其ID,否则将其添加到表中并返回新的ID。

代码语言:javascript
复制
CREATE OR REPLACE FUNCTION resolveCity(cityNameIn IN VARCHAR2)
RETURN NUMBER AS
    cityIDOut NUMBER;
BEGIN
    SELECT cityID
    INTO cityIDOut
    FROM tblCities
    WHERE cityName = cityNameIn;

    IF cityIDOut IS NULL THEN
        -- Add this city to the list
        INSERT INTO tblCities (cityName)
        VALUES (cityNameIn)
        RETURNING cityID INTO cityIDOut;
    END IF;

    RETURN(cityIDOut);
END;
/
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2017-05-24 19:15:47

如果选择在PL/SQL中失败,将引发NO_DATA_FOUND异常。在本例中,函数中没有处理程序,因此它被提升到外部处理程序--而且显然没有处理程序,因此它会掉在地板上并丢失。

我建议你将你的职能改写为:

代码语言:javascript
复制
CREATE OR REPLACE FUNCTION resolveCity(cityNameIn IN VARCHAR2)
RETURN NUMBER AS
    cityIDOut NUMBER;
BEGIN
  BEGIN
    SELECT cityID
      INTO cityIDOut
      FROM tblCities
      WHERE cityName = cityNameIn;
  EXCEPTION
    WHEN NO_DATA_FOUND THEN
      -- Add this city to the list
      INSERT INTO tblCities (cityName)
        VALUES (cityNameIn)
        RETURNING cityID INTO cityIDOut;
  END;

  RETURN(cityIDOut);
END;

祝你好运。

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/44166477

复制
相关文章

相似问题

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