VARRAYの作成:ストア可変長配列[PL/SQL]
それを使用しようとするとCREATE OR REPLACE TYPE ListaCursos IS VARRAY(10) OF Cursos;
DECLARE
listaCursos1 ListaCursos;
c1 Cursos;
c2 Cursos;
p_ref REF Profesor;
p_ref2 REF Profesor;
BEGIN
SELECT REF(p) INTO p_ref FROM Profesorado p WHERE p.codigo = 3;
c1 := NEW Cursos(1, 'Curso 1', p_ref, 20, '01/06/2011', '01/07/2011', 30);
SELECT REF(p) INTO p_ref2 FROM Profesorado p WHERE p.dni='51083099F';
c2 := NEW Cursos(2, 'Curso 2', p_ref2, 20, '01/06/2011', '01/07/2011', 30);
listaCursos1 := ListaCursos(c1, c2);
END;
/
:
CREATE TABLE Alumnado OF Alumno;
DECLARE
a1 Alumno;
a2 Alumno;
listaCursos1 ListaCursos;
BEGIN
a1 := NEW Alumno(100, '76401092Z', 'MANUEL', 'SUAREZ IBAÑEZ', 'M', '30/6/1990', listaCursos1(1));
a2 := NEW Alumno(102, '6915588V', 'MILAGROSA', 'DIAZ PEREZ', 'F', '28/10/1984', listaCursos1(2));
INSERT INTO Alumnado VALUES (a1);
INSERT INTO Alumnado VALUES (a2);
END;
/
そして今では、このエラーを示していますで
DECLARE * ERROR 1行目: ORA-06531:初期化されていないコレクションへの参照 ORA-06512:6行目
アクセスできます。 'listaCursos1(1)< - エラー'。 –
他のブロックで初期化しましたが、どうすれば保存できますか? – EBG
この値( 'listaCursos1')はどのくらい必要ですか?これらの挿入物のみ? –