Use table function to user-defined type column : table function « Object Oriented Database « Oracle PL / SQL

Oracle PL / SQL
1. Aggregate Functions
2. Analytical Functions
3. Char Functions
4. Constraints
5. Conversion Functions
6. Cursor
7. Data Type
8. Date Timezone
9. Hierarchical Query
10. Index
11. Insert Delete Update
12. Large Objects
13. Numeric Math Functions
14. Object Oriented Database
15. PL SQL
16. Regular Expressions
17. Report Column Page
18. Result Set
19. Select Query
20. Sequence
21. SQL Plus
22. Stored Procedure Function
23. Subquery
24. System Packages
25. System Tables Views
26. Table
27. Table Joins
28. Trigger
29. User Previliege
30. View
31. XML
Java
Java Tutorial
Java Source Code / Java Documentation
Java Open Source
Jar File Download
Java Articles
Java Products
Java by API
Photoshop Tutorials
Maya Tutorials
Flash Tutorials
3ds-Max Tutorials
Illustrator Tutorials
GIMP Tutorials
C# / C Sharp
C# / CSharp Tutorial
C# / CSharp Open Source
ASP.Net
ASP.NET Tutorial
JavaScript DHTML
JavaScript Tutorial
JavaScript Reference
HTML / CSS
HTML CSS Reference
C / ANSI-C
C Tutorial
C++
C++ Tutorial
Ruby
PHP
Python
Python Tutorial
Python Open Source
SQL Server / T-SQL
SQL Server / T-SQL Tutorial
Oracle PL/SQL Tutorial
PostgreSQL
SQL / MySQL
MySQL Tutorial
VB.Net
VB.Net Tutorial
Flash / Flex / ActionScript
VBA / Excel / Access / Word
XML
XML Tutorial
Microsoft Office PowerPoint 2007 Tutorial
Microsoft Office Excel 2007 Tutorial
Microsoft Office Word 2007 Tutorial
Oracle PL / SQL » Object Oriented Database » table function 
Use table function to user-defined type column
 
SQL>
SQL> CREATE TABLE EMP (EMPNO NUMBER(4NOT NULL,
  2                    ENAME VARCHAR2(10),
  3                    JOB VARCHAR2(9),
  4                    MGR NUMBER(4),
  5                    HIREDATE DATE,
  6                    SAL NUMBER(72),
  7                    COMM NUMBER(72),
  8                    DEPTNO NUMBER(2));

Table created.

SQL>
SQL> INSERT INTO EMP VALUES (7369'SMITH', 'CLERK',    7902, TO_DATE('17-DEC-1980', 'DD-MON-YYYY'), 800, NULL, 20);

row created.

SQL> INSERT INTO EMP VALUES (7499'ALLEN', 'SALESMAN', 7698, TO_DATE('20-FEB-1981', 'DD-MON-YYYY'), 160030030);

row created.

SQL> INSERT INTO EMP VALUES (7521'WARD',  'SALESMAN', 7698, TO_DATE('22-FEB-1981', 'DD-MON-YYYY'), 125050030);

row created.

SQL> INSERT INTO EMP VALUES (7566'JONES', 'MANAGER',  7839, TO_DATE('2-APR-1981',  'DD-MON-YYYY'), 2975, NULL, 20);

row created.

SQL> INSERT INTO EMP VALUES (7654'MARTIN', 'SALESMAN', 7698,TO_DATE('28-SEP-1981', 'DD-MON-YYYY'), 1250140030);

row created.

SQL> INSERT INTO EMP VALUES (7698'BLAKE', 'MANAGER', 7839,TO_DATE('1-MAY-1981', 'DD-MON-YYYY'), 2850, NULL, 30);

row created.

SQL> INSERT INTO EMP VALUES (7782'CLARK', 'MANAGER', 7839,TO_DATE('9-JUN-1981', 'DD-MON-YYYY'), 2450, NULL, 10);

row created.

SQL> INSERT INTO EMP VALUES (7788'SCOTT', 'ANALYST', 7566,TO_DATE('09-DEC-1982', 'DD-MON-YYYY'), 3000, NULL, 20);

row created.

SQL> INSERT INTO EMP VALUES (7839'KING', 'PRESIDENT', NULL,TO_DATE('17-NOV-1981', 'DD-MON-YYYY'), 5000, NULL, 10);

row created.

SQL> INSERT INTO EMP VALUES (7844'TURNER', 'SALESMAN', 7698,TO_DATE('8-SEP-1981', 'DD-MON-YYYY'), 1500030);

row created.

SQL> INSERT INTO EMP VALUES (7876'ADAMS', 'CLERK', 7788,TO_DATE('12-JAN-1983', 'DD-MON-YYYY'), 1100, NULL, 20);

row created.

SQL> INSERT INTO EMP VALUES (7900'JAMES', 'CLERK', 7698,TO_DATE('3-DEC-1981', 'DD-MON-YYYY'), 950, NULL, 30);

row created.

SQL> INSERT INTO EMP VALUES (7902'FORD', 'ANALYST', 7566,TO_DATE('3-DEC-1981', 'DD-MON-YYYY'), 3000, NULL, 20);

row created.

SQL> INSERT INTO EMP VALUES (7934'MILLER', 'CLERK', 7782,TO_DATE('23-JAN-1982', 'DD-MON-YYYY'), 1300, NULL, 10);

row created.

SQL>
SQL> CREATE TABLE DEPT (DEPTNO NUMBER(2),DNAME VARCHAR2(14),LOC VARCHAR2(13) );

Table created.

SQL>
SQL> INSERT INTO DEPT VALUES (10'ACCOUNTING', 'NEW YORK');

row created.

SQL> INSERT INTO DEPT VALUES (20'RESEARCH', 'DALLAS');

row created.

SQL> INSERT INTO DEPT VALUES (30'SALES', 'CHICAGO');

row created.

SQL> INSERT INTO DEPT VALUES (40'OPERATIONS', 'BOSTON');

row created.

SQL>
SQL> create or replace type emp_type
  2    as object
  3    (empno       number(4),
  4     ename       varchar2(10),
  5     job         varchar2(9),
  6     mgr         number(4),
  7     hiredate    date,
  8     sal         number(72),
  9     comm        number(72)
 10    );
 11  /

Type created.

SQL>
SQL> create or replace type emp_tab_type as table of emp_type;
  2  /

Type created.

SQL> create table dept_and_emp
  2    (deptno number(2primary key,
  3     dname     varchar2(14),
  4     loc       varchar2(13),
  5     emps      emp_tab_type
  6    )
  7    nested table emps store as emps_nt;

Table created.

SQL>
SQL>
SQL>
SQL> insert into dept_and_emp
  2    select dept.*,
  3       CASTmultisetselect empno, ename, job, mgr, hiredate, sal, comm from emp AS emp_tab_type )
  4      from dept
  5  /

rows created.

SQL>
SQL>
SQL> select d.deptno, d.dname, emp.*
  2    from dept_and_emp D, table(d.empsemp
  3  /

    DEPTNO DNAME               EMPNO ENAME      JOB              MGR HIREDATE                    SAL    COMM
---------- -------------- ---------- ---------- --------- ---------- -------------------- ---------- ----------
        10 ACCOUNTING           7369 SMITH      CLERK           7902 17-DEC-1980 00:00:00        800
        10 ACCOUNTING           7499 ALLEN      SALESMAN        7698 20-FEB-1981 00:00:00       1600        300
        10 ACCOUNTING           7521 WARD       SALESMAN        7698 22-FEB-1981 00:00:00       1250        500
        10 ACCOUNTING           7566 JONES      MANAGER         7839 02-APR-1981 00:00:00       2975
        10 ACCOUNTING           7654 MARTIN     SALESMAN        7698 28-SEP-1981 00:00:00       1250       1400
        10 ACCOUNTING           7698 BLAKE      MANAGER         7839 01-MAY-1981 00:00:00       2850
        10 ACCOUNTING           7782 CLARK      MANAGER         7839 09-JUN-1981 00:00:00       2450
        10 ACCOUNTING           7788 SCOTT      ANALYST         7566 09-DEC-1982 00:00:00       3000
        10 ACCOUNTING           7839 KING       PRESIDENT            17-NOV-1981 00:00:00       5000
        10 ACCOUNTING           7844 TURNER     SALESMAN        7698 08-SEP-1981 00:00:00       1500          0
        10 ACCOUNTING           7876 ADAMS      CLERK           7788 12-JAN-1983 00:00:00       1100
        10 ACCOUNTING           7900 JAMES      CLERK           7698 03-DEC-1981 00:00:00        950
        10 ACCOUNTING           7902 FORD       ANALYST         7566 03-DEC-1981 00:00:00       3000
        10 ACCOUNTING           7934 MILLER     CLERK           7782 23-JAN-1982 00:00:00       1300
        20 RESEARCH             7369 SMITH      CLERK           7902 17-DEC-1980 00:00:00        800
        20 RESEARCH             7499 ALLEN      SALESMAN        7698 20-FEB-1981 00:00:00       1600        300
        20 RESEARCH             7521 WARD       SALESMAN        7698 22-FEB-1981 00:00:00       1250        500
        20 RESEARCH             7566 JONES      MANAGER         7839 02-APR-1981 00:00:00       2975
        20 RESEARCH             7654 MARTIN     SALESMAN        7698 28-SEP-1981 00:00:00       1250       1400
        20 RESEARCH             7698 BLAKE      MANAGER         7839 01-MAY-1981 00:00:00       2850
        20 RESEARCH             7782 CLARK      MANAGER         7839 09-JUN-1981 00:00:00       2450
        20 RESEARCH             7788 SCOTT      ANALYST         7566 09-DEC-1982 00:00:00       3000
        20 RESEARCH             7839 KING       PRESIDENT            17-NOV-1981 00:00:00       5000
        20 RESEARCH             7844 TURNER     SALESMAN        7698 08-SEP-1981 00:00:00       1500          0
        20 RESEARCH             7876 ADAMS      CLERK           7788 12-JAN-1983 00:00:00       1100
        20 RESEARCH             7900 JAMES      CLERK           7698 03-DEC-1981 00:00:00        950
        20 RESEARCH             7902 FORD       ANALYST         7566 03-DEC-1981 00:00:00       3000
        20 RESEARCH             7934 MILLER     CLERK           7782 23-JAN-1982 00:00:00       1300
        30 SALES                7369 SMITH      CLERK           7902 17-DEC-1980 00:00:00        800
        30 SALES                7499 ALLEN      SALESMAN        7698 20-FEB-1981 00:00:00       1600        300
        30 SALES                7521 WARD       SALESMAN        7698 22-FEB-1981 00:00:00       1250        500
        30 SALES                7566 JONES      MANAGER         7839 02-APR-1981 00:00:00       2975
        30 SALES                7654 MARTIN     SALESMAN        7698 28-SEP-1981 00:00:00       1250       1400
        30 SALES                7698 BLAKE      MANAGER         7839 01-MAY-1981 00:00:00       2850
        30 SALES                7782 CLARK      MANAGER         7839 09-JUN-1981 00:00:00       2450
        30 SALES                7788 SCOTT      ANALYST         7566 09-DEC-1982 00:00:00       3000
        30 SALES                7839 KING       PRESIDENT            17-NOV-1981 00:00:00       5000
        30 SALES                7844 TURNER     SALESMAN        7698 08-SEP-1981 00:00:00       1500          0
        30 SALES                7876 ADAMS      CLERK           7788 12-JAN-1983 00:00:00       1100
        30 SALES                7900 JAMES      CLERK           7698 03-DEC-1981 00:00:00        950
        30 SALES                7902 FORD       ANALYST         7566 03-DEC-1981 00:00:00       3000
        30 SALES                7934 MILLER     CLERK           7782 23-JAN-1982 00:00:00       1300
        40 OPERATIONS           7369 SMITH      CLERK           7902 17-DEC-1980 00:00:00        800
        40 OPERATIONS           7499 ALLEN      SALESMAN        7698 20-FEB-1981 00:00:00       1600        300
        40 OPERATIONS           7521 WARD       SALESMAN        7698 22-FEB-1981 00:00:00       1250        500
        40 OPERATIONS           7566 JONES      MANAGER         7839 02-APR-1981 00:00:00       2975
        40 OPERATIONS           7654 MARTIN     SALESMAN        7698 28-SEP-1981 00:00:00       1250       1400
        40 OPERATIONS           7698 BLAKE      MANAGER         7839 01-MAY-1981 00:00:00       2850
        40 OPERATIONS           7782 CLARK      MANAGER         7839 09-JUN-1981 00:00:00       2450
        40 OPERATIONS           7788 SCOTT      ANALYST         7566 09-DEC-1982 00:00:00       3000
        40 OPERATIONS           7839 KING       PRESIDENT            17-NOV-1981 00:00:00       5000
        40 OPERATIONS           7844 TURNER     SALESMAN        7698 08-SEP-1981 00:00:00       1500          0
        40 OPERATIONS           7876 ADAMS      CLERK           7788 12-JAN-1983 00:00:00       1100
        40 OPERATIONS           7900 JAMES      CLERK           7698 03-DEC-1981 00:00:00        950
        40 OPERATIONS           7902 FORD       ANALYST         7566 03-DEC-1981 00:00:00       3000
        40 OPERATIONS           7934 MILLER     CLERK           7782 23-JAN-1982 00:00:00       1300

56 rows selected.

SQL>
SQL>
SQL> drop table emp cascade constraints;

Table dropped.

SQL> drop table dept cascade constraints;

Table dropped.

SQL> drop table dept_and_emp;

Table dropped.

SQL> drop type emp_tab_type;

Type dropped.

SQL> drop type emp_type;

Type dropped.

SQL>
SQL> --

 
Related examples in the same category
1. Use table function in from clause
www.java2java.com | Contact Us
Copyright 2009 - 12 Demo Source and Support. All rights reserved.
All other trademarks are property of their respective owners.