Background Image

FORUM

조회 수 14652 추천 수 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 이렇게 해야 하는군요....그 답변에는 그냥 가상테이블만 있었거든요..

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

  1. CUBRID 사용자를 위한 DBeaver 도구 출시 안내

    Date2024.04.23 Byadmin Views139
    read more
  2. SQLGate for CUBRID 영구 무료 라이선스 제공

    Date2020.04.09 Byadmin Views4478
    read more
  3. CUBRID 클라이언트만 설치 후 클라이언트 실행 에러

    Date2009.05.22 By일류요리사 Views16505
    Read More
  4. 큐브리드 매니저 질의편집기가 이상하네요.

    Date2009.05.21 By회색악마 Views11618
    Read More
  5. ODBC 다중 접속 댓글을 보고 나서...

    Date2009.05.20 ByApiClasser Views15888
    Read More
  6. CSQL을 통해서 데이터 입력 시 케릭터 셋 설정

    Date2009.05.20 By거만쟁이 Views13231
    Read More
  7. PDO 지원이 가능한가요?

    Date2009.05.20 Byihwan Views12045
    Read More
  8. 우분투 릴리즈 설치 지원 안되나요?

    Date2009.05.19 ByHoya Views17739
    Read More
  9. 쿼리 빌더 같은 것이 있나요?

    Date2009.05.16 Byjennysoft Views13085
    Read More
  10. [초보질문] dbcp test 중 오류발생

    Date2009.05.16 By삽질중 Views18406
    Read More
  11. [초보질문] 큐브리드 매니저에서 데이타베이스 종료시 에러

    Date2009.05.16 By삽질중 Views11940
    Read More
  12. Unable to access system message catalog.(null) (자답)

    Date2009.05.15 By공기청정기 Views11825
    Read More
  13. Unable to access system message catalog.(null)

    Date2009.05.14 By공기청정기 Views15693
    Read More
  14. MySQL의 LOAD DATA INFILE 기능은 CUBRID에 없나요?

    Date2009.05.13 By공기청정기 Views20624
    Read More
  15. [초보질문] 객체관계 테이블 set type 입력 및 조회 방법문의

    Date2009.05.13 By삽질중 Views14652
    Read More
  16. 안정성 관련 질문 드립니다.

    Date2009.05.12 Bykkckc Views15583
    Read More
  17. java.lang.ClassNotFoundException: cubrid.jdbc.dirver.CUBRIDDriver 에러에 관한문의

    Date2009.05.12 By삽질중 Views20671
    Read More
  18. 한글에 upper함수 적용하면 검색이 안되는 이유?

    Date2009.05.11 By장비맨 Views20810
    Read More
  19. [초보질문]function 변환 문의 (oracle -> cubrid)

    Date2009.05.08 By삽질중 Views22591
    Read More
  20. 큐브리드 개발 환경 구축 문제

    Date2009.05.08 By흐승욱 Views12783
    Read More
  21. [초보질문] 타유저 TABLE 생성 가능여부 및 볼륨 데이타 입력 문의

    Date2009.05.08 By삽질중 Views14046
    Read More
  22. ODBC 이용 SQLHSTMT 다중으로 사용하는게 불가능한가요 ?

    Date2009.05.04 ByApiClasser Views16565
    Read More
Board Pagination Prev 1 ... 186 187 188 189 190 191 192 193 194 195 ... 201 Next
/ 201

Contact Cubrid

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