0

以下函数应该返回与特定会议相关的信息,存储在会议表中:

CREATE TABLE  "MEETING" 
   (    "MEETING_ID" NUMBER(10,0) NOT NULL ENABLE, 
    "TIME" TIMESTAMP (4) NOT NULL ENABLE, 
    "LOCATION" VARCHAR2(40), 
    "MAP_HREF" VARCHAR2(140), 
    "FK_INTEREST_ID" CHAR(4) NOT NULL ENABLE, 
    "ADDITIONAL_INFO" CLOB, 
    "PASSED" NUMBER(1,0), 
    "TITLE" VARCHAR2(20), 
     CONSTRAINT "MEETING_PK" PRIMARY KEY ("MEETING_ID") ENABLE
   ) ;

代码编译得很好,运行也很好。

但是,如果会议存在,则仅返回 null。如果会议不存在,则异常会正确打印“UNKNOWN APPOINTMENT”。

CREATE OR REPLACE FUNCTION GetMeeting
                    (meetingnumber MEETING.MEETING_ID%TYPE)
RETURN VARCHAR
IS
    CURSOR current_meeting(meetingnumber MEETING.MEETING_ID%TYPE)
    IS
        SELECT TITLE
        FROM MEETING
        WHERE MEETING_ID = meetingnumber;

    r_meeting current_meeting%ROWTYPE;
BEGIN
    OPEN current_meeting(meetingnumber);

    FETCH current_meeting INTO r_meeting;

    IF current_meeting%NOTFOUND THEN
        r_meeting.TITLE := 'UNKNOWN APPOINTMENT';
    END IF;

    CLOSE current_meeting;

    RETURN r_meeting.TITLE;
END;


SELECT GetMeeting (27) appointment
FROM MEETING;
4

4 回答 4

2

似乎这是使用游标的练习?它比它需要的复杂得多。尝试类似(未经测试):

create or replace function get_meeting(i_meetingnumber MEETING.MEETING_ID%TYPE)
RETURN VARCHAR2
IS
  l_title MEETING.TITLE%TYPE;
BEGIN

  select title
  into l_title
  FROM MEETING
  WHERE MEETING_ID = i_meetingnumber;

  return l_title;
EXCEPTION
  when no_data_found then
    return 'UNKNOWN APPOINTMENT';
  when others then raise;
END;

将这个小逻辑放入函数中也有点不必要,我会根据需要简单地选择它(通过更大的 SQL 的连接或单独在更大的 pl/sql 过程中)

另外,我注意到您的原始函数返回 VARCHAR,其中标题为 VARCHAR2。不确定转换是否由 Oracle 隐式完成,但值得一提。

于 2013-05-13T13:39:16.930 回答
1
SELECT NVL(TITLE, 'UNKNOWN APPOINTMENT') FROM MEETING WHERE MEETING_ID = meetingnumber;

干净多了。

于 2013-05-13T13:45:47.090 回答
0

检查以下声明:

IF r_meeting%NOTFOUND THEN
        r_meeting.TITLE := 'UNKNOWN APPOINTMENT';
        END IF;

        CLOSE current_meeting;

        RETURN r_meeting.TITLE;
    END;
于 2013-05-13T12:56:52.683 回答
0

PL/SQL 函数工作正常。它会返回所需的结果,但您的选择会返回与 MEETING 中一样多的数据集。您应该从 dual 中进行选择。

于 2013-05-13T13:01:07.043 回答