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

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

List of Articles
번호 제목 글쓴이 날짜 조회 수
공지 CUBRID 사용자를 위한 DBeaver 도구 출시 안내 admin 2024.04.23 53
공지 SQLGate for CUBRID 영구 무료 라이선스 제공 file admin 2020.04.09 4459
3595 windows에서 linux(centOs) cubrid로 접속에러 1 file 홉스 2016.12.23 14736
3594 Windows 7 64bit 에서 cubrid 설치 되나요? 2 예수 2009.06.17 14733
3593 데이터가 존재하는 테이블 내 필드의 데이터 타입 변경이 가능한가요? 2 차오이 2011.04.09 14727
3592 Not Null만 설정하면 에러가 나요... 4 file 날개 2009.04.09 14718
3591 어찌해서 설치는됫는데... 1 가루구 2009.02.17 14695
3590 홀따옴표 처리 문의 1 초보 2010.04.15 14679
3589 asp.net 윈도우즈 설치 문의 3 shblitz 2011.12.29 14673
3588 클라이언트에서 원격지 DB로의 접속이 되지 않습니다... 9 김동진81 2009.10.08 14672
3587 잦은 트랜잭션으로 인한 마스터서버의 다운 문제. 6 노랑배 2012.02.16 14662
» [초보질문] 객체관계 테이블 set type 입력 및 조회 방법문의 2 삽질중 2009.05.13 14652
3585 64bit 9.1버전에서 컬럼 수정시 에러 발생 (에러코드 1046) 1 file 오션나인 2013.08.27 14632
3584 loaddb 시 로딩결과 또는 에러내용을 확인할 수 있는 로그파일 2 송송이 2016.12.20 14625
3583 root권한으로 구동한 cubrid를 일반계정으로 변경하는 방법 문의 2 밈s 2016.10.11 14608
3582 큐브리드매니저에서 NULL값과 문자속성의 빈값을 구분하여 표시 필요 2 file 고영진 2009.09.23 14594
3581 csql 환경에서 큐브리드 매니저에 있는 마이그레이션 기능을 사용할수 있을까요? 1 석현진 2017.01.04 14579
3580 큐브리드 매니저에 ms949 캐릭터셋 추가 8 종이 2010.05.04 14578
3579 CUBRIDPreparedStatement 에서 NullPointerException 발생 1 kjkmadness 2013.01.25 14545
3578 CUBRIDException 3 file 히로키 2009.11.24 14530
3577 어찌해서 설치는됫는데.. 1 가루구 2009.02.16 14529
3576 FreeBSD port 지원 가능한가요? 1 자유연애 2009.03.03 14524
Board Pagination Prev 1 ... 16 17 18 19 20 21 22 23 24 25 ... 200 Next
/ 200

Contact Cubrid

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