Background Image
응용개발
2015.05.07 19:43

전체 레코드 개수 확인하는 SP

조회 수 14728 추천 수 0 댓글 0
?

단축키

Prev이전 문서

Next다음 문서

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

CUBRID Manager 및 CUBRID Query Browser에서는 DB 내에 있는 전체 레코드 개수를 한번에 확인하는 방법을 아직 지원하지 않습니다.

따라서 전체 레코드 개수를 한번에 확인할 수 있는 SP를 작성하여 제공합니다.

SP(Stored Procedure)와 관련된 자세한 정보는 메뉴얼을 참고하시기 바랍니다.


1. 아래의 소스코드대로 CountAll.java 파일을 작성합니다.

import java.sql.Connection;

import java.sql.DriverManager;

import java.sql.PreparedStatement;

import java.sql.ResultSet;

import java.util.ArrayList;

import java.util.List;



public class CountAll {

public static long countAll() {

long recordCount = 0;

StringBuffer sql = new StringBuffer();

sql.append("SELECT class_name FROM db_class WHERE is_system_class='NO'");

List<String> tableList = new ArrayList<String>();

try {

Class.forName("cubrid.jdbc.driver.CUBRIDDriver");

Connection conn = DriverManager.getConnection("jdbc:default:connection:");

PreparedStatement pstmt = conn.prepareStatement(sql.toString());

ResultSet rs = pstmt.executeQuery();

while(rs.next()) {

tableList.add(rs.getString(1));

}

for(String tableName : tableList) {

sql.setLength(0);

sql.append("SELECT COUNT(*) FROM [" + tableName + "]");

pstmt = conn.prepareStatement(sql.toString());

rs = pstmt.executeQuery();

if(rs.next()) recordCount += rs.getLong(1);

}

conn.commit();

} catch (Exception e) {

e.printStackTrace();

}

return recordCount;

}

}


① 먼저 db_class 테이블에서 class_name 컬럼의 데이터를 조회합니다. (테이블 이름 조회)

조회한 테이블 데이터들은 List 에 저장됩니다.

② SP의 connection은 서버측 JDBC 드라이버를 사용해야 하기 때문에 default 설정을 사용합니다.

③ List에 저장된 테이블 이름들을 통해 COUNT(*) 함수를 수행하여 레코드 개수를 합산한 뒤 리턴합니다.


2. CountAll.java 파일 컴파일 및 loadjava 수행

2-1. 컴파일 수행

[seunghun@newTest1 ~]$ javac -cp .:$CUBRID/jdbc/cubrid_jdbc.jar CountAll.java 

컴파일 수행시 CUBRID JDBC 드라이버가 포함되어야 하므로 -cp 옵션에 JDBC 드라이버 경로를 추가하여 수행합니다.


2-2. loadjava 수행

[seunghun@newTest1 ~]$ loadjava -y demodb CountAll.class 

loadjava [option] <DB_NAME> <CLASS_FILE> 순서로 명령어를 수행하며,

-y 옵션은 해당 클래스 파일이 등록되어 있더라도 덮어씌우는 옵션 입니다.


3. DB에서 SP 생성 방법

CSQL 혹은 CUBRID Manager, CUBRID Query Browser에서 DB에 접속한 후 다음 명령어를 수행합니다.

CREATE FUNCTION countall() RETURN BIGINT AS LANGUAGE JAVA NAME 'CountAll.countAll() RETURN LONG'; 


4. SP 수행

SELECT 혹은 CALL 을 사용하여 countall() SP를 호출합니다.

csql> select countall();


=== <Result of SELECT Command in Line 1> ===


            countall()

======================

                 30690



1 rows selected.

SQL statement execution time:     0.049740 sec


Current transaction has been committed.


1 command(s) successfully processed.

csql> 

csql> call countall();


=== <Result of CALL Command in Line 2> ===


                Result

======================

                 30690


SQL statement execution time:     0.019026 sec


Current transaction has been committed.


1 command(s) successfully processed.

csql> 



List of Articles
번호 분류 제목 글쓴이 날짜 조회 수
279 질의작성 한건의 데이타를 여러건으로 조회하는 쿼리입니다. 권호일 2012.03.30 9419
278 운영관리 한 호스트내의 DB경로 변경 방법 janus 2010.02.19 12268
277 CUBRID 매니저 한 개 PC에서 CUBRID7.3과 CUBRID2008R1.4 & R2.0 매니저 사용 방법 1 정만영 2009.12.12 13054
276 응용개발 패키지 형태로 생성된 JAVA class를 JAVA SP에서 사용하기 손승일 2010.02.26 18375
275 기타 테이블에 comment 사용하기 1 남재우 2010.01.01 21051
274 질의작성 테이블 컬럼 변경 및 추가 정만영 2016.02.29 21850
273 질의작성 테이블 용량 산정 쿼리 성진 2015.12.08 7398
272 운영관리 테이블 사용량 확인방법 정만영 2015.02.03 11453
271 CUBRID 매니저 테이블 명세서 한 시트로 합치기 file 성진 2015.12.24 16525
270 질의작성 테이블 명세서 쿼리 1 성진 2017.08.04 3180
269 질의작성 테이블 리스트 취합 SQL 김창휘 2016.03.19 5522
268 질의작성 테이블 데이터 복사 하기 정만영 2009.03.14 22301
267 마이그레이션 타 DBMS를 CUBRID로 마이그레이션 시 varchar,char 컬럼 사이즈 관련 손승일 2010.07.01 38024
266 마이그레이션 타 DB 에서 마이그레이션시 질의 변경 샘플 - CASE 문 웁쓰 2009.12.31 21924
265 운영관리 큐브리드와 hostname 관계 정만영 2009.06.25 18584
264 운영관리 큐브리드매니져를 이용한 데이터베이스 자동 백업 남재우 2009.04.01 19052
263 운영관리 큐브리드 포트 정리 정만영 2016.07.05 6093
262 운영관리 큐브리드 서비스 재구동 시 cubrid manager server start: fail 오류 해결 방법 진우진 2015.12.16 7734
261 운영관리 큐브리드 사용포트 정리 3 정만영 2009.06.19 29776
260 운영관리 큐브리드 복제 구성 시 마스터 데이터베이스 백업 주의사항 정만영 2010.02.11 12591
Board Pagination Prev 1 2 3 4 5 6 7 8 9 10 ... 14 Next
/ 14

Contact Cubrid

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