日期:2014-05-17  浏览次数:20767 次

嵌套表的引用问题
一下SQL在执行到最后一句时报错

CREATE   TYPE   TEACHER   AS   OBJECT
(
    NAME   VARCHAR2(105),
    BIRTH   DATE
);
/

CREATE   TYPE   TEACHER_TABLE   AS   TABLE   OF   TEACHER;
/

CREATE   TABLE   CENTER(
    NAME   VARCHAR2(4)   PRIMARY   KEY,
    TEACHERS   TEACHER_TABLE
)NESTED   TABLE   TEACHERS   STORE   AS   TEACHER_TABLE_CENTER;

INSERT   INTO   CENTER   VALUES( '徐汇 ',
    TEACHER_TABLE(
        TEACHER( '张老师 ',   to_date( '1980-1-1 ',   'yyyy-mm-dd ')),
        TEACHER( '李老师 ',   to_date( '1982-1-1 ',   'yyyy-mm-dd ')),
        TEACHER( '胡老师 ',   to_date( '1978-1-1 ',   'yyyy-mm-dd '))
    )
);

INSERT   INTO   CENTER   VALUES( '长宁 ',
    TEACHER_TABLE(
        TEACHER( '方方老师 ',   to_date( '1981-12-31 ',   'yyyy-mm-dd ')),
        TEACHER( '马老师 ',   to_date( '1983-12-31 ',   'yyyy-mm-dd '))
    )
);

CREATE   TYPE   STUDENT   AS   OBJECT
(
    NAME   VARCHAR2(105),
    STUDNO   CHAR(10)
);
/

CREATE   TYPE   STUDENT_ARR   AS   VARRAY(30)   OF   STUDENT;
/

CREATE   TABLE   CLASS(
    CLASSID   VARCHAR2(7)   PRIMARY   KEY,
    CENTER_NAME   VARCHAR2(4)   REFERENCES   CENTER(NAME),
    TEACHER_REF   REF   TEACHER,
    STUDENTS   STUDENT_ARR
);

INSERT   INTO   CLASS
SELECT   '0722T03 ',   '徐汇 ',   REF(VALUE(T)),
STUDENT_ARR(
STUDENT( '张三 ',   '0001155245 '),
STUDENT( '李四 ',   '0001152444 '),
STUDENT( '王五 ',   '0001155242 '),
STUDENT( '赵六 ',   '0001158357 ')
)
FROM   TABLE(SELECT   TEACHERS   FROM   CENTER   WHERE   NAME   =   '徐汇 ')   T
WHERE   NAME   =   '张老师 ';

表结构简单来说就时有个CENTER表中有个个TEACHER的嵌套表,CLASS表中的TEACHER_REF字段希望引用该TEACHER嵌套表中的某记录,但在最后实行插入是报缺少右括号,但我实在找不出什么地方缺右括号啊。

------解决方案--------------------
帮顶
------解决方案--------------------
调试了一下,感觉是 REF(VALUE(T)) 错,
不知道其中的VALUE(T)能不能这样用的?
------解决方案--------------------
参考


REF函数用于对象表的创建和插入,看下面的例子:

--创建表对象Address_TP
CREATE TYPE Address_TP AS OBJECT (
address_id number,
street VARCHAR2(40),
building VARCHAR2(40),
phone VARCHAR2(15)
);
--创建表对象Student_TP
CREATE TYPE Student_TP AS OBJECT (
Name VARCHAR2(15),
Age NUMBER,
Address REF Address_TP
);
--创建对象表Address
CREATE TABLE Address OF Address_TP (
PRIMARY KEY (address_id)
);
--创建对象表Student
CREATE TABLE Student OF Student_TP (
PRIMARY KEY (Name)
);

--插入数据
INSERT INTO Address VALUES (
1, 'BeijingJianGuoMenWaiDaJie ', 'Buiding-A ',