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
번호 분류 제목 글쓴이 날짜 조회 수
16 응용개발 PHP에서 prepared statement 사용하기 3 Prototype 2009.04.16 21454
15 응용개발 응용프로그램에서 질의 처리시 commit/rollback 처리 문제 admin 2008.11.21 21600
14 응용개발 CUBRID에서 euc-kr의 한글 데이터를 utf-8의 한글 데이터로 변경 시 주의할 점 cubebridge 2010.04.01 22406
13 응용개발 윈도우 환경에서 PHP 모듈 로드를 못 할 경우 해결법 3 Prototype 2009.11.26 22487
12 응용개발 CUBRID 에서 제공하는 ODBC 함수 목록 admin 2008.11.21 26052
11 응용개발 loadjava 사용 시 inner class 로딩은 어떻게? admin 2008.11.21 27450
10 응용개발 Attempt to access a closed ResultSet(PreparedStatement) 오류 admin 2008.11.21 28035
9 응용개발 CUBRID에서 systimestamp, sysdatetime default값에 대한 정의 cubebridge 2009.12.16 28265
8 응용개발 tomcat 5.5 버전 이상에서 dbcp(커넥션 풀링) 설정법 admin 2008.11.21 28527
7 응용개발 CUBRID와 Oracle에서의 ''(공백)의 차이 비교 cubebridge 2010.10.01 28584
6 응용개발 php에서 serialize/unserialize 사용 시 주의할 점 시난 2009.12.29 31628
5 응용개발 CUBRID AUTO_INCREMENT 컬럼 MySQL LAST_INSERT_ID() 대체 방법 손승일 2009.12.22 33235
4 응용개발 JDBC 사용시 SQL 로깅 - p6spy 사용 1 웁쓰 2009.07.01 36002
3 응용개발 Weblogic 10.0 사용시 JDK 1.5를 사용한 JDBC 드라이버 사용시 주의사항. cubebridge 2012.02.22 51957
2 응용개발 WHERE 조건에서 다중 컬럼 IN절 처리 최적화 방법 (cubrid + ibatis) 1 이상신 2015.08.21 55137
1 응용개발 weblogic 8.1 에 CUBRID Connection Pool, DataSource 설정 방법 file 웁쓰 2009.07.01 66306
Board Pagination Prev 1 2 3 Next
/ 3

Contact Cubrid

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