KR20030014011A - Method and system for automatic combining a different kind of database - Google Patents

Method and system for automatic combining a different kind of database Download PDF

Info

Publication number
KR20030014011A
KR20030014011A KR1020010048327A KR20010048327A KR20030014011A KR 20030014011 A KR20030014011 A KR 20030014011A KR 1020010048327 A KR1020010048327 A KR 1020010048327A KR 20010048327 A KR20010048327 A KR 20010048327A KR 20030014011 A KR20030014011 A KR 20030014011A
Authority
KR
South Korea
Prior art keywords
database
merging
heterogeneous
copying
data
Prior art date
Application number
KR1020010048327A
Other languages
Korean (ko)
Inventor
김종훈
민병준
김성기
Original Assignee
(주)프리즘엠아이텍
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by (주)프리즘엠아이텍 filed Critical (주)프리즘엠아이텍
Priority to KR1020010048327A priority Critical patent/KR20030014011A/en
Publication of KR20030014011A publication Critical patent/KR20030014011A/en

Links

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/20Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
    • G06F16/23Updating
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/20Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
    • G06F16/25Integrating or interfacing systems involving database management systems
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/20Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
    • G06F16/27Replication, distribution or synchronisation of data between databases or within a distributed database system; Distributed database system architectures therefor
    • G06F16/275Synchronous replication

Abstract

PURPOSE: A system for automatically merging different kind of databases and a method thereof are provided to shorten an analyzing process and automatically analyze/standardize/merge data by minimizing a setting item of a user and suggesting the optimum method such as data filtering, variable reduction, and merging to the user when data are loaded and extracted from a database among various databases in remote places. CONSTITUTION: A data merging program is executed(S2). An interface for connecting a remote database system is executed(S8). A URL, an ID, and a password of a targeted database are inputted(S10). The targeted database is connected(S12). A table list of the targeted database is output on a screen(S14). A table to be copied out of the output table list is selected(S18). A local database system, which is an object to be copied, is connected(S20). The selected table is copied from the targeted database to the local database(S22).

Description

이종의 데이터 베이스 자동 병합 시스템 및 그 방법{Method and system for automatic combining a different kind of database}Heterogeneous database automatic merging system and its method {Method and system for automatic combining a different kind of database}

본 발명은 데이터 베이스 병합 시스템 및 그 방법에 관한 것으로, 더욱 상세하게는, 사용자의 선택에 의해 원격지에 이격되어 있는 서로 다른 데이터 베이스들간의 테이블을 복사하고, 복사된 테이블의 유사 데이터를 일괄 정리하며, 원하는테이블을 자동으로 병합할 수 있도록 된 이종의 데이터 베이스 자동 병합 시스템 및 그 방법에 관한 것이다.The present invention relates to a database merging system and method thereof, and more particularly, to copy a table between different databases that are remotely separated by a user's selection, and to collectively arrange similar data of the copied table. The present invention relates to a heterogeneous database automatic merging system and a method for automatically merging desired tables.

기업 경영의 의사 결정과 마케팅 활동을 위해서 대상 고객의 프로파일 정보, 구매 및 마케팅 관련 정보를 축적하는 일은 매우 중요한 일이다. 대상 고객에 대한 정보(Target Record)를 제때에 업데이트하지 못하거나 정확성을 유지하지 못하면, 정보의 축적에 소요된 막대한 노력이 낭비가 될 뿐만 아니라, 향후 이 데이터를 마케팅에 활용하면서 잘못된 정보로 인한 막대한 손실이 발생하기 때문에 축적되는 데이터의 유지 관리의 중요성이 강조되고 있다.Accumulating profile information, purchasing and marketing information of target customers is very important for corporate management decision making and marketing activities. Failure to update target records on time or to maintain accuracy is not only a waste of information, but also a tremendous amount of misinformation while using this data for marketing in the future. Because of the loss, the importance of maintaining the accumulated data is emphasized.

이를 위해서 이질적인 데이터 베이스에 각각 축적되는 고객 데이터를 추출하여 하나의 데이터 베이스로 병합하고 표준화한 다음, 부정확하거나 중복된 데이터를 제거하고 기존의 축적된 고객 정보에 대한 최신 정보를 수시로 갱신할 수 있어야 한다.To this end, it is necessary to extract customer data accumulated in heterogeneous databases, merge and standardize them into one database, remove inaccurate or duplicate data, and update the latest information on existing accumulated customer information from time to time. .

도 1은 종래 기술에 따라 사용자가 상업적인 데이터 분석 제공자와 상호 동작하는 시스템을 도시한 도면이다.1 is a diagram illustrating a system in which a user interacts with a commercial data analysis provider in accordance with the prior art.

도시된 바와 같이, 사용자는 클라이언트 컴퓨터(2)를 이용하여 데이터 분석 시스템(8)과 동작하여 데이터를 얻고, 입수한 데이터에 대하여 소정의 댓가를 지불한다.As shown, the user uses the client computer 2 to operate with the data analysis system 8 to obtain data and pay a predetermined price for the data obtained.

데이터 분석 시스템은 데이터 분석 알고리즘(4)과 분석될 데이터 베이스(6)를 모두 보유한다. 클라이언트 컴퓨터(2)와 데이터 분석 시스템(8)은 사용자와 데이터 분석 제공자가 컴퓨터 통신망(인터넷 혹은 인트라넷)을 통해 상호 동작하는클라이언트-서버 시스템으로서 구현될 수 있다. 한편 데이터 분석 알고리즘(4)과 데이터 베이스(6)는 각기 상이한 주체에 의해 개발될 수도 있다.The data analysis system has both a data analysis algorithm 4 and a database 6 to be analyzed. The client computer 2 and the data analysis system 8 may be implemented as a client-server system in which a user and a data analysis provider interact with each other via a computer communication network (Internet or intranet). Meanwhile, the data analysis algorithm 4 and the database 6 may be developed by different subjects.

의사 결정에 이용될 유용한 정보를 도출하기 위하여 수행하는 기존의 데이터 분석은 통상적으로 다음과 같은 과정을 수반한다.Existing data analysis performed to derive useful information for decision making usually involves the following process.

첫째, 데이터 분석의 대상이 되는 로 데이터(Raw Data: 처리나 집계가 행해지기 전의 데이터)를 데이터베이스에서 추출하거나 텍스트(Text) 또는 액셀(Excel) 등의 형태로 저장된 화일을 분석 시스템에서 로딩하는 과정과, 둘째, 본격적인 데이터 분석에 앞서 데이터를 사전 정리하기 위하여 중복되는 데이터들을 하나로 통합하는 작업과 로 데이터들을 원하는 형식의 포맷으로 변환하는 과정, 세째, 데이터의 코드 값이 수치적으로 의미있는 값을 나타내도록 하기 위하여 각 데이터 코드값에 설명을 부기하는 과정, 네째, 데이터 형태 및 분석 목적에 적합한 알고리즘 을 선정하고 적용하는 과정, 다섯째, 시행된 분석 결과를 평가하고, 필요시 세부 기준을 변경하거나 타 알고리즘을 적용하여 데이터들을 재분석하는 과정, 여섯째, 분석 목적에 따른 최종 결과를 해석하고 리포팅하는 과정으로 이루어진다.First, the process of extracting raw data (data before processing or aggregation) that is the target of data analysis from a database or loading a file stored in the form of text or Excel from an analysis system Second, in order to pre-arrange data prior to full-scale data analysis, the process of integrating duplicate data into one and converting the data into a format of a desired format. Third, the code value of the data is numerically meaningful. (4) the process of adding explanations to each data code value for presentation, the process of selecting and applying algorithms appropriate for the data type and analysis purpose, and (5) evaluating the results of the analysis performed and changing or changing the detailed criteria as necessary. Reanalyze the data by applying the algorithm. Sixth, the final result according to the analysis purpose. It consists of interpreting and reporting.

통상적으로 마케팅 분야에서 사용되는 데이터 분석 방법에는 다음과 같은 것이 있다.Typically, data analysis methods used in the field of marketing include the following.

첫째는, 데이터의 집계 및 구성 비율을 산정하고, 측정값의 평균 및 표준 편차, 측정값의 범위를 산정하며, 데이터 항목간의 교차 집계를 행하거나 교차성의 유의성을 검정하는 빈도 / 교차 분석 / 기술 통계 분석이 있고,First, frequency / crosstabulation / descriptive statistics for estimating the aggregation and composition ratio of the data, calculating the mean and standard deviation of the measured values, the range of the measured values, performing cross-aggregation between data items, or testing the significance of the crossover. There is an analysis,

둘째는, 측정값간의 유사성 및 관련성을 검정하고, 상관계수 및 공분산을 이용하는 상관 분석,Second, the correlation analysis using the correlation coefficient and covariance

세째는, 측정값간의 종속 관계를 규정하는 한편 종속의 정도를 검정하고, 목적 변수에 영향력 있는 변수 선정 및 그 영향력의 정도를 검정하는 선형 회귀 분석(로지스틱 회귀 분석),Third, linear regression analysis (logic logistic regression), which defines the dependencies between the measures, tests the degree of dependence, selects influential variables for the objective variable, and tests the degree of its influence.

네째는, 범주 형태로 된 목적값을 판별하고, 목적값에 영향력 있는 변수를 선정하는 판별 분석,Fourth, discriminant analysis to determine the target value in the form of category, and select the variable influential to the target value,

다섯째는, 유사한 성격을 가진 데이터들을 군집으로 집단화하고, 군집 방식에 따라 비계층적 군집과 계층적 군집으로 분류하며, 이 분류를 고객 세분화, 유사 고객 파악 등에 활용하는 군집 분석,Fifth, grouping data with similar characteristics into clusters, classifying them into non-hierarchical clusters and hierarchical clusters according to the clustering method, and using this classification for cluster segmentation and similar customer identification.

여섯째는, 변수간 유사성이 높은 변수들을 하나로 묶고 유사성이 적은 변수는 배제하여 측정 변수의 수를 줄이는 기법으로, 주로 응답자의 중요도 평가, 만족도 평가 등에 회귀 분석과 함께 활용하는 요인 분석,Sixth, a method of reducing the number of measurement variables by combining variables with high similarity and excluding variables with low similarity, which is mainly used with regression analysis for importance evaluation and satisfaction evaluation of respondents,

일곱째는, 특정 사건이 동시에 일어날 확률이 얼마나 되는지 산정하는 기법으로서, 근거 확률, 신뢰 확률, 그래프적 확률 등을 산정하여 결과 해석에 사용하는 연관성 분석,Seventh, as a technique for calculating the probability of a certain event occurring at the same time, the correlation analysis used to calculate the evidence probability, the confidence probability, the graphical probability, etc.

여덟째는, 기계 학습 분야에서 발달된 오류를 통한 자기 학습 모형으로서, 매우 다양한 신경망 모형이 있으나 마케팅 분야에서는 주로 다층 인공 지각론과 원형 기준 함수 등이 사용되며, 비교적 자유롭고 예측력도 높아 고객 판별, 불량 고객 예측, 구매 가능성 파악 등에 주로 사용하는 신경망 분석이 있다.Eighth, the self-learning model through error developed in the field of machine learning, there are many different neural network models, but in the marketing field, multilayer artificial perception theory and circular reference function are used. There is a neural network analysis which is mainly used for forecasting and purchasing possibility.

데이터 분석, 특히 데이터 마이닝 툴(Data Mining Tool)이라는 이름으로 시장에 출시된 제품은 전 세계적으로 100 여개가 넘고 그 가격 또한 천차 만별이다. 이들 솔루션들은 종류마다 조금씩 다르지만 앞서 언급한 각종 통계 분석 기법을 대부분 탑재하고 있으며 매우 대규모의 데이터 집합도 처리할 수 있도록 설계되어 있는 것이 일반적이다.There are over 100 products on the market under the name of data analytics, especially the Data Mining Tool, and prices vary widely. These solutions vary slightly from one type to the other, but are equipped with most of the aforementioned statistical analysis techniques and are typically designed to handle very large data sets.

또한, 이들 데이터 마이닝 툴들은 데이터 베이스와의 연결이나 분석 결과 전달 기능, 필터링 및 데이터 변환 기능, 매크로 기능 등을 지원하며 자체 알고리즘이 지속적으로 업데이트 및 추가되는 등 데이터 분석의 편익을 제공해 주는 것에 초점을 두고 있다.In addition, these data mining tools support the ability to connect to databases, deliver analysis results, filter and data transformation functions, and macro functions, and provide the benefits of data analysis by continuously updating and adding their own algorithms. I put it.

그러나, 상기한 기존의 솔루션들은 많은 문제점들을 안고 있다. 첫째로, 데이터 분석 자체가 통계학에 기반을 두고 있으므로 통계학적인 배경이 없는 일반 마케터나 분석가가 접근하기에는 무리가 있어 데이터의 분석 및 해석에 전문가나 외부 컨설턴트의 도움이 절대적으로 필요하다. 다시 말해, 인터페이스적인 측면에서 사용자 가이드 등을 제공하지 않아 사전 지식 없이는 사용자가 데이터 상태 및 분석 과정 등을 진행하기가 곤란하다는 문제점이 있다.However, the existing solutions described above present many problems. First, since data analysis itself is based on statistics, it is difficult for general marketers or analysts without a statistical background to access, so the help of experts or external consultants is absolutely necessary to analyze and interpret the data. In other words, there is a problem in that it is difficult for the user to proceed with the data state and analysis process without prior knowledge since the user guide is not provided in terms of interface.

둘째로, 사용자 자신이 직접 분석 과정 및 분석 결과를 해석하여 자신의 문제에 적용하여야 하고, 사용자의 비즈니스 이슈와 그 이슈를 이해하는 데 적합한 분석 모형이나 알고리즘을 선정하기가 쉽지 않으며, 분석 모형 선정 및 최적화에 있어서 많은 시행착오가 필요하다는 것이다.Secondly, the user must interpret the analysis process and the results of the analysis and apply it to his own problems, and it is not easy to select an analysis model or algorithm suitable for understanding the user's business issues and the issues. It requires a lot of trial and error for optimization.

세째로, 종래의 데이터 마이닝 툴은 그 규모가 매우 방대하고 이에 따라 구입 비용만 억대에 달하는 고가이며, 데이터 마이닝 툴의 구매 가격 이외에도 컨설팅 비용을 추가로 지불해야 하고, 툴을 구축할 엔지니어와 컨설턴트가 투입되어 상당 기간동안 이들의 지원을 받아야 하는 문제점이 있었다.Third, conventional data mining tools are very large and therefore expensive, costing only billions of dollars. In addition to the purchase price of data mining tools, additional consulting costs are required, and engineers and consultants to build the tools There was a problem of being put in and receiving their support for a considerable period of time.

네째로, 데이터 베이스나 일반 데이터 파일과의 연결 및 데이터 로딩 과정이 번거롭고 세부 과정이 많아 컴퓨터에 대한 전문 지식이 없는 분석가가 이용하기에는 다소 곤란하다는 것과, 데이터 변환 및 표준화 과정이 사용자의 판단과 통찰력을 필요로 하는 복잡한 기능들을 조합하여 수행되어야 하므로 데이터 분석의 질을 보장해 주지 못한다는 문제점이 있다.Fourth, the process of connecting and loading the database or general data files and loading the data is cumbersome and difficult for analysts without computer expertise. The problem is that the quality of data analysis cannot be guaranteed because it must be performed in combination with the complex functions required.

본 발명은 상기한 문제점들을 해결하기 위해 안출된 것으로서, 원격지에 이격되어 있는 서로 다른 데이터 베이스들간에 있어서, 데이터 베이스로부터 데이터 로딩 및 추출 과정시 사용자의 설정 항목을 최소화하고, 사용자에게 데이터 필터링 및 변수 축소, 병합 등의 최적 방안을 제시하여 분석 수행 과정을 단축할 수 있으며, 자동으로 데이터를 분석, 정제, 표준화하고 정리하여 병합할 수 있도록 된 이종의 데이터 베이스 자동 병합 시스템 및 그 방법을 제공함에 목적이 있다.The present invention has been made to solve the above problems, between different databases that are remotely spaced, to minimize the user's setting items during the data loading and extraction process from the database, data filtering and variables to the user The purpose is to provide a heterogeneous database automatic merging system and method, which can shorten the analysis process by suggesting optimal measures such as reduction and merging, and to automatically analyze, cleanse, standardize, organize, and merge data. There is this.

본 발명의 목적에 의하면, 원격지의 데이터 베이스 시스템들과 인터넷을 통해 연결되고, 데이터 베이스 병합 프로그램을 통해 원격지의 데이터 베이스 시스템들간의 테이블 복사, 유사 데이터 표준화 처리 및 테이블 병합 등을 실행하는 사용자 컴퓨터를 구비하는 이종의 데이터 베이스 자동 병합 방법에 있어서, 원격 데이터 베이스 시스템 연결을 위한 인터페이스를 실행하는 단계, 원본이 되는 표적 데이터 베이스 시스템과 대상이 되는 지역 데이터 베이스 시스템에 연결하는 단계,상기 표적 데이터 베이스의 테이블을 지역 데이터 베이스로 복사하는 단계, 유사 데이터 표준화 처리를 위한 사용자 인터페이스를 실행하는 단계, 상기 복사된 지역 데이터 베이스의 테이블을 일괄 정리하여 유사 데이터 표준화를 처리하는 단계, 테이블 병합을 위한 사용자 인터페이스를 실행하는 단계, 상기 지역 데이터 베이스의 병합할 테이블과 필드를 선택하는 단계, 상기 선택한 테이블의 필드를 병합하여 신규 테이블로 생성하는 단계를 포함하는 것을 특징으로 하는 이종의 데이터 베이스 자동 병합 방법이 제공된다.According to an object of the present invention, a user computer connected to remote database systems via the Internet and executing a table copy, similar data standardization processing, and table merging between remote database systems through a database merging program is provided. A method for automatically merging heterogeneous databases, the method comprising: executing an interface for connecting a remote database system, connecting to a target database system as a source and a local database system as a target, of the target database Copying a table to a local database, executing a user interface for processing similar data standardization, processing the standardization of similar data by collectively arranging the tables of the copied local database, and using a table for merging tables. Executing a user interface, selecting a table and a field to be merged in the local database, and merging the fields of the selected table to create a new table. This is provided.

본 발명의 다른 목적에 의하면, 다양한 이종의 데이터 베이스 시스템들이 인터넷을 통해 상호 연결되어 있는 이종의 데이터 베이스 자동 병합 시스템에 있어서, 상기 이종의 데이터 베이스 자동 병합 시스템의 기반이 되는 하드웨어로서 제반 동작을 제어하는 플랫폼, 자바 언어에 기반을 두고 클래스를 이용하여 인터페이스를 실행하는 자바 가상 머신(Java Virtual Machine), 상기 다양한 이종 데이터 베이스 시스템에 연결하기 위한 다수의 자바 데이터 베이스 연결자(Java DataBase Connectivity) 드라이버, 이종의 데이터 베이스 자동 병합을 실행하기 위한 데이터 베이스 병합 프로그램, 데이터의 입력을 위한 입력수단, 데이터의 화면 출력을 위한 화면 출력수단, 상기 입력수단을 통해 입력된 데이터를 임시 저장하거나 송수신되는 데이터를 저장하기 위한 데이터 저장부, 상기 데이터 베이스 병합 프로그램에 의해 원격지의 데이터 베이스 시스템들로부터 복사하거나 정리된 데이터들을 병합하여 저장하는 로컬 데이터 베이스, 사용자의 요구에 의해서 만들어진 프로그램의 어플리케이션 인터페이스(API)를 포함하여 구성되고, 상기 플랫폼은 상기 이종의데이터 베이스 시스템에 연결하여 테이블을 복사하고, 복사된 테이블 내용을 유사 데이터 표준화 처리하며, 사용자가 선택한 테이블의 필드를 병합하여 신규 테이블로 생성하는 것을 제어하는 것을 특징으로 하는 이종의 데이터 베이스 자동 병합 시스템이 제공된다.According to another object of the present invention, in a heterogeneous database automatic merging system in which various heterogeneous database systems are interconnected through the Internet, the overall operation is controlled as hardware that is the basis of the heterogeneous database automatic merging system. Platform, based on the Java language, a Java Virtual Machine that executes interfaces using classes, a plurality of Java Database Connectivity drivers for connecting to the various heterogeneous database systems, and heterogeneous. A database merging program for automatically merging databases, input means for inputting data, screen output means for screen output of data, temporarily storing data input through the input means or storing data transmitted and received Data for A storage unit, a local database for merging and storing data copied or organized from remote database systems by the database merging program, and including an application interface (API) of a program created at the request of a user, The platform is connected to the heterogeneous database system to copy a table, standardizes the copied table contents, and controls the generation of a new table by merging the fields of the table selected by the user. A database automatic merging system is provided.

도 1은 사용자가 상업적인 데이터 분석 제공자와 상호 동작하는 종래 기술의 시스템을 도시한 도면,1 illustrates a prior art system in which a user interacts with a commercial data analysis provider;

도 2는 본 발명의 실시예에 따른 이종의 데이터 베이스 자동 병합 시스템을 설명하기 위한 블럭 구성도,2 is a block diagram illustrating a heterogeneous database automatic merging system according to an embodiment of the present invention;

도 3은 도 2의 사용자 컴퓨터(12)의 내부 구성을 개략적으로 나타낸 도면,3 is a view schematically showing the internal configuration of the user computer 12 of FIG.

도 4는 원격 데이터 베이스 시스템으로부터 테이블을 선택하여 복사하는 과정을 나타낸 순서도,4 is a flowchart illustrating a process of selecting and copying a table from a remote database system;

도 5는 데이터 베이스 병합 프로그램 실행시 제공되는 첫 화면을 나타낸 도면,5 is a view showing the first screen provided when the database merge program is executed;

도 6은 원격 데이터 베이스 시스템 연결을 위한 인터페이스와 로그인 화면을 나타낸 도면,6 is a view showing an interface and a login screen for connecting to a remote database system;

도 7은 데이터 베이스 연결을 위한 사용자 인터페이스의 프로그램 코드를 나타낸 도면,7 illustrates program codes of a user interface for connecting a database;

도 8은 원격 데이터 베이스 내의 테이블 내용을 나타낸 화면,8 is a screen showing the contents of a table in a remote database;

도 9는 데이터 베이스 복사를 위한 사용자 인터페이스의 프로그램 코드를 나타낸 도면,9 illustrates program code of a user interface for copying a database;

도 10은 테이블 복사를 위한 메타 데이터 처리 클래스의 프로그램 코드를 나타낸 도면,10 is a diagram showing a program code of a meta data processing class for copying a table;

도 11은 테이블 복사시 생성되는 신규 테이블의 필드 타입 처리 클래스의 프로그램 코드를 나타낸 도면,11 is a diagram showing a program code of a field type processing class of a new table generated when a table is copied;

도 12는 테이블 복사를 위한 클래스의 프로그램 코드와 다이어그램을 나타낸 도면,12 is a diagram showing a program code and a diagram of a class for copying a table;

도 13은 지역 데이터 베이스로의 로그인과 테이블 복사를 나타낸 화면,13 is a screen showing login to a local database and a table copy;

도 14는 유사 데이터 표준화 처리를 나타낸 순서도,14 is a flowchart showing similar data normalization processing;

도 15는 선택한 테이블의 내용을 보여주는 화면 출력을 나타낸 도면,15 is a view showing a screen output showing the contents of the selected table;

도 16은 유사 데이터 표준화 처리를 위한 사용자 인터페이스의 프로그램 코드를 나타낸 도면,16 is a diagram showing a program code of a user interface for similar data normalization processing;

도 17은 표준화 처리를 위한 데이터를 입력하는 화면을 나타낸 도면,17 is a diagram showing a screen for inputting data for standardization processing;

도 18은 유사 데이터의 표준화 처리를 위한 클래스의 프로그램 코드와 다이어그램을 나타낸 도면,18 is a diagram showing a program code and a diagram of a class for standardizing similar data;

도 19는 유사 데이터 표준화 처리 후 일괄 정리된 테이블의 내용을 보여주는 화면을 나타낸 도면,19 is a diagram showing a screen showing the contents of a table arranged collectively after similar data normalization processing;

도 20은 병합할 테이블 선택을 위한 인터페이스 화면을 나타낸 도면,20 is a view showing an interface screen for selecting a table to merge;

도 21은 병합되는 테이블의 이름과 프라이머리키를 입력하는 화면을 나타낸 도면,21 is a view showing a screen for inputting a name and primary key of a table to be merged;

도 22는 테이블 병합을 위한 사용자 인터페이스의 프로그램 코드를 나타낸 화면,22 is a screen illustrating program code of a user interface for merging a table;

도 23은 테이블 병합 처리 클래스의 프로그램 코드와 다이어그램을 나타낸 도면,23 is a diagram showing a program code and a diagram of a table merge processing class;

도 24는 테이블의 병합된 결과를 보여주는 화면을 나타낸 도면이다.24 is a diagram illustrating a screen showing merged results of a table.

♣ 도면의 주요부분에 대한 부호의 설명 ♣♣ Explanation of symbols for main part of drawing ♣

2 : 클라이언트4 : 데이터 분석 알고리즘2: client 4: data analysis algorithm

6 : 데이터 베이스8 : 데이터 분석 제공자6: database 8: data analysis provider

10 : 인터넷12 : 사용자 컴퓨터10 Internet 12 User Computer

14 : 오라클 데이터 베이스16 : SQL 서버14: Oracle Database 16: SQL Server

18 : 인포믹스 데이터 베이스122 : 자바 가상 머신18: Informix database 122: Java virtual machine

124 ~ 128 : JDBC 드라이버130 : API124 ~ 128: JDBC driver 130: API

132 : 플랫폼134 : 데이터 베이스 병합 프로그램132 platform: a database merge program

135 : 데이터 저장부136 : 로컬 데이터 베이스135: data storage unit 136: local database

이하, 첨부된 도면을 참조하여 본 발명에 따른 실시예를 상세하게 설명한다.Hereinafter, exemplary embodiments of the present invention will be described in detail with reference to the accompanying drawings.

도 2는 본 발명의 실시예에 따른 이종의 데이터 베이스 자동 병합 시스템을 설명하기 위한 블럭 구성도이다.2 is a block diagram illustrating a heterogeneous database automatic merging system according to an exemplary embodiment of the present invention.

본 발명에서는 사용자가 사용하는 플랫폼의 종류와 무관하게 동작할 수 있는 융통성을 제공하기 위해 자바 가상 머신(Java Virtual Machine)을 실행 기반으로 채택하였다. 또한, 데이터 베이스 관리 시스템(DBMS: Data Base Management System, 이하 DBMS라 칭함)간의 이종성을 극복하기 위해 자바 언어에 기반을 둔 자바 데이터 베이스 연결자(JDBC: Java Data Base Connectivity, 이하 JDBC라 칭함) 기술을 사용하였다.In the present invention, in order to provide flexibility that can operate regardless of the type of platform used by the user, a Java virtual machine is adopted as an execution basis. In addition, to overcome the heterogeneity between the Database Management System (DBMS), a Java Database Connector (JDBC) technology based on the Java language is used. Used.

도 2에 도시된 바와 같이, 본 발명에 따른 이종의 데이터 베이스 자동 병합 시스템은, 원격지에 흩어져 있는 컴퓨터들이 통신을 통해 데이터를 송수신하기 위한 네트워크인 인터넷(10)에 사용자 컴퓨터(12)를 포함한 다수의 이종의 데이터 베이스 시스템들(14 ~ 18)이 연결되어 있고, 사용자 컴퓨터(12)에서 URL(Uniform Resource Locator)과 사용자 로그인 계정 정보를 입력하여 인터넷(10)상에 분산된 여러 종류의 DBMS를 손쉽게 연결해서, 각 데이터 베이스 시스템의 테이블 내의 데이터를 각 필드 단위로 정렬(Sorting)하고 유사 데이터의 일괄 표준화를 수행한다.As shown in FIG. 2, the heterogeneous database automatic merging system according to the present invention includes a plurality of user computers 12 in the Internet 10, which is a network for transmitting and receiving data through communication between computers scattered in remote locations. Heterogeneous database systems 14 to 18 are connected, and the user computer 12 inputs a Uniform Resource Locator (URL) and user login account information to provide various types of DBMSs distributed on the Internet 10. Easily linked, the data in the tables of each database system is sorted by field and batch-normalized similar data.

도 3은 이종의 데이터 베이스 자동 병합을 수행하기 위하여 도 2에 도시한 사용자 컴퓨터(12)가 수행하는 기능을 나타낸 블럭 구성도이다.FIG. 3 is a block diagram showing a function performed by the user computer 12 shown in FIG. 2 to perform heterogeneous database automatic merging.

어떠한 플랫폼과도 호환적으로 동작할 수 있는 융통성을 제공하기 위해 사용자 컴퓨터(12)에는 자바 가상 머신(122)이 설치되어 있고, 다양한 이종 데이터 베이스 시스템에 연결하기 위한 JDBC 드라이버(124 ~ 128)를 가지고 있다.In order to provide flexibility to operate with any platform, the Java virtual machine 122 is installed on the user computer 12, and JDBC drivers 124 to 128 for connecting to various heterogeneous database systems are provided. Have.

도 3에서, 참조 부호 130은 사용자의 요구에 의해서 만들어진 프로그램으로서 어플리케이션 프로그래밍 인터페이스(API: Application Programming Interface)이고, 132는 컴퓨터 시스템의 기반이 되는 하드웨어(CPU) 또는 운영 체제 소프트웨어(OS)인 플랫폼이다.In FIG. 3, reference numeral 130 denotes a program made at the request of a user, and is an application programming interface (API), and 132 is a platform which is hardware (CPU) or operating system software (OS) on which a computer system is based. .

사용자 컴퓨터(12)는 상기 JDBC 드라이버들(124 ~ 128)을 통해 각각의 표적 데이터 베이스와 연결하게 되는데, 데이터 베이스 응용 개발을 지원하는 JDBC의 주요 클래스는 다음의 표 1과 같다.The user computer 12 is connected to each target database through the JDBC drivers 124 to 128. The main classes of JDBC supporting database application development are shown in Table 1 below.

클래스 명Class name 주 요 기 능main function DriverDriver DBMS 연결을 위해 해당 DBMS 벤더가 제공하는 자바 컴포넌트Java components provided by the appropriate DBMS vendor for connecting to the DBMS. ConnectionConnection DBMS 와의 연결 및 세션 유지, 트랜잭션 관리를 지원Support connection, session maintenance and transaction management with DBMS StatementStatement SQL 처리를 위한 인터페이스 제공Provide an interface for SQL processing PreparedStatementPreparedStatement 사전에 컴파일된 SQL 처리Precompiled SQL Processing CallableStatementCallablestatement 저장된 일련의 프로시져를 처리하는 인터페이스 제공Provide an interface to handle a set of stored procedures ResultSetResultSet SQL 질의 결과를 나타내는 인터페이스Interface representing the result of an SQL query ResultSetMetaDataResultSetMetaData ResultSet의 컬럼 정보를 제공Provide column information of ResultSet DatabaseMetaDataDatabaseMetaData Database 전체에 대한 메타 정보를 제공Provide meta information about the entire database

또한, 도 3에서 참조 부호 134는 본 발명에 따른 이종의 데이터 베이스 자동 병합을 실행하는 데이터 베이스 정리 도구로서의 데이터 베이스 병합 프로그램이고, 참조 부호 135는 사용자 컴퓨터(12)에서 처리된 데이터를 임시 저장하거나 송수신되는 데이터를 저장하기 위한 데이터 저장부, 참조 부호 136은 상기 데이터 베이스 병합 프로그램(134)을 이용하여 원격지의 데이터 베이스 시스템들로부터 데이터를 복사하거나 정리된 데이터들을 병합하여 다른 시스템들이 공유할 수 있도록 저장하는 로컬 데이터 베이스이다.In FIG. 3, reference numeral 134 denotes a database merging program as a database cleanup tool for executing heterogeneous database automatic merging according to the present invention, and reference numeral 135 temporarily stores data processed by the user computer 12, or A data storage unit for storing data transmitted and received, reference numeral 136 denotes data to be shared by other systems by copying data from remote database systems or merging data using the database merging program 134. Local database to store.

또한, 도 3에 도시하지는 않았지만, 사용자 컴퓨터(12)는 사용자가 데이터를 입력하거나 선택할 때 이용하는 키보드 또는 마우스, 그리고 화면 출력을 위한 모니터 등을 더 구비하게 된다.In addition, although not shown in FIG. 3, the user computer 12 may further include a keyboard or mouse used when a user inputs or selects data, and a monitor for screen output.

이어, 도 4와 도 14에 나타낸 순서도를 참조하여 이종의 데이터 베이스 자동 병합 방법을 설명한다.Next, a heterogeneous database automatic merging method will be described with reference to the flowcharts shown in FIGS. 4 and 14.

도 4는 원격 데이터 베이스 시스템으로부터 테이블을 선택하여 복사하는 과정을 나타낸 순서도이다.4 is a flowchart illustrating a process of selecting and copying a table from a remote database system.

먼저, 사용자 컴퓨터(12)를 이용하여 사용자가 프로그램 화일 형태로 저장되어 있는 데이터 베이스 병합 프로그램(134)을 실행하도록 명령하게 된다(S2 단계).First, the user computer 12 instructs the user to execute the database merge program 134 stored in the form of a program file (step S2).

사용자가 데이터 베이스 병합 프로그램(134)의 실행 명령을 입력하면, 사용자 컴퓨터(12)의 플랫폼(132)은 데이터 베이스 병합 프로그램을 실행하여 도 5에 도시된 바와 같은 첫 화면을 제공하게 된다(S4 단계).When a user inputs an execution command of the database merging program 134, the platform 132 of the user computer 12 executes the database merging program to provide a first screen as shown in FIG. 5 (step S4). ).

도 5에 도시된 첫 화면에는 원격지의 데이터 베이스를 연결할 각각의 데이터 베이스 URL 리스트(화면의 좌측 상단)와 선택된 데이터 베이스의 테이블 리스트(화면의 좌측 중단), 각 필드의 레코드 현황(화면의 우측 상단), 정리할 데이터의 입력과 대상 입력창(화면의 우측 하단) 등이 화면에 표시되고 있다.In the first screen shown in Fig. 5, each database URL list (upper left corner of the screen) to connect a remote database, a table list of a selected database (left side of the screen), record status of each field (upper right corner of the screen) ), Input of data to be arranged and a target input window (lower right of the screen) are displayed on the screen.

상기 첫 화면이 제공되고 있는 상태에서, 플랫폼(132)은 사용자가 원격 데이터 베이스 연결에 관한 명령을 입력하는지를 판단하게 된다(S6 단계).In the state where the first screen is being provided, the platform 132 determines whether the user inputs a command regarding a remote database connection (step S6).

상기 첫 화면에서 사용자가 파일 메뉴를 통해 원격 데이터 베이스 시스템 연결에 관한 메뉴를 선택하게 됨에 따라 원격 데이터 베이스 연결에 관한 명령이 입력되면, 플랫폼(132)은 도 7에 도시된 바와 같이 데이터 베이스 연결을 위한 사용자 인터페이스를 실행하여 표적의 데이터 베이스 시스템에 연결할 데이터 베이스 드라이버와, 그 데이터 베이스 시스템의 URL을 입력하는 화면을 제공하게 된다(S8 단계).In the first screen, when a user selects a menu for connecting to a remote database system through a file menu, when a command for connecting to a remote database is input, the platform 132 performs a database connection as shown in FIG. 7. By executing the user interface for providing a database driver to be connected to the target database system and a screen for inputting the URL of the database system (step S8).

도 7에 도시된 데이터 베이스 연결을 위한 사용자 인터페이스는 다이얼로그 윈도우를 생성시키는 "JDialog" 클래스를 상속받은 "ConnectDlg" 클래스가 "JPanel" 클래스, "JButton" 클래스, "JTextField" 클래스, "JLabel" 클래스, "XYLayout" 클래스, "DataBase" 클래스들과 연관되어 작동됨을 보여준다.The user interface for database connection shown in FIG. 7 includes the "JPanel" class, the "JButton" class, the "JTextField" class, the "JLabel" class, the "ConnectDlg" class inheriting the "JDialog" class that creates a dialog window. It shows that it works in conjunction with the "XYLayout" class and the "DataBase" classes.

도 7에서, "ConnectDlg" 클래스는 데이터 베이스 연결을 위한 다이얼로그 윈도우를 만들어 주는 클래스로서, "JDialog" 클래스를 상속받아 정의한 클래스이다.In FIG. 7, the "ConnectDlg" class is a class that creates a dialog window for connecting to a database, and is a class defined by inheriting the "JDialog" class.

상기 "JPanel" 클래스는 사용자 인터페이스를 생성할 때 필요한, 버튼, 라디오 버튼, 체크 박스, 레이블, 텍스트 필드와 같은 컴포넌트를 배치하고 이들을 담기 위한 컨테이너 객체를 생성하는 클래스이다.The "JPanel" class is a class for placing a component such as a button, a radio button, a check box, a label, and a text field required for creating a user interface and creating a container object for containing them.

상기 "JButton" 클래스는 사용자 인터페이스의 버튼 객체를 생성하며, "JPanel" 객체 상에 배치된다.The "JButton" class creates a button object of a user interface and is placed on a "JPanel" object.

상기 "JTextField" 클래스는 사용자 인터페이스의 텍스트 필드 객체를 생성하며, " JPanel" 객체 상에 배치된다.The "JTextField" class creates a text field object of the user interface and is placed on the "JPanel" object.

상기 "JLabel" 클래스는 사용자 인터페이스의 레이블 객체를 생성하며, " JPanel" 객체 상에 배치된다.The "JLabel" class creates a label object of the user interface and is placed on the "JPanel" object.

상기 "XYLayout" 클래스는 패널과 같은 컨테이너 객체 상에서 버튼, 레이블 등과 같은 각 컴포넌트의 배치를 x, y 축 좌표 개념으로 자유롭게 배치할 수 있도록 제어해준다.The "XYLayout" class controls the layout of each component such as a button, a label, and the like on a container object such as a panel freely in the concept of x and y axis coordinates.

상기 "DataBase" 클래스는 JDBC를 이용하여 데이터 베이스 연결 및 연결 관리를 수행하는 객체를 생성한다.The "DataBase" class creates an object that performs database connection and connection management using JDBC.

이어, 사용자가 데이터 베이스 드라이버명을 입력하고, 표적 데이터 베이스 시스템의 URL을 입력하면, 플랫폼(132)은 표적 데이터 베이스 시스템에 접속할 때 이용되는 아이디와 패스워드를 입력받기 위한 화면을 제공하게 된다.Subsequently, when the user inputs a database driver name and a URL of the target database system, the platform 132 provides a screen for inputting an ID and password used when accessing the target database system.

사용자가 아이디와 패스워드를 입력하면(S10 단계), 플랫폼(132)은 입력된 아이디와 패스워드 및 상기 URL 데이터 등을 데이터 저장부(135)에 저장해 두게 된다.When the user enters the ID and password (step S10), the platform 132 stores the input ID and password and the URL data in the data storage unit 135.

상기 플랫폼(132)은 자바 가상 머신(122)을 구동하여 입력된 데이터 베이스 드라이버명에 해당하는, 예컨대, JDBC 드라이버1(124)을 통해 데이터 저장부(135)에 저장되어 있는 데이터들을 토대로 상기 표적 데이터 베이스 시스템의 URL로 접속을 실행하게 된다(S12 단계).The platform 132 drives the Java virtual machine 122 based on the data stored in the data storage unit 135 through the JDBC driver 1 124 corresponding to the database driver name input. The connection is made to the URL of the database system (step S12).

상기 표적 데이터 베이스 시스템을 구비하는 컴퓨터의 URL로의 접속은, 예컨대, 웹브라우저를 이용하는 통상적인 인터넷 접속 과정을 통해 이루어지므로 이에 대한 자세한 설명은 생략한다.Since the connection to the URL of the computer having the target database system is made through a conventional internet access process using, for example, a web browser, a detailed description thereof will be omitted.

표적 데이터 베이스 시스템에서는 임의의 사용자 컴퓨터로부터 접속 요청이 있으면, 로그인 과정을 통해 접속을 요청한 클라이언트가 정당한 가입인지를 판단하여, 정당한 경우에만 접속을 허용하게 된다.In the target database system, if there is an access request from any user computer, the client requesting access through the login process is determined to be a valid subscription, and the access is allowed only when it is legitimate.

따라서, 상기 데이터 베이스 시스템에서 로그인에 필요한 아이디와 패스워드를 요구하게 되면, 플랫폼(132)은 상기 데이터 저장부(135)에 저장되어 있는 아이디와 패스워드 데이터를 표적 데이터 베이스 시스템에 제시하게 되고, 이를 확인한 표적 데이터 베이스 시스템에서는 자신의 데이터 베이스에 저장되어 있는 테이블의 목록을 접속된 사용자 컴퓨터(12)로 제공해 주게 된다.Therefore, when the database system requires the ID and password required for login, the platform 132 presents the ID and password data stored in the data storage unit 135 to the target database system. In the target database system, a list of tables stored in its database is provided to the connected user computer 12.

상기 표적 데이터 베이스 시스템으로부터 데이터 베이스 테이블 목록에 관한 데이터를 수신한 사용자 컴퓨터(12)의 플랫폼(132)은 모니터(미도시)를 통해 도 8에 도시된 바와 같이 테이블 목록을 출력해 주게 된다(S14 단계).The platform 132 of the user computer 12 that has received data on the database table list from the target database system outputs the table list as shown in FIG. 8 through a monitor (not shown) (S14). step).

이어, 사용자가 도 8에 제시한 바와 같이 화면 출력되는 테이블 목록 중, 도 8에 도시된 바와 같이 검은 막대 모양이 가리키고 있는 것처럼 임의의 테이블을 선택하게 되면(S16 단계), 플랫폼(132)은 도 9에 제시된 바와 같은 데이터 베이스 복사를 위한 사용자 인터페이스를 실행하게 된다.Subsequently, when the user selects an arbitrary table from the list of tables displayed on the screen as shown in FIG. 8 as indicated by the black bar as shown in FIG. This will launch the user interface for copying the database as shown in 9.

도 9에서, 데이터 베이스 복사를 위한 사용자 인터페이스는 원격 및 로컬의 표적 데이터를 사용자가 미리 설정한 DBMS로 복사할 수 있도록 사용자 인터페이스를 제공하는 "DbCopy" 클래스가 도 7에 도시된 클래스를 포함하여 "SplitPanel" 클래스, "BorderLayout" 클래스, "Vector" 클래스, "ListControl" 클래스와 연관되어 작동되게 된다.In FIG. 9, the user interface for database copying includes a class "DbCopy" including a class shown in FIG. 7, which provides a user interface for copying remote and local target data to a user-set DBMS. It works in conjunction with the SplitPanel "class, the" BorderLayout "class, the" Vector "class, and the" ListControl "class.

도 9에서 이미 도 7에 도시된 클래스들의 설명은 생략한다. 도 9의 "SplitPanel" 클래스는 윈도우 탐색기와 같은 인터페이스에서 상하 좌우 분리선을 마우스로 드래그(Drag)하면 해당 패널 영역의 면적이 넓어지고 좁아지는 기능을 수행하는 가변 패널 객체를 만들어준다.In FIG. 9, descriptions of the classes already shown in FIG. 7 will be omitted. The "SplitPanel" class of FIG. 9 creates a variable panel object that performs a function of expanding and narrowing the area of the corresponding panel area by dragging the upper, lower, left, and right dividing lines with a mouse in an interface such as a window explorer.

상기 "BorderLayout" 클래스는 "XYLayout" 클래스와는 달리, 컴포넌트의 배치를 컨테이너 객체의 가장자리 경계에 맞춰 북, 남, 동, 서, 중앙 위치로 자리 잡도록 제어한다.Unlike the "XYLayout" class, the "BorderLayout" class controls the layout of components to be positioned in north, south, east, west, and center positions according to the edge boundary of the container object.

상기 "Vector" 클래스는 자바(Java) 언어에서 제공하는 유연한 자료 구조를 생성하는 클래스로서, 타입이 다른 여러 데이터들을 하나의 논리적인 단위로서 취급할 수 있도록 해준다.The "Vector" class is a class that creates a flexible data structure provided by the Java language. The "Vector" class can handle various types of data as one logical unit.

상기 "ListControl" 클래스는 사용자 인터페이스에 여러 데이터 항목을 리스트 형식으로 표현하고 제어하는 객체를 생성한다.The "ListControl" class creates an object that represents and controls various data items in a list form in a user interface.

상기 도 9에 나타낸 바와 같은 사용자 인터페이스를 실행하여 원격지의 표적 데이터 베이스에 정의된 테이블을 사용자 컴퓨터(12) 또는 사용자가 지정하는 다른 데이터 베이스로 복사하기 위해서는 표적 데이터 베이스의 카탈로그, 스키마, 테이블명, 칼럼명 등의 메타 데이터 정보를 얻어와야 한다.In order to copy the table defined in the target database at a remote location to the user computer 12 or another database designated by the user by executing the user interface as shown in FIG. 9, the catalog, schema, table name, Metadata information such as column name should be obtained.

이때, 플랫폼(132)은 도 10에 도시된 바와 같은 테이블 복사를 위한 메타 데이터 처리 클래스를 이용하게 된다. 즉, 플랫폼(132)은 자바 가상 머신(122)을 구동하여 상기 메타 데이터 처리 클래스를 이용해 테이블 복사에 관한 스레드(Thread)를 생성해 테이블 복사를 처리하게 된다.At this time, the platform 132 uses a metadata processing class for copying a table as shown in FIG. 10. That is, the platform 132 drives the Java virtual machine 122 to generate a thread for copying the table using the metadata processing class to process the copying of the table.

도 10에 도시된 테이블 복사를 위한 메타 데이터 처리 클래스는 "DBMeta" 클래스가 "DatabaseMetaData" 인터페이스와 "Vector" 클래스, "Connection" 클래스, "ResultSet" 인터페이스와 연관되어 작동하게 된다.In the metadata processing class for copying the table shown in FIG. 10, the "DBMeta" class is associated with the "DatabaseMetaData" interface, the "Vector" class, the "Connection" class, and the "ResultSet" interface.

도 10에서, 상기 "DatabaseMetaData" 인터페이스는 데이터 베이스 전체에 대한 메타 데이터 정보를 표현한 인터페이스 객체를 생성한다.In FIG. 10, the "DatabaseMetaData" interface creates an interface object representing meta data information for the entire database.

상기 "DBMeta" 클래스는 데이터 베이스 테이블 복사를 위한 메타 데이터 처리를 담당하는 클래스로서, 표적 데이터 베이스에 정의된 테이블을 사용자가 지정한 데이터 베이스로 복사할 때 필요한 표적 데이터 베이스의 카탈로그, 스키마, 테이블명, 컬럼명 등의 메타 데이터를 처리한다. 상기 "DatabaseMetaData" 인터페이스를 인터페이스해서 클래스를 생성한다.The "DBMeta" class is a class in charge of metadata processing for copying a database table. The catalog, schema, table name, and the like of the target database required for copying a table defined in the target database to a user-specified database are provided. Process meta data such as column name. Create a class by interfacing the "DatabaseMetaData" interface.

상기 "Connection" 클래스는 표적 DBMS와의 연결 및 세션 유지, 트랜잭션 관리를 지원한다.The "Connection" class supports connection, session maintenance, and transaction management with the target DBMS.

상기 "ResultSet" 인터페이스는 SQL 질의 결과는 나타내는 인터페이스이다.The "ResultSet" interface is an interface representing an SQL query result.

또한, 상기 테이블 복사를 위해서 사용자가 지정한 데이터 베이스로 신규 테이블을 생성해야 되는데, 플랫폼(132)은 상기 메타 데이터 정보를 이용하여 신규 테이블의 필드 타입을 정의해야 한다. 이 때, 플랫폼(132)은 도 11에 도시된 바와 같은 테이블 복사시 생성되는 신규 테이블의 필드 타입 처리 클래스를 이용하여 신규 테이블의 생성을 처리하게 된다.In addition, it is necessary to create a new table with a user-specified database for copying the table. The platform 132 must define a field type of the new table using the metadata information. At this time, the platform 132 processes the creation of the new table using the field type processing class of the new table generated when the table is copied as shown in FIG. 11.

도 11에 도시된 신규 테이블의 필드 타입 처리 클래스는 "DBMeta" 클래스가 "Connection" 클래스, "ResultSet" 클래스, "Vector" 클래스, "DatabaseMetaData" 클래스와 연관되어 작동하는 것이다.The field type processing class of the new table shown in FIG. 11 is that the "DBMeta" class operates in association with the "Connection" class, the "ResultSet" class, the "Vector" class, and the "DatabaseMetaData" class.

상기 "FieldNameType" 클래스는 이종 데이터 베이스 환경에서 표적 데이터 베이스의 테이블을 사용자가 지정한 데이터 베이스의 신규 테이블로 복사할 때 테이블의 필드 타입을 일치시켜 주는 처리를 담당한다. 또한, "String" 클래스는 문자열 표현과 처리를 담당하는 표준 자바 클래스이다.The "FieldNameType" class is responsible for matching a field type of a table when a table of a target database is copied to a new table of a database designated by a user in a heterogeneous database environment. Also, the "String" class is a standard Java class that handles string representation and handling.

그리고, 사용자가 임의의 필드를 선택하여 복사를 실행하게 되면 도 12에 도시된 바와 같이, 플랫폼(132)은 선택된 테이블을 복사하는 클래스를 이용하여 표적 데이터 베이스내에 있는 필드 내용을 복사하는 과정을 수행하게 된다.When the user selects an arbitrary field and executes a copy, as shown in FIG. 12, the platform 132 performs a process of copying the contents of the field in the target database using a class for copying the selected table. Done.

도 12에서, 테이블 복사를 위한 클래스는 선택된 테이블을 복사하는 기능의 "CTabe" 클래스가 도 9와 도 10 및 도 11에 도시된 클래스들과 관련되어 작동한다.In Fig. 12, the class for copying a table operates in association with the classes shown in Figs.

상기 화면 출력되는 표적 데이터 베이스의 테이블 목록 중 임의의 테이블을 선택하는 S16 단계에서, 사용자는 선택한 테이블을 옮겨야 할 대상의 지역 데이터 베이스를 지정해야 한다.In step S16 of selecting an arbitrary table from the table list of the target database displayed on the screen, the user must designate a local database of a target to which the selected table is to be moved.

사용자는 화면 출력되는 테이블 목록의 하단부에 구비된 도 13(A)에 도시된 바와 같은 입력창을 통해 지정할 데이터 베이스 시스템과의 연결을 위한 JDBC 드라이버를 설정하고, 그 지역 데이터 베이스의 URL 데이터를 입력하게 된다.The user sets a JDBC driver for connection with the database system to be designated through an input window as shown in FIG. 13A provided at the bottom of the table list displayed on the screen, and inputs URL data of the local database. Done.

상기와 같은 과정으로 해당 데이터를 입력하여 상기 표적 데이터 베이스로부터 복사해 옮길 지역 데이터 베이스를 지정하게 되면(S18 단계), 사용자컴퓨터(12)의 플랫폼(132)은 도 13의 (B)와 같이 지역 데이터 베이스 로그인에 관한 입력 화면창을 제공하게 된다.When the corresponding data is input by the above process and the local database to be copied from the target database is designated (step S18), the platform 132 of the user computer 12 is located as shown in (B) of FIG. It will provide an input window for logging into the database.

사용자가 지역 데이터 베이스 로그인에 관한 입력 화면창을 통해 해당 아이디와 패스워드를 입력하면, 플랫폼(132)은 데이터 저장부(135)에 상기 입력된 데이터를 임시 저장하고, 이를 근거로 해당 지역 데이터 베이스 시스템으로 연결을 시도한다(S20 단계).When the user inputs the corresponding ID and password through the input screen window regarding the local database login, the platform 132 temporarily stores the input data in the data storage unit 135, and based on this, the local database system Attempt to connect (step S20).

이후, 로그인이 성공적으로 진행되어 상기 지정한 지역 데이터 베이스 시스템과 연결되면, 플랫폼(132)은 도 13의 (C)와 같이 화면의 일부에서는 표적 데이터 베이스의 테이블 목록을 출력하고, 화면의 다른 일부로는 지정한 지역 데이터 베이스의 테이블 목록을 화면 출력하게 된다.Subsequently, when the login is successfully performed and connected to the designated local database system, the platform 132 outputs a table list of the target database on a part of the screen as shown in FIG. 13C, and the other part of the screen. The table list of the specified local database is displayed.

상기와 같이 표적 데이터 베이스와 지역 데이터 베이스의 테이블 내용이 출력되는 가운데, 사용자는 표적 데이터 베이스에서 복사하고자 하는 테이블을 선택하고, 화면상에서 복사 버튼을 클릭하게 됨으로써 테이블 복사가 이루어지게 된다(S22 단계).While the contents of the table of the target database and the local database are output as described above, the user selects a table to be copied from the target database and clicks the copy button on the screen to copy the table (step S22). .

즉, 사용자가 테이블을 선택하고 복사 버튼을 클릭하게 되면, 사용자 컴퓨터(12)의 플랫폼(132)은 데이터 베이스의 테이블 중 선택한 테이블을 복사해서 지역 데이터 베이스로 전송해 달라는 제어 데이터를 지역 데이터 베이스의 URL 데이터와 함께 표적 데이터 베이스 시스템으로 전송하게 된다.That is, when the user selects a table and clicks the copy button, the platform 132 of the user computer 12 copies the selected table among the tables of the database and transmits the control data to the local database. The data is sent along with the URL data to the target database system.

표적 데이터 베이스 시스템에서는 데이터 베이스 중 선택된 테이블과 그 내용 데이터를 지역 데이터 베이스 URL 주소로 송출해 주게 됨으로써, 상기 표적 데이터 베이스에서 지역 데이터 베이스로의 테이블 복사가 실행되는 것이다.In the target database system, a table selected from the database and its contents data are sent to a local database URL address, thereby copying a table from the target database to the local database.

전술한 바와 같은 과정으로 표적 데이터 베이스에서 지역 데이터 베이스로 테이블 복사가 이루어진 이후, 사용자는 지역 데이터 베이스에 복사된 데이터를 나름대로 사용하기 편리하게 정리를 하게 된다.After the table copy is made from the target database to the local database by the above-described process, the user can conveniently arrange the data copied to the local database in their own way.

도 14는 유사 데이터 표준화 처리 과정을 나타낸 순서도이다.14 is a flowchart showing a process of standardizing similar data.

사용자가 데이터 베이스 병합 프로그램(134)을 이용하여 지역 데이터 베이스로 복사된 테이블을 선택하고(S32 단계), 그 선택된 테이블의 내용이 도 15에 도시된 바와 같이 화면 출력되고 있는 상태에서(S34 단계), 플랫폼(132)은 표준화시킬 유사 데이터의 입력이 있는지를 판단하게 된다(S36 단계).The user selects the table copied to the local database using the database merging program 134 (step S32), and the contents of the selected table are displayed on the screen as shown in FIG. 15 (step S34). In operation S36, the platform 132 determines whether there is an input of similar data to be normalized.

플랫폼(132)은 필드별로 유사 데이터를 통일화된 데이터로 정리하기 위해 도 16에 도시한 바와 같은 유사 데이터 표준화 처리를 위한 사용자 인터페이스를 이용하게 된다.The platform 132 uses a user interface for similar data standardization processing as shown in FIG. 16 to organize similar data for each field into unified data.

도 15에서는, 복사해 온 "customer" 테이블의 "city" 필드에 대해서 "거주지"라는 데이터 클래스를 적용하는 것을 예시하고 있다. 여기서 "city" 필드를 보면 "서울특별시", "인천직할시" 형태의 데이터 값을 가지고 있음을 알 수 있다.In FIG. 15, the data class "resident" is applied to the "city" field of the copied "customer" table. If you look at the "city" field, you can see that it has data values of "Seoul" and "Incheon".

상기한 상태에서, 사용자가 도 17에 도시된 바와 같은 유사 데이터 등록을 위한 인터페이스를 이용하여 표준화시킬 유사 데이터를 입력하게 되면, 플랫폼(132)은 입력된 데이터를 토대로 유사 데이터 표준화 처리를 위한 사용자 인터페이스를 실행하게 된다(S38 단계).In the above state, when the user inputs similar data to be normalized using the interface for similar data registration as shown in FIG. 17, the platform 132 performs a user interface for similar data standardization processing based on the input data. It will be executed (step S38).

예컨대, 도 17 화면 우측에 있는 표를 참조할 때, 제 2 줄과 제 4 줄과 같이바뀌는 데이터를 "광주시"나 "서울시"로 하고, 바뀔 대상의 데이터를 "광주광역시"나 "서울특별시"로, 데이터 클래스는 "거주지"로 일괄 정리하는 "start" 명령을 입력하게 되면, 플랫폼(132)은 도 18과 같이 유사 데이터의 표준화 처리를 위한 일괄 정리 클래스를 이용하게 됨으로써 유사 데이터에 대한 일괄 표준화 처리를 실행하게 된다(S40 단계).For example, referring to the table on the right side of the screen of FIG. 17, data to be changed as in the second and fourth lines is referred to as "gwangju city" or "seoul city", and the data to be changed is "gwangju metropolitan city" or "seoul city". As a result, when the data class inputs a "start" command for collectively arranging "dwelling", the platform 132 uses the batch cleanup class for standardizing similar data, as shown in FIG. The process is executed (step S40).

따라서, 플랫폼(132)은 "광주광역시"는 "광주시"로, "서울특별시"는 "서울시"로 일괄적으로 변경하게 된다. 그 결과, 도 19에 도시된 바와 같이 데이터 클래스의 정의에 따라 "city" 필드의 값이 "서울시", "인천시"와 같은 형태의 값으로 변경되었음을 알 수 있다.Accordingly, the platform 132 is collectively changed to "gwangju" as "gwangju" and "seoul" as "seoul". As a result, as shown in FIG. 19, it can be seen that the value of the "city" field is changed to a value such as "Seoul" or "Incheon" according to the definition of the data class.

이상에서 설명한 바와 같이, 유사 데이터의 표준화 처리를 위한 사용자 인터페이스를 이용하면 전체 필드 데이터를 대상으로 유사 데이터를 정리할 수 있으며, 정형화된 테이블을 얻을 수 있게 되는 것이다.As described above, by using the user interface for standardizing the similar data, the similar data can be arranged for all the field data, and a standardized table can be obtained.

이어, 플랫폼(132)은 정리할 테이블이 더이상 없는지를 판단하고(S42 단계), 정리할 테이블이 더 있는 경우에는 테이블의 내용을 화면 출력하는 상기 S34 단계로 복귀하여 전술된 과정으로 유사 데이터 표준화 처리를 반복하게 된다.Subsequently, the platform 132 determines whether there are no more tables to clean up (step S42), and if there are more tables to clean up, returns to the step S34 of outputting the contents of the table and repeats the similar data normalization process in the above-described process. Done.

한편, 정리할 테이블이 더이상 없어 사용자가 테이블을 병합하고자 하여 테이블 병합에 관한 인터페이스를 선택하게 되면(S44 단계), 플랫폼(132)은 도 22에 도시된 바와 같이 테이블 병합을 위한 사용자 인터페이스 클래스를 실행하고, 도 20에 도시한 바와 같이 테이블 병합을 실행하기 위한 화면을 출력하게 된다(S46 단계).On the other hand, when there are no more tables to clean up and the user selects an interface for merging the tables in order to merge the tables (step S44), the platform 132 executes a user interface class for merging the tables as shown in FIG. As shown in FIG. 20, a screen for executing a table merge is output (step S46).

도 20(A)에 도시된 바와 같이 사용자가 "Table A", "Table B" 영역에서 ">" 버튼을 클릭하여 병합할 대상의 필드를 선택하면(S48 단계), 플랫폼(132)은 새로운 테이블에 선택된 병합 대상의 필드를 이동시켜 테이블 병합 처리를 실행하게 된다(S50 단계).As shown in FIG. 20 (A), when the user clicks the ">" button in the "Table A" and "Table B" areas to select a field to be merged (step S48), the platform 132 selects a new table. In step S50, the table merge process is performed by moving the selected field of the merge target.

그리고, 사용자가 병합 처리에 따른 신규 테이블의 이름을 입력하여 지정하게 되면, 플랫폼(132)은 도 23에 도시된 바와 같은 테이블 병합 처리 클래스를 이용하여 새로 입력된 이름의 테이블로 상기 선택된 필드를 가지는 신규 테이블을 생성하게 된다(S52 단계).When a user inputs and specifies a name of a new table according to a merge process, the platform 132 may have the selected field as a table of a newly input name using a table merge process class as shown in FIG. 23. A new table is created (step S52).

또한, 플랫폼(132)은 사용자가 병합되는 각 테이블의 프라이머리 키(Primary Key)를 지정하기 위해 "Select" 버튼을 클릭하고 해당 필드를 선택하면, 선택한 필드를 그 테이블에서 프라이머리 키로 설정하게 된다.In addition, the platform 132 clicks the "Select" button to select the primary key of each table to be merged and selects the corresponding field, and sets the selected field as the primary key in the table. .

전술한 바와 같은 과정을 통해 도 24에 도시한 바와 같이 병합 결과에 따른 결과값들을 얻을 수 있다.Through the above-described process, as shown in FIG. 24, the result values according to the merge result may be obtained.

지금까지의 과정을 통해서 지역 데이터 베이스에는 정리된 데이터 베이스 테이블들이 남아 있게 된다. 플랫폼(132)은 이 테이블들을 다른 특정 데이터 베이스 시스템으로 이주하는 기능도 실행할 수 있다.So far, the database has been cleaned up in the local database. The platform 132 may also execute the function of migrating these tables to other specific database systems.

또한, 상기 데이터 베이스 병합 전후 어느 과정에서도 원하는 테이블에서 불필요한 레코드를 삭제할 수 있으며, 범위 지정 연산자를 사용하여 특정 조건을 만족하는 필드의 값을 추출할 수도 있다.In addition, unnecessary records may be deleted from a desired table in any process before or after the database merge, and a value of a field satisfying a specific condition may be extracted using a range designation operator.

즉, 상기 실시예에 의하면 원격지에 있는 데이터 베이스 시스템의 테이블 내용을 다른 특정의 데이터 베이스 시스템으로 복사 이동하고, 사용하기에 편리하도록 유사 데이터를 일괄 정리하며, 또한 원하는 테이블들을 병합할 수 있게 된다.That is, according to the above embodiment, it is possible to copy and move the contents of a table in a remote database system to another specific database system, to collectively arrange similar data for convenient use, and to merge desired tables.

본 발명은 전술한 실시예에 한정되지 않고 본 발명의 기술적 요지를 벗어나지 않는 범위 내에서 다양하게 변형 및 변경 실시할 수 있다.The present invention is not limited to the above-described embodiments, and various modifications and changes can be made without departing from the technical gist of the present invention.

이상 설명한 바와 같이 본 발명에 의하면, 원격지의 이종의 데이터 베이스 내용을 복사하고 일괄 정리하며 이들을 병합할 수 있게 됨으로써, 데이터 베이스로부터의 데이터 로딩 및 추출 과정시 사용자의 설정 항목을 최소화할 수 있게 되고, 다양한 소스 형식에 구애 없이 범용적인 데이터 연결 가능성을 제공하며, 데이터 분석 선행 과정의 단축화를 구현할 수 있는 효과가 있다.As described above, according to the present invention, it is possible to copy, collectively, and merge the heterogeneous database contents of remote locations, thereby minimizing user setting items in the process of loading and extracting data from the database. It provides universal data connectivity possibilities regardless of various source formats, and can shorten the data analysis process.

Claims (25)

원격지의 데이터 베이스 시스템들과 인터넷을 통해 연결되고, 데이터 베이스 병합 프로그램을 통해 원격지의 데이터 베이스 시스템들간의 테이블 복사, 유사 데이터 표준화 처리 및 테이블 병합 등을 실행하는 사용자 컴퓨터를 구비하는 이종의 데이터 베이스 자동 병합 방법에 있어서,A heterogeneous database automatic with a user computer connected to remote database systems via the Internet and performing table copying, similar data standardization processing, and table merging between remote database systems through a database merging program. In the merging method, 상기 데이터 베이스 병합 프로그램을 실행하는 단계,Executing the database merging program; 원격 데이터 베이스 시스템 연결을 위한 인터페이스를 실행하는 단계,Executing an interface for connecting to a remote database system, 표적이 되는 데이터 베이스 시스템으로 연결하는 단계,Connecting to the target database system, 상기 표적 데이터 베이스의 테이블 목록을 화면 출력하는 단계,Outputting a table list of the target database; 상기 화면 출력되는 테이블 목록 중 복사하고자 하는 테이블을 선택하는 단계,Selecting a table to copy from the list of tables displayed on the screen; 복사해 옮길 대상이 되는 지역 데이터 베이스 시스템으로 연결하는 단계,Connecting to the local database system to be copied and moved, 상기 표적 데이터 베이스에서 지역 데이터 베이스로 선택한 테이블을 복사하는 단계를 포함하는 것을 특징으로 하는 이종의 데이터 베이스 자동 병합 방법.Copying the selected table from the target database to a local database. 제 1 항에 있어서,The method of claim 1, 상기 원격 데이터 베이스 시스템 연결을 위한 인터페이스는 자바(Java) 언어에 기반을 둔 자바 데이터 베이스 연결자(JDBC) 기술을 사용한 것을 특징으로 하는 이종의 데이터 베이스 자동 병합 방법.The interface for connecting to the remote database system is a heterogeneous database automatic merging method, characterized in that using the Java Database Connector (JDBC) technology based on the Java language. 제 1 항에 있어서,The method of claim 1, 상기 원격 데이터 베이스 시스템 연결을 위한 인터페이스는 다양한 이종의 데이터 베이스 시스템을 연결하기 위한 JDBC 드라이버를 이용하여 표적 데이터 베이스에 연결하는 것을 특징으로 하는 이종의 데이터 베이스 자동 병합 방법.The interface for connecting to the remote database system is a heterogeneous database automatic merging method, characterized in that for connecting to the target database using a JDBC driver for connecting a variety of heterogeneous database system. 제 1 항에 있어서,The method of claim 1, 상기 표적 데이터 베이스와 지역 데이터 베이스로의 연결시, 각각의 데이터 베이스 시스템의 URL과 아이디 및 패스워드를 입력하여 연결하는 것을 특징으로 하는 이종의 데이터 베이스 자동 병합 방법.When connecting to the target database and the local database, heterogeneous database automatic merging method characterized in that the connection by inputting the URL and ID and password of each database system. 제 1 항에 있어서,The method of claim 1, 상기 표적 데이터 베이스에서 지역 데이터 베이스로의 테이블 복사시 데이터 베이스 복사를 위한 인터페이스를 이용하는 것을 특징으로 하는 이종의 데이터 베이스 자동 병합 방법.Method for automatically merging heterogeneous databases, using an interface for copying a database when copying a table from the target database to a local database. 제 1 항에 있어서,The method of claim 1, 상기 선택한 테이블을 복사하기 전에 표적 데이터 베이스의 카탈로그, 스키마, 테이블명, 칼럼명에 관한 메타 데이터 정보를 얻기 위해 메타 데이터 처리를 위한 클래스를 이용하는 것을 특징으로 하는 이종의 데이터 베이스 자동 병합 방법.A method for automatically merging heterogeneous databases, wherein a class for processing metadata is used to obtain metadata information about a catalog, schema, table name, and column name of a target database before copying the selected table. 제 1 항에 있어서,The method of claim 1, 상기 선택된 테이블 복사시 테이블 복사를 위한 클래스를 이용하는 것을 특징으로 하는 이종의 데이터 베이스 자동 병합 방법.The method of automatically merging heterogeneous databases, wherein a class for copying a table is used when copying the selected table. 원격지의 데이터 베이스 시스템들과 인터넷을 통해 연결되고, 데이터 베이스 병합 프로그램을 통해 원격지의 데이터 베이스 시스템들간의 테이블 복사, 유사 데이터 표준화 처리 및 테이블 병합 등을 실행하는 사용자 컴퓨터를 구비하는 이종의 데이터 베이스 자동 병합 방법에 있어서,A heterogeneous database automatic with a user computer connected to remote database systems via the Internet and performing table copying, similar data standardization processing, and table merging between remote database systems through a database merging program. In the merging method, 데이터 베이스 병합 프로그램을 실행하여 대상 데이터 베이스의 테이블 내용을 화면 출력하는 단계,Executing the database merge program to display the contents of the table of the target database; 유사 데이터 표준화 처리를 위한 사용자 인터페이스를 실행하는 단계,Executing a user interface for processing similar data standardization, 일괄 정리할 데이터를 입력하는 단계,Enter the data you'd like to bulk sort, 유사 데이터 표준화 처리를 위한 클래스를 이용하여 테이블 내용을 일괄 정리하는 단계,Collectively tidying up table contents using classes for standardizing similar data; 일괄 정리된 테이블 내용을 화면 출력하는 단계를 포함하는 것을 특징으로 하는 이종의 데이터 베이스 자동 병합 방법.A method for automatically merging heterogeneous databases, comprising: outputting the contents of a batched table. 원격지의 데이터 베이스 시스템들과 인터넷을 통해 연결되고, 데이터 베이스병합 프로그램을 통해 원격지의 데이터 베이스 시스템들간의 테이블 복사, 유사 데이터 표준화 처리 및 테이블 병합 등을 실행하는 사용자 컴퓨터를 구비하는 이종의 데이터 베이스 자동 병합 방법에 있어서,Heterogeneous database automation with user computers connected to remote database systems via the Internet, and using a database merge program to perform table copying, pseudo-data normalization processing, and table merging between remote database systems. In the merging method, 병합할 테이블 선택을 위한 인터페이스를 실행하는 단계,Launching an interface for selecting tables to merge, 병합하고자 하는 테이블과 필드를 선택하는 단계,Selecting the tables and fields you want to merge, 상기 선택한 테이블의 필드들을 신규 테이블로 병합하는 단계,Merging the fields of the selected table into a new table; 상기 신규 테이블의 이름을 설정하는 단계,Setting a name of the new table; 상기 신규 테이블의 내용을 화면 출력하는 단계를 포함하는 것을 특징으로 하는 이종의 데이터 베이스 자동 병합 방법.Displaying the contents of the new table screen heterogeneous database automatic merging method comprising the. 제 9 항에 있어서,The method of claim 9, 상기 병합되는 각 테이블의 프라이머리 키(Primary Key)를 설정하는 단계를 추가로 포함하는 것을 특징으로 하는 이종의 데이터 베이스 자동 병합 방법.The method of claim 1, further comprising the step of setting a primary key of each of the merged tables. 제 9 항에 있어서,The method of claim 9, 상기 데이터 베이스 병합 전후, 어느 과정에서도 원하는 테이블에서 불필요한 레코드를 삭제할 수 있는 것을 특징으로 하는 이종의 데이터 베이스 자동 병합 방법.The method for automatically merging heterogeneous databases, wherein unnecessary records can be deleted from a desired table before or after the database merging. 제 9 항에 있어서,The method of claim 9, 병합하고자 하는 테이블과 필드를 선택할 때 범위 지정 연산자를 사용하여 특정 조건을 만족하는 필드의 값을 추출할 수 있는 것을 특징으로 하는 이종의 데이터 베이스 자동 병합 방법.A method for automatically merging heterogeneous databases, in which a range operator is used to extract values of fields that satisfy specific conditions when selecting tables and fields to be merged. 제 9 항에 있어서,The method of claim 9, 상기 선택한 테이블을 신규 테이블로 병합할 때 테이블 병합 처리 클래스를 통해 실행하는 것을 특징으로 하는 이종의 데이터 베이스 자동 병합 방법.When merging the selected table into a new table, heterogeneous database automatic merging method characterized in that executed through a table merge processing class. 원격지의 데이터 베이스 시스템들과 인터넷을 통해 연결되고, 데이터 베이스 병합 프로그램을 통해 원격지의 데이터 베이스 시스템들간의 테이블 복사, 유사 데이터 표준화 처리 및 테이블 병합 등을 실행하는 사용자 컴퓨터를 구비하는 이종의 데이터 베이스 자동 병합 방법에 있어서,A heterogeneous database automatic with a user computer connected to remote database systems via the Internet and performing table copying, similar data standardization processing, and table merging between remote database systems through a database merging program. In the merging method, 원격 데이터 베이스 시스템 연결을 위한 인터페이스를 실행하는 단계,Executing an interface for connecting to a remote database system, 원본이 되는 표적 데이터 베이스 시스템과 대상이 되는 지역 데이터 베이스 시스템에 연결하는 단계,Connecting to the target target database system and the target local database system, 상기 표적 데이터 베이스의 테이블을 지역 데이터 베이스로 복사하는 단계,Copying the table of the target database to a local database; 유사 데이터 표준화 처리를 위한 사용자 인터페이스를 실행하는 단계,Executing a user interface for processing similar data standardization, 상기 복사된 지역 데이터 베이스의 테이블을 일괄 정리하여 유사 데이터 표준화를 처리하는 단계,Processing the similar data standardization by collectively arranging the tables of the copied local database; 테이블 병합을 위한 사용자 인터페이스를 실행하는 단계,Launching a user interface for merging tables, 상기 지역 데이터 베이스의 병합할 테이블과 필드를 선택하는 단계,Selecting tables and fields to be merged in the local database; 상기 선택한 테이블의 필드를 병합하여 신규 테이블로 생성하는 단계를 포함하는 것을 특징으로 하는 이종의 데이터 베이스 자동 병합 방법.And merging the fields of the selected table to create a new table. 제 14 항에 있어서,The method of claim 14, 상기 원격 데이터 베이스 시스템 연결을 위한 인터페이스는 자바(Java) 언어에 기반을 둔 자바 데이터 베이스 연결자(JDBC) 기술을 사용한 것을 특징으로 하는 이종의 데이터 베이스 자동 병합 방법.The interface for connecting to the remote database system is a heterogeneous database automatic merging method, characterized in that using the Java Database Connector (JDBC) technology based on the Java language. 제 14 항에 있어서,The method of claim 14, 상기 원격 데이터 베이스 시스템 연결을 위한 인터페이스는 다양한 이종의 데이터 베이스 시스템을 연결하기 위한 JDBC 드라이버를 이용하여 표적 데이터 베이스에 연결하는 것을 특징으로 하는 이종의 데이터 베이스 자동 병합 방법.The interface for connecting to the remote database system is a heterogeneous database automatic merging method, characterized in that for connecting to the target database using a JDBC driver for connecting a variety of heterogeneous database system. 제 14 항에 있어서,The method of claim 14, 상기 표적 데이터 베이스와 지역 데이터 베이스로의 연결시, 각각의 데이터 베이스 시스템의 URL과 아이디 및 패스워드를 입력하여 연결하는 것을 특징으로 하는 이종의 데이터 베이스 자동 병합 방법.When connecting to the target database and the local database, heterogeneous database automatic merging method characterized in that the connection by inputting the URL and ID and password of each database system. 제 14 항에 있어서,The method of claim 14, 상기 표적 데이터 베이스에서 지역 데이터 베이스로의 테이블 복사시 데이터 베이스 복사를 위한 인터페이스를 이용하는 것을 특징으로 하는 이종의 데이터 베이스 자동 병합 방법.Method for automatically merging heterogeneous databases, using an interface for copying a database when copying a table from the target database to a local database. 제 14 항에 있어서,The method of claim 14, 상기 선택한 테이블을 복사하기 전에 표적 데이터 베이스의 카탈로그, 스키마, 테이블명, 칼럼명에 관한 메타 데이터 정보를 얻기 위해 메타 데이터 처리를 위한 클래스를 이용하는 것을 특징으로 하는 이종의 데이터 베이스 자동 병합 방법.A method for automatically merging heterogeneous databases, wherein a class for processing metadata is used to obtain metadata information about a catalog, schema, table name, and column name of a target database before copying the selected table. 제 14 항에 있어서,The method of claim 14, 상기 선택된 테이블 복사시 테이블 복사를 위한 클래스를 이용하는 것을 특징으로 하는 이종의 데이터 베이스 자동 병합 방법.The method of automatically merging heterogeneous databases, wherein a class for copying a table is used when copying the selected table. 다양한 이종의 데이터 베이스 시스템들이 인터넷을 통해 상호 연결되어 있는 이종의 데이터 베이스 자동 병합 시스템에 있어서,In heterogeneous database automatic merging system in which various heterogeneous database systems are interconnected through the Internet, 상기 이종의 데이터 베이스 자동 병합 시스템의 기반이 되는 하드웨어로서 제반 동작을 제어하는 플랫폼,A platform that controls the overall operation as hardware that is the basis of the heterogeneous database automatic merging system, 자바 언어에 기반을 두고 클래스를 이용하여 인터페이스를 실행하는 자바 가상 머신(Java Virtual Machine),Java Virtual Machine, which is based on the Java language and uses interfaces to implement interfaces, 상기 다양한 이종 데이터 베이스 시스템에 연결하기 위한 다수의 자바 데이터 베이스 연결자(Java DataBase Connectivity) 드라이버,A plurality of Java Database Connectivity driver for connecting to the various heterogeneous database systems, 이종의 데이터 베이스 자동 병합을 실행하기 위한 데이터 베이스 병합 프로그램,A database merge program for executing heterogeneous database automatic merges, 데이터의 입력을 위한 입력수단,Input means for inputting data, 데이터의 화면 출력을 위한 화면 출력수단,Screen output means for screen output of data, 상기 입력수단을 통해 입력된 데이터를 임시 저장하거나 송수신되는 데이터를 저장하기 위한 데이터 저장부,A data storage unit for temporarily storing data input through the input means or storing data transmitted and received; 상기 데이터 베이스 병합 프로그램에 의해 원격지의 데이터 베이스 시스템들로부터 복사하거나 정리된 데이터들을 병합하여 저장하는 로컬 데이터 베이스,A local database for merging and storing data copied or cleaned up from remote database systems by the database merging program; 사용자의 요구에 의해서 만들어진 프로그램의 어플리케이션 인터페이스(API)를 포함하여 구성되고,It is configured to include the application interface (API) of the program made at the request of the user, 상기 플랫폼은 상기 이종의 데이터 베이스 시스템에 연결하여 테이블을 복사하고, 복사된 테이블 내용을 유사 데이터 표준화 처리하며, 사용자가 선택한 테이블의 필드를 병합하여 신규 테이블로 생성하는 것을 제어하는 것을 특징으로 하는 이종의 데이터 베이스 자동 병합 시스템.The platform is connected to the heterogeneous database system to copy a table, standardizes the copied table contents, and controls the generation of a new table by merging fields of a table selected by a user. Database automatic merge system. 제 21 항에 있어서,The method of claim 21, 상기 다양한 이종의 데이터 베이스 시스템에 연결시, 사용자가 입력한 각각의 데이터 베이스 시스템의 URL과 아이디 및 패스워드를 통해 연결하는 것을 특징으로 하는 이종의 데이터 베이스 자동 병합 시스템.When connecting to the various heterogeneous database systems, heterogeneous database automatic merging system, characterized in that the connection through the URL and ID and password of each database system input by the user. 제 21 항에 있어서,The method of claim 21, 상기 이종의 데이터 베이스 시스템으로부터 선택한 테이블을 복사할 때 데이터 베이스 복사를 위한 인터페이스를 이용하는 것을 특징으로 하는 이종의 데이터 베이스 자동 병합 시스템.The heterogeneous database automatic merging system, wherein an interface for copying a database is used when copying a selected table from the heterogeneous database system. 제 21 항에 있어서,The method of claim 21, 상기 선택한 테이블을 복사하기 전에 상기 이종의 데이터 베이스의 카탈로그, 스키마, 테이블명, 칼럼명에 관한 메타 데이터 정보를 얻기 위해 메타 데이터 처리를 위한 클래스를 이용하는 것을 특징으로 하는 이종의 데이터 베이스 자동 병합 시스템.And a class for processing metadata to obtain metadata information about the catalog, schema, table name, and column name of the heterogeneous database before copying the selected table. 제 21 항에 있어서,The method of claim 21, 상기 선택된 테이블 복사시 테이블 복사를 위한 클래스를 이용하는 것을 특징으로 하는 이종의 데이터 베이스 자동 병합 시스템.The heterogeneous database automatic merging system, characterized in that to use the class for copying the table when copying the selected table.
KR1020010048327A 2001-08-10 2001-08-10 Method and system for automatic combining a different kind of database KR20030014011A (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
KR1020010048327A KR20030014011A (en) 2001-08-10 2001-08-10 Method and system for automatic combining a different kind of database

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
KR1020010048327A KR20030014011A (en) 2001-08-10 2001-08-10 Method and system for automatic combining a different kind of database

Publications (1)

Publication Number Publication Date
KR20030014011A true KR20030014011A (en) 2003-02-15

Family

ID=27718720

Family Applications (1)

Application Number Title Priority Date Filing Date
KR1020010048327A KR20030014011A (en) 2001-08-10 2001-08-10 Method and system for automatic combining a different kind of database

Country Status (1)

Country Link
KR (1) KR20030014011A (en)

Cited By (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR20010099183A (en) * 2001-09-10 2001-11-09 . Data Combination Management System
KR100693370B1 (en) * 2005-08-22 2007-03-09 (주)공영디비엠 Duplicated database merge purge arrangement apparatus and the Method Thereof
KR100984976B1 (en) * 2008-04-08 2010-10-05 한국생명공학연구원 The integrating and searching method of alien 2-dimension table
KR101021064B1 (en) * 2008-05-30 2011-03-11 주식회사 프라임데이타시스템 Method and System of mapping multi-dimensional data to table, and computer readable medium recording the method
KR102299746B1 (en) * 2020-04-20 2021-09-08 최길주 System for automatically processing data of web baed heterogeneous database and method thereof

Citations (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JPH05197763A (en) * 1991-08-23 1993-08-06 Internatl Business Mach Corp <Ibm> Method and system for executing join in computor- processing database system
JPH07253991A (en) * 1994-03-16 1995-10-03 Mitsubishi Electric Corp Join processing system
US5497486A (en) * 1994-03-15 1996-03-05 Salvatore J. Stolfo Method of merging large databases in parallel
KR970049768A (en) * 1995-12-21 1997-07-29 이대원 How to build a database
JPH10240753A (en) * 1997-02-26 1998-09-11 Hitachi Ltd Database management system and storage medium used therefor
KR19990063253A (en) * 1997-12-16 1999-07-26 보토스 알. 제이 Method of forming a merge database and computer controlled telephone switching system using the same

Patent Citations (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JPH05197763A (en) * 1991-08-23 1993-08-06 Internatl Business Mach Corp <Ibm> Method and system for executing join in computor- processing database system
US5497486A (en) * 1994-03-15 1996-03-05 Salvatore J. Stolfo Method of merging large databases in parallel
JPH07253991A (en) * 1994-03-16 1995-10-03 Mitsubishi Electric Corp Join processing system
KR970049768A (en) * 1995-12-21 1997-07-29 이대원 How to build a database
JPH10240753A (en) * 1997-02-26 1998-09-11 Hitachi Ltd Database management system and storage medium used therefor
KR19990063253A (en) * 1997-12-16 1999-07-26 보토스 알. 제이 Method of forming a merge database and computer controlled telephone switching system using the same

Cited By (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR20010099183A (en) * 2001-09-10 2001-11-09 . Data Combination Management System
KR100693370B1 (en) * 2005-08-22 2007-03-09 (주)공영디비엠 Duplicated database merge purge arrangement apparatus and the Method Thereof
KR100984976B1 (en) * 2008-04-08 2010-10-05 한국생명공학연구원 The integrating and searching method of alien 2-dimension table
KR101021064B1 (en) * 2008-05-30 2011-03-11 주식회사 프라임데이타시스템 Method and System of mapping multi-dimensional data to table, and computer readable medium recording the method
KR102299746B1 (en) * 2020-04-20 2021-09-08 최길주 System for automatically processing data of web baed heterogeneous database and method thereof

Similar Documents

Publication Publication Date Title
JP6857689B2 (en) Data retrieval devices, programs, and recording media
Hui et al. Data mining for customer service support
US6263341B1 (en) Information repository system and method including data objects and a relationship object
US7249048B1 (en) Incorporating predicrive models within interactive business analysis processes
US9064224B2 (en) Process driven business intelligence
US6954758B1 (en) Building predictive models within interactive business analysis processes
US6567814B1 (en) Method and apparatus for knowledge discovery in databases
US6820089B2 (en) Method and system for simplifying the use of data mining in domain-specific analytic applications by packaging predefined data mining models
US20090193039A1 (en) Data driven system for data analysis and data mining
US20060129609A1 (en) Database synchronization using change log
Abdirad et al. Artificial intelligence for BIM content management and delivery: Case study of association rule mining for construction detailing
CN112966162A (en) Scientific and technological resource integration method and device based on data warehouse and middleware
KR100877156B1 (en) System and method of access path analysis for dynamic sql before executed
CN104541297A (en) Extensibility for sales predictor (SPE)
KR20030014011A (en) Method and system for automatic combining a different kind of database
Enikeev et al. Software tools and techniques for the expert systems building
US20030145040A1 (en) Database access system and recording medium which records program for controlling the system
Hooda et al. Improve Quality of Data Management and Maintenance in Data Warehouse Systems
US11216486B2 (en) Data retrieval apparatus, program and recording medium
Mandrai et al. A survey of conceptual data mining and applications
Saravanan et al. Data Mining Open Source Tools-Review.
Langer et al. Organizing the Data Ecosystem
Ouared et al. Explainable AI for DBA: Bridging the DBA's experience and machine learning in tuning database systems
Tang et al. Building data mining solutions with SQL Server 2000
JP2003058562A (en) Method for dynamically constructing analysis by utilizing predictive model computer under analysis environment of interactive business

Legal Events

Date Code Title Description
A201 Request for examination
E902 Notification of reason for refusal
E601 Decision to refuse application