Background Image

FORUM

조회 수 12201 추천 수 0 댓글 5
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄
SELECT * , (

SELECT sum( po_point )
FROM point AS a
WHERE a.mb_id = b.mb_id
AND INSTR( po_rel_expert, '수학' )
) AS ex_point
FROM board_write AS b
ORDER BY ex_point DESC 

 목적은 a 테이블인 point 테이블과 b 테이블인 board  테이블에서 mb_id 값이 일치하는 point 테이블의 po_point 값을 구하려고 합니다.어떻게 해야하죠?
  • ?
    남재우 2010.03.16 02:49
    select 절에 * 와 다른 필드를 쓸때는 * 에 대하여 qualified name 을 붙여 주셔야 합니다. 즉, from 절에서 board_write 테이블에 대하여 b로 qualified name 을 부여하였으므로 select b.*, 와 같이 사용하면 됩니다.
  • ?
    초보 2010.03.16 20:10
    그렇게 하여도 다음과 같은 오류가 납니다.
    Semantic: ' and ' operator is not defined on types logical and integer

    어떻게 하죠? 포인트테이블 스키마는 다음과 같습니다.
    CREATE TABLE "point"(
    "mb_id" character varying(20) NOT NULL,
    "po_time" timestamp NOT NULL,
    "po_content" character varying(510) NOT NULL,
    "po_point" numeric(10,0) DEFAULT 0 NOT NULL,
    "po_rel_board" numeric(10,0) DEFAULT 0,
    "po_rel_table" character varying(50),
    "po_rel_id" character varying(20),
    "po_rel_action" character varying(510),
    "po_rel_expert" character varying(510),
    "po_id" numeric(20,0) AUTO_INCREMENT PRIMARY KEY
    );
  • ?
    남재우 2010.03.16 21:09
    CUBRID에서는 where 절에 자동 형변환을 지원하지 않습니다. 에러를 보면 board_write 의 md_id가 integer인것으로 판단됩니다. 자동형변환이 사용에는 편리하겠지만 성능적으로는 어찌되었건 형변환을 해야 하므로 그만큼의 시간소요가 있습니다.
    두 테이블의 타입을 맞추거나 하나의 필드에 대하여 형변환을 해야 합니다.
    a.mb_id 는 검색 대상이니 b.mb_id 를 형변환하면 됩니다. cast(b.mb_id as varchar(20))
  • ?
    초보 2010.03.17 02:42
    둘다 varchar 형이고 자릿수만  각각 20, 40으로 틀립니다.

    오류 이유가 머죠??
  • ?
    남재우 2010.03.17 03:52
    AND INSTR( po_rel_expert, '수학' ) 가 작성할 때 오타라고 생각했는데 아닌 것 같습니다. 실제 질의가 이와 같다면 AND INSTR( po_rel_expert, '수학' ) = 1 와 같은 형태로 사용해야 합니다. CUBRID 에서는 반드시 a = b 형태로 사용해야 합니다.

List of Articles
번호 제목 글쓴이 날짜 조회 수
공지 CUBRID 사용자를 위한 DBeaver 도구 출시 안내 admin 2024.04.23 50
공지 SQLGate for CUBRID 영구 무료 라이선스 제공 file admin 2020.04.09 4458
754 PDO 지원이 가능한가요? 1 ihwan 2009.05.20 12045
753 cm_admin 으로 사용자를 추가해도 쿼리 브라우저에서 접속 불가합니다..도와주세요 1 asuraiv 2013.12.10 12047
752 window2000에서 사용하게 해주세요. 2 나상숙 2009.04.07 12051
751 데이타베이스 복구에 관한 질문. 1 김우람 2009.03.18 12051
750 modify 질문드립니다. 1 rikal 2016.08.03 12054
749 [긴급] 삭제되지 않는 테이블은 어떻게 처리해야하나요.. 4 스마트 2010.09.25 12056
748 This object is in a zombie state 인 경우 1 유겸아빠 2011.06.01 12070
747 server start시 error 발생 관련 3 flypig 2012.02.24 12075
746 왜 컬럼이름이 안붙나요...... 1 file 안지민 2009.03.06 12075
745 TIME 포맷 관련 질문 입니다. 1 이승훈 2009.03.19 12107
744 데이터베이스 하드차지하는 용량이 계속 늘어요 2 하나엘 2009.11.17 12108
743 큐브리드 재시작 후 처음 조회시 조회가 오래걸립니다. 4 종이 2010.04.24 12108
742 csql 로 demodb 접속 시 오류 입니다~! 1 하하보이 2011.06.29 12110
741 is null 조건 쿼리가 더 오래 걸리는 이유가 무엇인가요? 1 초보 2010.04.06 12118
740 큐브리드 매니저 Xe설치후 게시판관리하려면 1 Kai 2014.01.09 12124
739 오류코드 출력문의 3 뚜벅초 2016.06.17 12130
738 큐브리드와 powerDNS 연동 1 aliveJune 2009.09.04 12139
737 윈도우 -> 리눅스 큐브리드 원격접속 문제 1 박대서 2013.04.21 12157
736 Cubrid FUNCTION 한글 깨짐 문제 1 록밥 2017.02.24 12161
735 디비생성에러 5 file giyoung.kim 2011.10.12 12163
Board Pagination Prev 1 ... 158 159 160 161 162 163 164 165 166 167 ... 200 Next
/ 200

Contact Cubrid

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