Background Image

FORUM

조회 수 11498 추천 수 0 댓글 3
?

단축키

Prev이전 문서

Next다음 문서

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

학생정보와, 시험정보가 있습니다.

그리고 각 학생들이

가장 잘한 시험의 날짜 및 점수,
가장 못한 시험의 날짜 및 점수

이렇게 뽑으려고 합니다.

create class people(
    name varchar(20),
    age short
);

create class exam(
    whois people,
    whenis date,
    point float
);

insert into people values('김', 12) into p1;
insert into people values('이', 13) into p2;
insert into people values('박', 14) into p3;
insert into people values('홍', 15) into p4;

insert into exam values(p1, date'1/2/2009', 60);
insert into exam values(p1, date'1/4/2009', 70);
insert into exam values(p1, date'1/6/2009', 75);
insert into exam values(p2, date'1/7/2009', 80);
insert into exam values(p2, date'1/8/2009', 76);
insert into exam values(p3, date'1/9/2009', 99);

select name, age, exam_good.whenis, exam_good.point, exam_bad.whenis, exam_bad.point from (
select name, age,
(select exam from exam where whois = people order by point desc for orderby_num() = 1) exam_good,
(select exam from exam where whois = people order by point for orderby_num() = 1) exam_bad
 from people
 ) A;

제가 원하는 결과는 다음과 같습니다.

김   12   1/6/2009   75   1/2/2009   60
이   13   1/7/2009   80   1/8/2009   76
박   14   1/9/2009   99   1/9/2009   99
홍   15     NULL    NULL    NULL    NULL

하지만 해보면 다음과 같이 나옵니다.

김   12   1/6/2009   75     NULL    NULL
이   13   1/7/2009   80     NULL    NULL
박   14   1/9/2009   99     NULL    NULL
홍   15     NULL    NULL    NULL    NULL

전 제가 뭔가 잘못한 줄 알았는데, 아무래도 이건 버그 같습니다.

select name, (select exam from exam where whois = people order by point desc for orderby_num() = 1)  from people;
이건 됩니다.

select (select exam from exam where whois = people order by point desc for orderby_num() = 1), name  from people;
이건 안됩니다.

순서를 바꿨다고안되는건 무슨상황인가요

  • ?
    말씀하신 내용에 대해서 추가적으로 살펴보고 있습니다. 
    확인 내용이 나오면 추가적인 답변을 드리도록 하겠습니다.
    현재 원하시는 결과를 도출하기 위해서는  Primary key, foreign key를 이용하여 테이블을 생성하여 쿼리를 만드시기를 권장합니다. PK. FK를 이용하여 생성한 후 원하는 결과를 위한 쿼리 예제를 첨부합니다. 
  • ?
    admin 2009.03.10 18:25
    해당문제는 CUBRID2008 최신버젼에서 패치되어있읍니다.
    특별한 문제가 없으시다면 최신버젼으로의 업그레이드를 권장합니다. 아울로 7.3관련 질문은 홈페이지 첫화면 우측하단의 7.3이하 게시판 이용을 부탁드립니다.
  • ?
    서경식 2009.03.11 00:33
    subquery가 (select a from ... order by b) 와 같이 order by에 hidden column(select 절에 나타나지 않는 칼럼)이 있으면,
    내부적으로 (select a, b from ... order by 2) 로 바꾸어서 수행하게 됩니다.
    문제는 이런 패턴의 subquery가 from 절이 아니고 select 절에 나타나는 경우입니다.
    select 절에 쓸 수 있는 subquery는 1-column만 가져야 하는데, 2 개 이상의 칼럼을 가지는 subquery가 되기 때문에 내부적으로 결과가 틀려지게 됩니다. 
    우회안은, 문제의 subquery 를 derived로 한 번 싸면 됩니다. 

    csql> ;list

       1  select    name, age,
       2    exam_good.whenis, exam_good.point,
       3    exam_bad.whenis, exam_bad.point
       4  from (
       5    select name, age,
       6            ( select exam
       7              from (
       8                    select exam, point
       9                    from exam
      10                    where whois = people
      11                    order by 2 desc for orderby_num() = 1
      12                         ) good(exam, point)
      13            ) exam_good,
      14            (
      15                    select exam
      16                    from (
      17                    select exam, point
      18                    from exam
      19                    where whois = people
      20                    order by 2 for orderby_num() = 1
      21                   ) bad(exam, point)
      22            ) exam_bad
      23    from people
      24   ) A;

      name                     age  exam_good.whenis  exam_good.point  exam_bad.whenis  exam_bad.point
    ==================================================================================================
      '김'                      12  01/06/2009           7.500000e+01  01/02/2009         6.000000e+01
      '이'                      13  01/07/2009           8.000000e+01  01/08/2009         7.600000e+01
      '박'                      14  01/09/2009           9.900000e+01  01/09/2009         9.900000e+01
      '홍'                      15  NULL                         NULL  NULL                       NULL

    이 버그는 예전부터 확인한 사항입니다만, 우회안이 있는 상황이고, 그 발생 빈도에 비해 해결 비용이 크다고 생각되어 해결의 우선 순위가 높지 않다고 분류된 이슈입니다.



List of Articles
번호 제목 글쓴이 날짜 조회 수
공지 CUBRID 사용자를 위한 DBeaver 도구 출시 안내 admin 2024.04.23 48
공지 SQLGate for CUBRID 영구 무료 라이선스 제공 file admin 2020.04.09 4458
1074 Hibernate로 페이징 처리시 오류발생에 대한 내용입니다. 4 백화요란 2011.09.16 12913
1073 select count 한 개수와 select 한 개수가 다른이유는 뭘까요? 4 file 인경수 2011.09.16 11912
1072 계층적질의 결과물과 조인 시 문제점 2 하루야 2011.09.09 9489
1071 ROW_NUMBER() OVER(PARTITION BY 어떻게..해야 할까요??? 5 초식곰 2011.09.09 26459
1070 Oracle의 stored function/procedure에 대한 질문입니다. 2 배나온천사 2011.09.06 10032
1069 호스트 연결이 안되요.(비밀번호오류) 2 양희종 2011.09.06 13919
1068 큐브리드를 시작할수없습니다. 2 SoMa 2011.09.04 9383
1067 제품소개 FAQ를 읽고 질문 드립니다 1 유니콘 2011.09.02 8102
1066 delete join 2 비형여자 2011.08.31 12845
1065 [초보질문] databases.txt 에 접근할수 없다는 에러메시지가 나옵니다.. 4 file 몰라몰라 2011.08.29 10845
1064 [초보질문] 쿼리편집기에 대한 질문입니다. 2 몰라몰라 2011.08.28 10002
1063 Cubrid 설치시 에러 2 file reerror 2011.08.27 8739
1062 언로드 후, 로드가 안되는데 어떤 사항을 체크해 봐야 할까요? 2 secret 차오이 2011.08.23 18
1061 오라클 rank() over를 대체 할 수 있는 함수가 있나요? 1 쿠쿡 2011.08.16 23280
1060 큐브리드 질의 편집기에서 쿼리 관련 문의 입니다. 1 유리심장 2011.08.12 8889
1059 [질문] Insert문의 속도 향상 방법이 있나요? 3 ........ 2011.08.10 25231
1058 테이블 우측마우스 메뉴 "데이터 올리기"를 명령어로 하는 방법은?? 1 풀소리 2011.08.09 8532
1057 큐브리드 R4.0 에서 between 사용시 문제가 발생합니다. 1 종이 2011.08.07 9248
1056 XE를 mysql에서 cubrid로 이전한 후 속도가 너무 느립니다. 22 엔하늘 2011.08.07 28568
1055 우분투 11.04에 큐브리드 설정 관련 질분 드립니다. 2 지눙이 2011.08.07 8860
Board Pagination Prev 1 ... 142 143 144 145 146 147 148 149 150 151 ... 200 Next
/ 200

Contact Cubrid

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