Background Image

FORUM

2009.12.05 03:48

oid select 질문입니다.

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

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄

자료실에 있는 큐브리드를 이용한 데이터베이스 이해와 실습의 문제에서

create table items ( name varchar(10), price int, primary key (name) );  

create table gamuser( id varchar(10), passwd varchar(10), inventory set(items), primary key(id) );

이렇게 테이블을 생성후에
insert into items values ( '노랑머리', 500 );
insert into items values ( '파랑머리', 600 );
insert into items values ( '선글라스', 300 );
insert into items values ( '장갑', 200 );
insert into items values ( '목걸이', 400 );  
--
insert into gamuser values ('user1', 'abcd', {(select items.identity from items where name = '노랑머리')});
insert into gamuser values ('user2', '1234', {(select items.identity from items where name = '노랑머리'),
                                                                (select items.identity from items where name = '선글라스')});
 이렇게 데이터를 넣은후에
select * from gamuser where id = 'user1';
gamuserd 테이블의 user1을 조회하면 inventory의 값이 oid 로 나오는데요.

주소를 따라간 값을 출력하려면 어떻게 해야하나요.


  • ?
    seongjoon 2009.12.07 00:56
    다음과 같은 쿼리를 사용하며 될 듯 싶습니다.
    select * from items where items in (select inventory from gamuser where id = 'user1');
    원하시는 결과가 아니시라면 댓글 주세요.
  • ?
    남재우 2009.12.09 06:21
    OID 를 사용하여 다른 테이블을 참고하는 경우에는 path expression 방법을 씁니다. 즉 <OID 를 가지고 있는 필드명>.<참고하는 테이블의 필드명> 형태로 사용합니다.
    select items.name from gamuser 와 같이 사용할 수 있습니다. 하지만 예에서는 단순히 OID를 참고하고 있는 것이 아니라 set 형태로 참고하고 있으므로 set derived table 형태와 같이 사용해야 합니다. set 을 가상의 테이블로 만들어 질의를 처리하는 것입니다. 주의할 점은 원래 하나의 레코드가 set 안의 원소 개수만큼 레코드가 늘어나므로 주의하실 필요가 있습니다.
    select item.name, item.price from gamuser, table(itemas) as t(item) 과 같이 질의 합니다. items 라는 set 필드를 t 라는 가상의 테이블로 만들고 가상의 테이블상의 필드명을 item 이라고 정의하는 것입니다.

List of Articles
번호 제목 글쓴이 날짜 조회 수
공지 CUBRID 사용자를 위한 DBeaver 도구 출시 안내 admin 2024.04.23 71
공지 SQLGate for CUBRID 영구 무료 라이선스 제공 file admin 2020.04.09 4466
999 8.44 버전 지원 여부와 9.대로 업그레이드시 안정 버전 문의드립니다. 1 땡땡이 2017.07.06 268
998 AUTO INCREASE 가 편집이 안됨 2 file 큐브리드어려워요 2022.02.08 268
997 testdb_t숫자, testdb_x숫자 형식으로 있는 파일 삭제 해도 되나요? 3 coolkkm 2017.11.30 267
996 혼합형 데이터 정렬 방법 1 큐키 2021.06.14 265
995 큐브리드 마이그레이션툴 사용시 질문입니다. 5 bjosbkjx 2019.01.28 265
994 auto_increment 추가 방법 문의 1 부패방지운영팀 2023.04.14 265
993 이중화 씨 락상태가 30분 정도 걸려있다가 재기동 하면 바로 안올라오나요? 3 coolkkm 2017.12.14 264
992 ERWIN에서 Reverse Engineer 사용중에 에러 발생 3 연습용 2021.09.15 264
991 데이터 복구 1 file 연습만이살길 2022.03.25 264
990 버전 문의드립니다 1 ka 2018.10.11 263
989 SELECT 전체 갯수에 대해 질문 드리겠습니다. 1 훈입니다. 2020.04.17 263
988 큐브리드 매니저에서 질의 실행계획 질문하겠습니다. 3 file 연습용 2021.10.01 262
987 파라미터 바인드 문제.. 2 오션나인 2021.06.04 262
986 Locale 확인방법 문의 2 bchlim 2020.07.20 262
985 PHP PDO Driver 설치가 안됩니다. 웨버 2020.08.27 261
984 JOIN (+)과 함수 에러 3 wewek3jk3 2019.07.24 260
983 실행계획 읽는 법 문의 드립니다. 1 file kikiki767 2022.07.01 260
982 큐브리드 마이그레이션중 에러 7 밍아 2022.03.03 260
981 아카이브 삭제 명령어 문의 드립니다. 1 Philip Park 2021.04.06 260
980 파이썬에서 튜토리얼대로 했는데 안됩니다. 2 이방원 2020.08.02 258
Board Pagination Prev 1 ... 146 147 148 149 150 151 152 153 154 155 ... 200 Next
/ 200

Contact Cubrid

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