假设我正在使用一个表人员,并且人员可能有多个姓氏,因此该属性应该是一个由 3 个元素组成的 varray(例如,它不是关于存储姓氏的位置),这是一个用于创建姓氏类型的简单 sql , 表 person 并在 oracle 的 sql developer (11G XE) 中添加示例行:
create type lastn as varray(3) of varchar2(10);
CREATE TABLE person
(
ID NUMBER NOT NULL
, last_name lastn
, CONSTRAINT EXEMPLE_PK PRIMARY KEY
(
ID
)
ENABLE
);
insert into person values(1,lastn('dani','bilel'));
我知道如何一次更新所有姓氏,但我需要保留现有姓氏并添加其他姓氏,或者删除一个姓氏而不影响其他姓氏。简而言之,我希望我的代码像(我不熟悉 PL/SQL):
insert into table
(select last_name from example where id=1)
values lastn('new');
在这种情况下,我想获得第一个姓氏为“bilel”,第二个姓氏为“dani”的人
select * from person where id in (select id from pernom p,table(p.last_name)
where column_value(1)='bilel' and column_value(2)='dani');
我知道它不是那样工作的,但我想知道这种情况下的 CRUD( create update delete ) 语句。并在 where 语句中使用 varray选择语句。
感谢您的答复。