* 질문 등록 시 다음의 내용을 꼭 기입하여 주세요.
|
Window7 32bit, Linux 64bit 등 |
|
[cubrid_rel] 수행 결과 |
|
[도움말]-[버전정보] 확인 |
|
java, php, odbc 등 입력 |
* CUBRID 응용 오류, SQL 오류 또는 SQL 튜닝 관련된 문의는 반드시 다음의 내용을 추가해 주세요. 비밀글이나 비밀 댓글도 가능합니다.
* 저희가 상황을 이해하고, 재현이 가능해야 알 수 있는 문제들이 많습니다. 가능한 정보/정황들을 부탁합니다.
에러 내용 및 재현 방법 | 재현 가능한 Source와 SQL |
관련 테이블(인덱스, 키정보 포함) 정보 | CUBRID 홈 디렉토리 아래 log 디렉토리 압축 |
-------------- 아래에 질문 사항을 기입해 주세요. ------------------------------------------------------------------------
DB_ATTRIBUTE 테이블에서 컬럼정보를 조회하는데
추가로 해당 테이블의 row 수도 필요합니다.
검색해보니 select count(*) 밖에 사용을 못하는 것 같은데
저는 WHERE CLASS_NAME in 으로 여러개의 테이블을 한번에 조회해야해서
select count(*) from ${tableName} 이런식으로 변수를 사용하지 못합니다..
다른 방법이 없을까요?
ex)
SELECT CLASS_NAME, DEF_ORDER, COMMENT FROM DB_ATTRIBUTE WHERE CLASS_NAME in ('a', 'b')
여기에 추가로 각 테이블 a, b의 row 수도 조회해야함
a, b와 같은 CLASS_NAME 목록은 달라짐
db_attribute인 시스템테이블은 데이터베이스 내에서 현재 사용자가 접근 권한을 가진 클래스에 대해 그 속성 정보를 담고 있습니다.
rows의 경우 db_class 시스템테이블을 참조 하시면 되고, 두 테이블의 정보는 join으로 가져오셔서 사용하시면 됩니다.
하단의 간단 예제를 올리니 참조해 조합해 보세요
SELECT
c.class_name,
COUNT(*) AS count_column
FROM db_class c JOIN db_attribute a ON a.class_name = c.class_name AND a.from_class_name IS NULL
WHERE
c.is_system_class = 'NO'
AND c.class_type = 'CLASS'
AND c.class_name <> '_cub_schema_comments'
GROUP BY
c.class_name
감사합니다.