Die generierte DDL-Datei wird auf der Seite DDL voranzeigen im Assistenten Datenbankobjekte einfügen angezeigt.
In Tabelle 1 werden Beispiele für die DDL gezeigt, die für das Kopieren von PL/SQL-Funktionen aus einer Oracle Database 11g-Quellendatenbank in eine DB2 Version 9.7 für Linux®, UNIX® und Windows®-Zieldatenbank generiert wird.
| Oracle Database 11g - PL/SQL-Funktionsdefinition | Generierte DDL für Datenbank in DB2 Version 9.7 |
|---|---|
CREATE OR REPLACE FUNCTION func_authid2 RETURN NUMBER AUTHID DEFINED AS x NUMBER(9,2); BEGIN x := 65400; RETURN x; END; / |
CREATE FUNCTION func_authid2 RETURN NUMBER AUTHID DEFINED AS x NUMBER(9,2); BEGIN x := 65400; RETURN x; END func_authid2; |
CREATE OR REPLACE FUNCTION func_cursr ( p_job VARCHAR2 ) RETURN SYS_REFCURSOR IS emp_refcur SYS_REFCURSOR; BEGIN OPEN emp_refcur FOR SELECT empno, ename FROM emp WHERE job = p_job; RETURN emp_refcur; END; / |
CREATE FUNCTION func_cursr ( p_job VARCHAR2 ) RETURN SYS_REFCURSOR IS emp_refcur SYS_REFCURSOR; BEGIN OPEN emp_refcur FOR SELECT empno, ename FROM emp WHERE job = p_job; RETURN emp_refcur; END func_cursr; |
CREATE OR REPLACE FUNCTION func_cursr2
( p_job VARCHAR2,
c SYS_REFCURSOR )
RETURN SYS_REFCURSOR
IS
emp_refcur SYS_REFCURSOR;
BEGIN
OPEN emp_refcur
FOR SELECT empno, ename
FROM emp
WHERE job = p_job;
RETURN emp_refcur;
END;
/
|
CREATE FUNCTION func_cursr2 (
p_job VARCHAR2,
c SYS_REFCURSOR )
RETURN SYS_REFCURSOR
IS
emp_refcur SYS_REFCURSOR;
BEGIN
OPEN emp_refcur
FOR SELECT empno, ename
FROM emp
WHERE job = p_job;
RETURN emp_refcur;
END func_cursr2;
|
CREATE OR REPLACE FUNCTION func_inout
( p_job IN VARCHAR2,
p_job2 OUT VARCHAR2,
p_job3 IN OUT VARCHAR2 )
RETURN SYS_REFCURSOR
IS
emp_refcur SYS_REFCURSOR;
BEGIN
OPEN emp_refcur
FOR SELECT empno, ename
FROM emp
WHERE job = p_job;
RETURN emp_refcur;
END;
/
|
CREATE FUNCTION func_inout ( p_job IN VARCHAR2, p_job2 OUT VARCHAR2, p_job3 IN OUT VARCHAR2 ) RETURN SYS_REFCURSOR IS emp_refcur SYS_REFCURSOR; BEGIN OPEN emp_refcur FOR SELECT empno, ename FROM emp WHERE job = p_job; RETURN emp_refcur; END func_inout; |
CREATE OR REPLACE FUNCTION func_inout2
( p_job IN VARCHAR2,
p_job2 OUT NOCOPY VARCHAR2,
p_job3 IN OUT VARCHAR2 )
RETURN SYS_REFCURSOR
IS
emp_refcur SYS_REFCURSOR;
BEGIN
OPEN emp_refcur
FOR SELECT empno, ename
FROM emp
WHERE job = p_job;
RETURN emp_refcur;
END;
/
|
CREATE FUNCTION func_inout2 ( p_job IN VARCHAR2, p_job2 OUT NOCOPY VARCHAR2, p_job3 IN OUT VARCHAR2 ) RETURN SYS_REFCURSOR IS emp_refcur SYS_REFCURSOR; BEGIN OPEN emp_refcur FOR SELECT empno, ename FROM emp WHERE job = p_job; RETURN emp_refcur; END func_inout2; |
CREATE FUNCTION sal_ok2
( salary NUMBER,
title VARCHAR2 )
RETURN BOOLEAN
IS
min_sal NUMBER;
max_sal NUMBER;
-- AUTHID CURRENT_USER
-- PARALLEL_ENABLE
BEGIN
SELECT losal, hisal
INTO min_sal, max_sal
FROM sals
WHERE job = title;
RETURN (salary >= min_sal)
AND (salary <= max_sal);
END;
/
|
CREATE FUNCTION sal_ok2 )
salary NUMBER,
title VARCHAR2 )
RETURN BOOLEAN
IS
min_sal NUMBER;
max_sal NUMBER;
-- AUTHID CURRENT_USER
-- PARALLEL_ENABLE
BEGIN
SELECT losal, hisal
INTO min_sal, max_sal
FROM sals
WHERE job = title;
RETURN (salary >= min_sal)
AND (salary <= max_sal);
END sal_ok2;
|
In Tabelle 2 wird ein Beispiel für die DDL gezeigt, die für das Kopieren einer PL/SQL-Funktion aus einer DB2 Version 9.7 für Linux, UNIX und Windows-Quellendatenbank in eine Oracle Database 11g-Zieldatenbank generiert wird.
| DB2 Version 9.7-Datenbank - PL/SQL-Funktionsdefinition | Generierte DDL für Oracle Database 11g |
|---|---|
CREATE FUNCTION F047(
pID INTEGER,
pFName CHAR,
pLNAME VARCHAR
-- , pmyLONGVARCHAR LONG VARCHAR
)
RETURN CHAR
AS
BEGIN
RETURN pFName;
END F047;
|
CREATE FUNCTION F047
(pID INTEGER,
pFName CHAR,
pLNAME VARCHAR
--, pmyLONGVARCHAR LONG VARCHAR
)
RETURN CHAR
AS
BEGIN
RETURN pFName;
END F047;
|