Background Image

FORUM

2019.05.23 10:09

뷰테이블 select 오류

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

단축키

Prev이전 문서

Next다음 문서

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

* 질문 등록 시 다음의 내용을 꼭 기입하여 주세요.
OS
Window10
CUBRID Ver.
8.4.4.10001
CUBRID TOOL Ver.
10.1.0003
응용 환경(API)
java

* CUBRID 응용 오류, SQL 오류 또는 SQL 튜닝 관련된 문의는 반드시 다음의 내용을 추가해 주세요. 비밀글이나 비밀 댓글도 가능합니다.
* 저희가 상황을 이해하고, 재현이 가능해야 알 수 있는 문제들이 많습니다. 가능한 정보/정황들을 부탁합니다.
에러 내용 및 재현 방법 재현 가능한 Source와 SQL
관련 테이블(인덱스, 키정보 포함) 정보 CUBRID 홈 디렉토리 아래 log 디렉토리 압축

-------------- 아래에 질문 사항을 기입해 주세요. ------------------------------------------------------------------------
CREATE OR REPLACE VIEW jnitmenu_vt(
menu_seq integer default 0,
site_nm character varying(50),
menu_depth1 character varying(50),
menu_depth2 character varying(50),
menu_depth3 character varying(50),
menu_depth4 character varying(50),
menu_depth5 character varying(50),
menu_depth6 character varying(50),
menu_depth7 character varying(50),
menu_url character varying(1),
menu_dept character varying(100),
menu_part character varying(200),
menu_tel character varying(20),
menu_memid character varying(20),
[method] character varying(1))
    AS 
select [b].[MENU_SEQ], [a].[SITE_NM], [a].[MENU_DEPTH1], [a].[MENU_DEPTH2], [a].[MENU_DEPTH3], [a].[MENU_DEPTH4], [a].[MENU_DEPTH5], [a].[MENU_DEPTH6],
 [a].[MENU_DEPTH7], [a].[MENU_URL], [b].[MENU_DEPT], [b].[MENU_PART], [b].[MENU_TEL], [b].[MENU_MEMID], [a].[METHOD] 
 from [jnitcmsmenu_vt] [a] left outer join [jnitmenu] [b] on ( cast([b].[MENU_URL] as varchar(255) )=[a].[MENU_URL])
  where (([a].[ISCNT]= cast(1 as varchar )) and ([a].[ISDEL]= cast(0 as varchar ))) 
  order by [a].[SITE_ID], 15, [a].[DEPTH];

위 쿼리로 view 테이블을 생성하였습니다.

jnitcmsmenu_vt 는 또다른 view 테이블이고
jnitmenu 는 실제 테이블입니다.

상단에 select 문만 실행해보면

select [b].[MENU_SEQ], [a].[SITE_NM], [a].[MENU_DEPTH1], [a].[MENU_DEPTH2], [a].[MENU_DEPTH3], [a].[MENU_DEPTH4], [a].[MENU_DEPTH5], [a].[MENU_DEPTH6],
 [a].[MENU_DEPTH7], [a].[MENU_URL], [b].[MENU_DEPT], [b].[MENU_PART], [b].[MENU_TEL], [b].[MENU_MEMID], [a].[METHOD] 
 from [jnitcmsmenu_vt] [a] left outer join [jnitmenu] [b] on ( cast([b].[MENU_URL] as varchar(255) )=[a].[MENU_URL])
  where (([a].[ISCNT]= cast(1 as varchar )) and ([a].[ISDEL]= cast(0 as varchar ))) 
  order by [a].[SITE_ID], 15, [a].[DEPTH];

MENU_SEQ SITE_NM MENU_DEPTH1 MENU_DEPTH2 MENU_DEPTH3 MENU_DEPTH4 MENU_DEPTH5 MENU_DEPTH6 MENU_DEPTH7 MENU_URL MENU_DEPT MENU_PART MENU_TEL MENU_MEMID METHOD
NULL 북방경제협력위원회 include header NULL NULL NULL NULL NULL / NULL NULL NULL NULL 0
NULL 북방경제협력위원회 include sidebar NULL NULL NULL NULL NULL / NULL NULL NULL NULL 0
NULL 북방경제협력위원회 include footer NULL NULL NULL NULL NULL / NULL NULL NULL NULL 0
NULL 북방경제협력위원회 소개・홍보 위원장 인사말 NULL NULL NULL NULL NULL / NULL NULL NULL NULL 0
NULL 북방경제협력위원회 소개・홍보 위원회의 역할 NULL NULL NULL NULL NULL / NULL NULL NULL NULL 0


이런식으로 제대로 결과는 나옵니다.


크리에이트 문의 경우에도 

1번째 질의 CREATE 작업 완료. [0.017 초]

메시지가 뜨면서 view 테이블이 제대로 만들어졌다는 표시가 나옵니다. 

그런데 

SELECT COUNT(*) totcnt    FROM JNITMENU_VT    WHERE 1=1       

쿼리를 실행해보면 

실행 오류 : -494

Semantic: There are more columns in the query specification than attributes in class jnitmenu_vt. select count(*) from JNITMENU_VT JNITMENU_VT where (1=1)

이런 메시지가 뜨면서 select 가 되지 않고 있습니다.

이런 현상을 어떻게 해결해야 하나요?


  • ?
    권호일 2019.05.23 14:36
    뷰테이블을 사용하지 말고 원본테이블을 사용해서 해보시기 바랍니다.

    예시)
    SELECT count(*)
    from (
    select [b].[MENU_SEQ], [a].[SITE_NM], [a].[MENU_DEPTH1], [a].[MENU_DEPTH2], [a].[MENU_DEPTH3], [a].[MENU_DEPTH4], [a].[MENU_DEPTH5], [a].[MENU_DEPTH6],
    [a].[MENU_DEPTH7], [a].[MENU_URL], [b].[MENU_DEPT], [b].[MENU_PART], [b].[MENU_TEL], [b].[MENU_MEMID], [a].[METHOD]
    from [jnitcmsmenu_vt] [a] left outer join [jnitmenu] [b] on ( cast([b].[MENU_URL] as varchar(255) )=[a].[MENU_URL])
    where (([a].[ISCNT]= cast(1 as varchar )) and ([a].[ISDEL]= cast(0 as varchar )))
    order by [a].[SITE_ID], 15, [a].[DEPTH] ) T1
    where 1 = 1
  • ?
    한넷개발자 2019.05.23 15:10
    원본테이블을 사용해서는 제대로 된 결과가 나오고 있습니다.
    그런데 반드시 뷰테이블을 사용해야만 하는 경우라서요
    뷰테이블에 접근이 불가능 하니 미치겠습니다.
  • ?
    허서진 2019.05.23 15:37
    안녕하세요. 큐브리드를 이용해주셔서 감사합니다.
    현재 발생하는 이슈는 A테이블에 대한 order by 구문 수행 시 select list에 없는 컬럼에 대해 order by 명령이 수행되면서 해당 컬럼을 찾을 수 없다는 메시지가 발생하는 것으로 보입니다.
    해당 컬럼을 select list에 추가해 주시거나, 인라인 뷰로 한번 묶은 뒤 추려내는 방식으로 수정하시면 정상적으로 사용하실 수 있을 것으로 생각됩니다.
    가능 하시다면 아래와 같이 수행해 보시는 것을 권장드립니다.

    CREATE OR REPLACE VIEW jnitmenu_vt(
    menu_seq integer default 0,
    site_nm character varying(50),
    menu_depth1 character varying(50),
    menu_depth2 character varying(50),
    menu_depth3 character varying(50),
    menu_depth4 character varying(50),
    menu_depth5 character varying(50),
    menu_depth6 character varying(50),
    menu_depth7 character varying(50),
    menu_url character varying(1),
    menu_dept character varying(100),
    menu_part character varying(200),
    menu_tel character varying(20),
    menu_memid character varying(20),
    [method] character varying(1),
    site_id int,
    [depth] varchar)
    AS
    select[b].[MENU_SEQ], [a].[SITE_NM], [a].[MENU_DEPTH1], [a].[MENU_DEPTH2], [a].[MENU_DEPTH3], [a].[MENU_DEPTH4], [a].[MENU_DEPTH5], [a].[MENU_DEPTH6],
    [a].[MENU_DEPTH7], [a].[MENU_URL], [b].[MENU_DEPT], [b].[MENU_PART], [b].[MENU_TEL], [b].[MENU_MEMID], [a].[METHOD] , [a].[SITE_ID], [a].[DEPTH]
    from [jnitcmsmenu_vt] [a] left outer join [jnitmenu] [b] on ( cast([b].[MENU_URL] as varchar(255) )=[a].[MENU_URL])
    where (([a].[ISCNT]= cast(1 as varchar )) and ([a].[ISDEL]= cast(0 as varchar )))
    order by [a].[SITE_ID], 15, [a].[DEPTH];

List of Articles
번호 제목 글쓴이 날짜 조회 수
공지 SQLGate for CUBRID 영구 무료 라이선스 제공 file admin 2020.04.09 4443
3907 cubrid 9.3.1 설치해서 원격으로 접속하고자 설치했는데 에러가 뜹니다 3 file Xstar 2023.10.27 97
3906 loaddb 실행 중 발생하는 오류에 대해서 문의 드립니다. 1 file 뚜벅뚜벅 2023.10.19 102
3905 큐브리드 매니서 실행 문의 1 마리오 2023.10.19 96
3904 큐브리드 DB가 실행되지 않는 것 같습니다. 4 file 뚜벅뚜벅 2023.10.18 123
3903 ===<ResultofSELECTCommandinLine1>=== 등의 출력 없이 결과값만 반환받고 싶습니다. 3 f0081 2023.10.18 93
3902 가로 데이터 세로로 조회 6 Ggyak 2023.10.18 120
3901 테이블별 row 개수를 조회하는 쿼리 6 cncn 2023.10.18 110
3900 [ADO.NET] Syntax error: unexpected 6 tree1891 2023.10.17 152
3899 큐브리드매니저 패스워드 변경 문의건 1 file yurrrr 2023.10.16 102
3898 Db프로시져 스케쥴 실행 성공 리포트나 로그 결과른 보고싶습니다 2 Roy 2023.10.16 105
3897 db 데이터용량을 조회하는 쿼리 2 cncn 2023.10.11 116
3896 특정 값 우선 정렬 3 drunkenascii 2023.10.11 66
3895 이기종간 DB Link 문의 드립니다. 6 kikiki767 2023.09.26 102
3894 jdbc 오류 1 file 대청댐 2023.09.22 104
3893 javasp start fail이 발생합니다. 1 유수부쟁선 2023.09.22 62
3892 자연조인문제 1 dfahwh 2023.09.17 71
3891 killtran 관련하여 문의 드립니다. 1 후루숑 2023.09.06 143
3890 Cubrid 물리명 길이 제한 값이 어떻게되나요? 3 엘L 2023.09.05 109
3889 쿼리속도문제 3 Ggyak 2023.09.01 160
3888 dbtimezone 1 sj.han 2023.08.30 93
Board Pagination Prev 1 2 3 4 5 6 7 8 9 10 ... 200 Next
/ 200

Contact Cubrid

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