교재 보구 따라하는 데도 안되네요 ㅠ.ㅠ
두개의 테이블을 만들었습니다.
create table items
( name varchar(10),
price int,
primary key(name)
);
create table gameuser
( id varchar(10),
passwd varchar(10),
inventory set(items),
primary key(id)
);
items 에는
노랑머리 500
파랑머리 600
썬글라스 800
목걸이 900
의 레코드를 입력했습니다.
그리고 gameuser 는
INSERT INTO GAMEUSER
VALUES('USER1','1234',
{(SELECT ITEMS.IDENTITY FROM ITEMS WHERE NAME = '노랑머리')
,(SELECT ITEMS.IDENTITY FROM ITEMS WHERE NAME = '썬글라스')
,(SELECT ITEMS.IDENTITY FROM ITEMS WHERE NAME = '목걸이')};
이렇게 입력했습니다. -===> 맞는지요?
그리고
SELECT ID,PASSWD, INVENTORY.NAME FROM GAMEUSER
요렇게 조회 했습니다. ===> 오류가 나네요? 어떻게 해야 하는지요??
도와주세요~~
두개의 테이블을 만들었습니다.
create table items
( name varchar(10),
price int,
primary key(name)
);
create table gameuser
( id varchar(10),
passwd varchar(10),
inventory set(items),
primary key(id)
);
items 에는
노랑머리 500
파랑머리 600
썬글라스 800
목걸이 900
의 레코드를 입력했습니다.
그리고 gameuser 는
INSERT INTO GAMEUSER
VALUES('USER1','1234',
{(SELECT ITEMS.IDENTITY FROM ITEMS WHERE NAME = '노랑머리')
,(SELECT ITEMS.IDENTITY FROM ITEMS WHERE NAME = '썬글라스')
,(SELECT ITEMS.IDENTITY FROM ITEMS WHERE NAME = '목걸이')};
이렇게 입력했습니다. -===> 맞는지요?
그리고
SELECT ID,PASSWD, INVENTORY.NAME FROM GAMEUSER
요렇게 조회 했습니다. ===> 오류가 나네요? 어떻게 해야 하는지요??
도와주세요~~
입력은 잘하셨읍니다. values 에 마지막 ) 가 없는데 이건 아마 오타인 것 같구요.
검색할때 기본적인 방법은 맞습니다만 inventory가 set 인 관계로 꺼내는 방법이 조금 다릅니다. 단순히 질의로만 하실려면 set derived table 을 이용하는 방법을 사용해야 하며, 이는 set 에 들어가 있는 값들을 가상 테이블로 만드는 것입니다. 즉 set 안에 한개의 값이 있으면 한개의 레코드를 가지는 가상테이블로 만들어 지는 것이죠. 예에서는 3개의 값이 들어가 있으므로 3개의 레코드를 가지는 가상테이블로 만들어 집니다. 결국 결과는 3개의 레코드를 가지게 됩니다. 물론 id나 passwd는 동일한 값을 가지게 되겠죠. 필요하다면 응용단에서 본래 하나의 레코드가 임의 개수의(여기서는 3개)의 레코드로 확장되었음을 판단할 근거가 필요하기도 합니다. 질의는 아래와 같습니다.
csql> select id,passwd, t_inventory.name from gameuser, table(inventory) as t(t_inventory)
csql> ;ru
=== <Result of SELECT Command in Line 1> ===
id passwd t_inventory.name
==================================================================
'USER1' '1234' 'yellow'
'USER1' '1234' 'glass'
'USER1' '1234' 'necklace'
3 rows selected.
table(inventory) as t(...) 부분이 inventory 필드를 가상테이블 t로 만들어 내는 부분입니다.