FORUM

조회 수 15102 추천 수 0 댓글 2
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄
교재 보구 따라하는 데도 안되네요 ㅠ.ㅠ

두개의 테이블을 만들었습니다.
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
요렇게 조회 했습니다. ===> 오류가 나네요? 어떻게 해야 하는지요??

도와주세요~~

  • ?
    남재우 2009.05.13 03:23

    입력은 잘하셨읍니다. 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로 만들어 내는 부분입니다.

  • ?
    삽질중 2009.05.13 03:52
    네~ 답변 감사합니다. 비슷한 답변 보구 했었는데..
    가상테이블.NAME 이렇게 해야 하는군요....그 답변에는 그냥 가상테이블만 있었거든요..

    응용력이 떨어져서리..
    암튼 답변 정말 감사드립니다.

List of Articles
번호 제목 글쓴이 날짜 조회 수
공지 CUBRID 사용자를 위한 DBeaver 도구 출시 안내 7 admin 2024.04.23 14857
257 특정 테이블 최적화 시 에러 발생 3 인경수 2009.07.11 11233
256 [긴급] Java VM can not be started 메세지 원인?? 13 이석희 2009.07.07 20017
255 procedure 문의드립니다 1 삽질쟁이 2009.07.03 13974
254 The column name is invalid. 에러메시지 좀... 1 file 논픽션Lover 2009.07.02 21538
253 DataBase 검사 오류 1 file NonStop 2009.07.02 11898
252 초보질문 - insert할때 질문 1 rusell 2009.07.02 10806
251 데이터 보안기능 문의 1 secret hareton 2009.07.01 8
250 큐브리드와 php 연동을 할려는데 문제가?? 2 흑심품은연필 2009.07.01 12346
249 cubrid.jdbc.dirver.CUBRIDDriver 에러 4 논픽션Lover 2009.06.30 13851
248 복제 문의해요 3 삽질쟁이 2009.06.28 11814
247 select @@identity 1 펭귄 2009.06.27 20320
246 웹서버(Win)와 DB서버를 분리할 때 odbc설치 방법 2 안지민 2009.06.26 18101
245 안녕하세요? loaddb 에 대해 질문이 있습니다. 1 secret 서기97 2009.06.25 13
244 CUBRID-8.1.4.1032-linux 완전삭제 방법 1 secret rupee76 2009.06.25 9
243 ADD_MONTHS 함수의 사용 1 체리필터 2009.06.25 16563
242 재귀적 조인에 대한 쿼리를 저장할 수 있나요? 3 sizers 2009.06.23 20099
241 cubrid.jdbc.jci.JdbcCacheWorker에서 java.lang.NullPointerException 계속 발생하네요... 4 secret 거만쟁이 2009.06.23 30
240 spec 나 srpm 은 어디에서 받을 수 있나요? 5 아주가끔은 2009.06.21 10728
239 로그관련 문의부탁드립니다. 1 NonStop 2009.06.19 9839
238 Visual Basic 관련 문의 1 방랑아 2009.06.19 10590
Board Pagination Prev 1 ... 191 192 193 194 195 196 197 198 199 200 ... 208 Next
/ 208

Contact Cubrid

영업문의 070-4077-2112 / 기술문의 070-4077-2145 / 대표전화 070-4077-2110 / Email. contact_at_cubrid.com
Contact Sales

Sketchbook5, 스케치북5

Sketchbook5, 스케치북5

나눔글꼴 설치 안내


이 PC에는 나눔글꼴이 설치되어 있지 않습니다.

이 사이트를 나눔글꼴로 보기 위해서는
나눔글꼴을 설치해야 합니다.

나눔고딕 사이트로 가기

Sketchbook5, 스케치북5

Sketchbook5, 스케치북5