KR102453595B1 - 관계형 데이터베이스 보존 방법 및 시스템 - Google Patents
관계형 데이터베이스 보존 방법 및 시스템 Download PDFInfo
- Publication number
- KR102453595B1 KR102453595B1 KR1020200136076A KR20200136076A KR102453595B1 KR 102453595 B1 KR102453595 B1 KR 102453595B1 KR 1020200136076 A KR1020200136076 A KR 1020200136076A KR 20200136076 A KR20200136076 A KR 20200136076A KR 102453595 B1 KR102453595 B1 KR 102453595B1
- Authority
- KR
- South Korea
- Prior art keywords
- relational database
- database
- unit
- tag information
- sql statement
- Prior art date
Links
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F16/00—Information retrieval; Database structures therefor; File system structures therefor
- G06F16/20—Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
- G06F16/21—Design, administration or maintenance of databases
- G06F16/214—Database migration support
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F16/00—Information retrieval; Database structures therefor; File system structures therefor
- G06F16/20—Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
- G06F16/25—Integrating or interfacing systems involving database management systems
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F16/00—Information retrieval; Database structures therefor; File system structures therefor
- G06F16/20—Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
- G06F16/27—Replication, distribution or synchronisation of data between databases or within a distributed database system; Distributed database system architectures therefor
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F16/00—Information retrieval; Database structures therefor; File system structures therefor
- G06F16/20—Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
- G06F16/28—Databases characterised by their database models, e.g. relational or object models
- G06F16/284—Relational databases
Landscapes
- Engineering & Computer Science (AREA)
- Databases & Information Systems (AREA)
- Theoretical Computer Science (AREA)
- Data Mining & Analysis (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Computing Systems (AREA)
- Information Retrieval, Db Structures And Fs Structures Therefor (AREA)
Abstract
본 발명은 관계형 데이터베이스 보존 방법 및 시스템에 관한 것으로서, 제1 관계형 데이터베이스에 저장된 데이터 집합을 제2 관계형 데이터베이스에 저장하되, 상기 제1 관계형 데이터베이스 내 테이블에 대해서는 기설정된 조건을 만족하는 테이블을 XML 파일로 변환하여 상기 제2 관계형 데이터베이스에 저장하고, 링크데이터에 대해서는 해당 물리적 파일의 위치 정보를 상기 제2 관계형 데이터베이스 내 XML 파일에 삽입하여 저장하는 컨트롤러를 포함한다.
Description
본 발명은 데이터베이스 보존 시스템에 관한 것으로, 더욱 상세하게는 제1 관계형 데이터베이스의 데이터 집합을 제2 관계형 데이터베이스에 보존하기 위한 관계형 데이터베이스 보존 방법 및 시스템에 관한 것이다.
현재 대다수의 기업이나 공공기관에서는 상용화 데이터베이스 관리시스템(DataBase Management System, DBMS)을 사용하며, 고가의 사용료 및 유지보수 비용을 지불하고 있다. 이를 사용하는 업체는 상용 DBMS를 보존하기 위해서 다른 상용 DBMS로 전환하거나 오픈소스 DBMS로 전환하여 사용하는 경우가 발생할 수 있다. 예를 들면, 기록물관리 대상인 공공기관의 행정정보시스템의 데이터를 보존할 때 데이터 세트로 보존하도록 되어 있으며, 데이터 세트로 보존하는 방법 중에 SIARD(Software-Independent Archival of Relational Databases)가 주로 이용되고 있다.
한편, SIARD 형식은 2007년부터 스위스 연방 기록 보관소(Swiss Federal Archives)와 전 세계의 다른 많은 기록 보관소에서 관계형 데이터베이스의 장기 보존을 위한 정규화 형식으로 사용되고 있는 방법 중의 하나이다.
SIARD 형식은 아카이브(archive)된 데이터베이스 스키마 정의를 SQL : 2008 준수 XML 파일로 저장하고, 테이블 및 데이터 또한 XML 파일로 저장한다.
여기서, 기존의 SIARD의 경우 DB 사용권한의 모든 테이블을 XML 파일로 저장하지만, 일반적인 행정정보시스템은 모든 데이터를 보존하는 것이 아니라 "공공기록물 관리에 관한 법률 시행령" 별표 1 기록물의 보존기간별 책정기준에 따라 데이터를 선별하여 저장할 수 있어야 한다.
그러나 기존의 SIARD는 DB 내 BLOB, CLOB 형태로 저장된 파일에 대해서는 SIARD 형태로 보존할 수 있으나, 실제 파일을 물리적 스토리지 공간에 저장하고, 그 위치정보만을 저장하도록 하는 일반적인 행정정보시스템의 저장 방식인 DB 내 링크데이터(즉, 패스 저장)에 대해서는 보존할 수 없었다. 즉, 기존의 SIARD는 다양한 DBMS를 지원하는 현재 한국의 중앙부처에서 가장 많이 사용하는 DB인 큐브리드(CUBRID)에 대해서는 지원하지 않는다.
본 명세서는 상기한 바와 같은 문제점을 해결하기 위하여 안출된 것으로서, 데이터베이스 내 링크데이터를 저장할 수 있는 관계형 데이터베이스 보존 방법 및 시스템을 제공하는 데 그 목적이 있다.
본 발명의 다른 목적은 관계형 데이터베이스의 테이블을 선택하여 보존할 수 있는 관계형 데이터베이스 보존 방법 및 시스템을 제공한다.
이와 같은 목적을 달성하기 위한, 본 명세서의 실시예에 따르면, 본 명세서에 따른 관계형 데이터베이스 보존 시스템은, 제1 관계형 데이터베이스에 저장된 데이터 집합을 제2 관계형 데이터베이스에 저장하되, 상기 제1 관계형 데이터베이스 내 테이블에 대해서는 기설정된 조건을 만족하는 테이블을 XML 파일로 변환하여 상기 제2 관계형 데이터베이스에 저장하고, 링크데이터에 대해서는 해당 물리적 파일의 위치 정보를 상기 제2 관계형 데이터베이스 내 XML 파일에 삽입하여 저장하는 컨트롤러를 포함한다.
바람직하게는, 상기 데이터 집합은 데이터베이스 스키마 정의, 테이블, 및 데이터를 포함하는 것을 특징으로 한다.
바람직하게는, 상기 컨트롤러는 상기 링크데이터의 물리적 파일에 대해서 별도의 위치를 지정하여 복사하고, 상기 제2 관계형 데이터베이스 내 XML 파일 내 별도의 컬럼을 생성하여 해당 위치 정보를 저장하는 것을 특징으로 한다.
바람직하게는, 상기 기설정된 조건은 테이블의 보존기한인 것을 특징으로 한다.
바람직하게는, 상기 제2 관계형 데이터베이스는 SIARD(Software-Independent Archival of Relational Databases)인 것을 특징으로 한다.
바람직하게는, 상기 컨트롤러는 상기 제1 관계형 데이터베이스에 접근할 수 있는 제1 SQL(Structured Query Language) 문과 상기 제2 관계형 데이터베이스에 접근할 수 있는 제2 SQL 문 사이의 호환성을 분석하고, 호환이 가능한 경우 상기 제2 SQL 문을 출력하며, 호환이 불가능한 경우 상기 제1 SQL 문으로부터 상기 제2 SQL 문으로의 변환 가이드 데이터를 제공하는 것을 특징으로 한다.
바람직하게는, 상기 컨트롤러는 상기 XML 파일을 파싱하여 테이블을 생성하고, 상기 생성된 테이블에 속성(attribute)을 첨부하며, 상기 속성에 검색 식별 태크 정보를 추가하고, 상기 검색 식별 태그 정보가 추가된 테이블 사이의 관계를 매핑한 후, 매핑된 테이블 사이의 관계를 상기 제2 관계형 데이터베이스에 저장하는 것을 특징으로 한다.
본 명세서의 다른 실시예에 따르면, 본 명세서에 따른 관계형 데이터베이스 보존 방법은, 관계형 데이터베이스 보존 시스템이, 제1 관계형 데이터베이스에 저장된 데이터 집합을 제2 관계형 데이터베이스에 저장하는 단계를 포함하되, 상기 관계형 데이터베이스 보존 시스템은, 상기 제1 관계형 데이터베이스 내 테이블에 대해서는 기설정된 조건을 만족하는 테이블을 XML 파일로 변환하여 상기 제2 관계형 데이터베이스에 저장하고, 링크데이터에 대해서는 해당 물리적 파일의 위치 정보를 상기 제2 관계형 데이터베이스 내 XML 파일에 삽입하여 저장하는 것을 특징으로 한다.
이상에서 설명한 바와 같이 본 명세서에 의하면, 행정정보시스템은 생산, 수집, 가공, 저장, 검색, 제공, 송신 및 수신 등을 위해 조합된 문자, 숫자, 도형, 및 이미지에 대한 데이터세트 보존 방안의 하나로 기존 DB 덤프를 통해 각각의 DBMS에 종속된 형태의 보존만 존재하였으나, 본 발명에 따른 관계형 데이터베이스 보존 시스템을 통해 DBMS에 관계없이 데이터세트를 보존 및 복원 가능하다.
또한, 전체 DB를 보존하지 않고 선별적 보존이 가능하도록 하여 저장공간과 보존할 때의 속도를 개선할 수 있다.
또한, 전자파일의 경우 링크데이터(파일 경로만 기록된 DB)에 대해서도 다른 데이터와 함께 저장할 수 있도록 하여 전자파일 보존 방식을 개선할 수 있다.
도 1은 본 발명의 실시예에 따른 관계형 데이터베이스 보존 시스템의 개략적인 구성을 나타낸 블럭 구성도,
도 2는 본 발명의 실시 형태에 관한 관계형 데이터베이스 보존 시스템의 기능을 실현 가능한 하드웨어의 일례를 도시한 블록도,
도 3은 본 발명의 실시예에 따른 관계형 데이터베이스 보존 방법을 나타낸 흐름도,
도 4는 본 발명의 실시예에 따른 데이터베이스 전환 방법을 나타낸 흐름도,
도 5는 본 발명의 실시예에 따른 XML 기반의 메타데이터를 관계형 데이터베이스로 구성하여 메타데이터를 관리하는 방법을 나타낸 흐름도,
도 6 및 도 7은 본 발명의 실시예에 따른 관계형 데이터베이스 보존 시스템의 링크데이터 저장 방법을 보여주는 예시화면, 및
도 8 및 도 9는 본 발명의 실시예에 따른 관계형 데이터베이스 보존 시스템의 동작 원리를 설명하기 위한 예시화면이다.
도 2는 본 발명의 실시 형태에 관한 관계형 데이터베이스 보존 시스템의 기능을 실현 가능한 하드웨어의 일례를 도시한 블록도,
도 3은 본 발명의 실시예에 따른 관계형 데이터베이스 보존 방법을 나타낸 흐름도,
도 4는 본 발명의 실시예에 따른 데이터베이스 전환 방법을 나타낸 흐름도,
도 5는 본 발명의 실시예에 따른 XML 기반의 메타데이터를 관계형 데이터베이스로 구성하여 메타데이터를 관리하는 방법을 나타낸 흐름도,
도 6 및 도 7은 본 발명의 실시예에 따른 관계형 데이터베이스 보존 시스템의 링크데이터 저장 방법을 보여주는 예시화면, 및
도 8 및 도 9는 본 발명의 실시예에 따른 관계형 데이터베이스 보존 시스템의 동작 원리를 설명하기 위한 예시화면이다.
본 명세서에서 사용되는 기술적 용어는 단지 특정한 실시예를 설명하기 위해 사용된 것으로, 본 발명을 한정하려는 의도가 아님을 유의해야 한다. 또한, 본 명세서에서 사용되는 기술적 용어는 본 명세서에서 특별히 다른 의미로 정의되지 않는 한, 본 발명이 속하는 기술 분야에서 통상의 지식을 가진 자에 의해 일반적으로 이해되는 의미로 해석되어야 하며, 과도하게 포괄적인 의미로 해석되거나, 과도하게 축소된 의미로 해석되지 않아야 한다. 또한, 본 명세서에서 사용되는 기술적인 용어가 본 발명의 사상을 정확하게 표현하지 못하는 잘못된 기술적 용어일 때에는, 당업자가 올바르게 이해할 수 있는 기술적 용어로 대체되어 이해되어야 할 것이다. 또한, 본 발명에서 사용되는 일반적인 용어는 사전에 정의되어 있는 바에 따라, 또는 전후 문맥상에 따라 해석되어야 하며, 과도하게 축소된 의미로 해석되지 않아야 한다.
또한, 본 명세서에서 사용되는 단수의 표현은 문맥상 명백하게 다르게 뜻하지 않는 한, 복수의 표현을 포함한다. 본 출원에서, "구성된다" 또는 "포함한다" 등의 용어는 명세서 상에 기재된 여러 구성 요소들, 또는 여러 단계들을 반드시 모두 포함하는 것으로 해석되지 않아야 하며, 그 중 일부 구성 요소들 또는 일부 단계들은 포함되지 않을 수도 있고, 또는 추가적인 구성 요소 또는 단계들을 더 포함할 수 있는 것으로 해석되어야 한다.
또한, 본 명세서에서 사용되는 구성요소에 대한 접미사 "모듈" 및 "부"는 명세서 작성의 용이함만이 고려되어 부여되거나 혼용되는 것으로서, 그 자체로 서로 구별되는 의미 또는 역할을 갖는 것은 아니다.
또한, 본 명세서에서 사용되는 제1, 제2 등과 같이 서수를 포함하는 용어는 다양한 구성 요소들을 설명하는 데 사용될 수 있지만, 상기 구성 요소들은 상기 용어들에 의해 한정되어서는 안 된다. 상기 용어들은 하나의 구성요소를 다른 구성요소로부터 구별하는 목적으로만 사용된다. 예를 들어, 본 발명의 권리 범위를 벗어나지 않으면서 제1 구성요소는 제2 구성 요소로 명명될 수 있고, 유사하게 제2 구성 요소도 제1 구성 요소로 명명될 수 있다.
우선, 설명에 앞서 SQL(structured query language)에 대해서 설명하자면, SQL은 데이터베이스를 사용할 때, 데이터베이스에 접근할 수 있는 데이터베이스 하부 언어에 대한 것으로, 데이터 정의어(DDL)와 데이터 조작어(DML)를 포함한 데이터베이스용 질의 언어이다. 서로 다른 종류의 관계형 데이터베이스는 서로 완전하게 동일한 SQL을 사용하지는 않으며, 일부의 SQL 문은 동일하고, 일부는 서로 다른 구문을 통해 처리하도록 구성될 수 있다. 이에 따라 제1 관계형 데이터베이스의 제1 SQL 문을 제2 관계형 데이터베이스에 직접 사용하는 경우에는, 차이가 있는 구문으로 인하여 호환이 되지 않는 문제가 발생되며, 본 발명의 관계형 데이터베이스 보존 시스템은 제1 SQL 문을 제2 관계형 데이터베이스에 적용하기 위해 마이그레이션하는 데이터베이스 전환 시스템으로 구성될 수도 있다.
이하, 첨부된 도면을 참조하여 본 발명에 따른 바람직한 실시예를 상세히 설명하되, 도면 부호에 관계없이 동일하거나 유사한 구성 요소는 동일한 참조 번호를 부여하고 이에 대한 중복되는 설명은 생략하기로 한다.
또한, 본 발명을 설명함에 있어서 관련된 공지 기술에 대한 구체적인 설명이 본 발명의 요지를 흐릴 수 있다고 판단되는 경우 그 상세한 설명을 생략한다. 또한, 첨부된 도면은 본 발명의 사상을 쉽게 이해할 수 있도록 하기 위한 것일 뿐, 첨부된 도면에 의해 본 발명의 사상이 제한되는 것으로 해석되어서는 아니됨을 유의해야 한다.
도 1은 본 발명의 실시예에 따른 관계형 데이터베이스 보존 시스템의 개략적인 구성을 나타낸 블럭 구성도이다.
도 1을 참조하면, 본 발명에 따른 관계형 데이터베이스 보존 시스템은 입력부(110), 제1 변환부(120), 및 저장부(130)를 포함할 수 있다. 또한, 관계형 데이터베이스 보존 시스템은 제1 관계형 데이터베이스로부터 제2 관계형 데이터베이스로의 전환이 용이하게 이루어지도록 검증부(140), 제2 변환부(150), 및 출력부(160)를 더 포함할 수 있다. 또한, 관계형 데이터베이스 보존 시스템은 사용자로 하여금 손쉽게 관계형 데이터베이스에 저장된 메타데이터(metadata)를 조회할 수 있도록 테이블 생성부(170), 태그 정보 생성부(180), 매핑부(190), 및 뷰 생성부(200)를 더 포함할 수 있다.
입력부(110)는 제1 관계형 데이터베이스로부터 데이터베이스 스키마 정의, 테이블, 및 데이터를 포함하는 데이터 집합을 수신한다. 또한, 입력부(110)는 사용자 단말기로부터 제1 SQL 문을 포함하는 데이터를 수신할 수 있다.
제1 변환부(120)는 제1 관계형 데이터베이스에 저장된 데이터 집합을 저장부(130), 즉, 제2 관계형 데이터베이스에 저장한다.
여기서, 제1 변환부(120)는 제1 관계형 데이터베이스 내 테이블에 대해서는 기설정된 조건을 만족하는 테이블을 XML 파일로 변환하여 제2 관계형 데이터베이스에 저장한다. 기록물 관리 관점에서 중요한 데이터여서 향후 보존을 위해 보존기간이 30년 이상이 되는 데이터를 보존하는 것으로, 기설정된 기준은 관련 법인 "공공기록물 관리에 관한 법률 시행령" 별표 1 기록물의 보존기간별 책정 기준에 따라 정해질 수 있다.분류된다.
또한, 제1 변환부(120)는 링크데이터에 대해서는 해당 물리적 파일의 위치 정보를 제2 관계형 데이터베이스 내 XML 파일에 삽입하여 저장한다. 즉, 제1 변환부(120)는 링크데이터의 물리적 파일에 대해서 별도의 위치를 지정하여 복사하고, 제2 관계형 데이터베이스 내 XML 파일 내 별도의 컬럼을 생성하여 해당 위치 정보를 저장할 수 있다. 이때, 제1 변환부(120)는 링크데이터의 물리적 파일을 별도의 위치에 압축하여 저장할 수 있다.
저장부(130)는 제2 관계형 데이터베이스로서, 제1 변환부(120)에 의해 변환된 데이터 집합을 저장한다. 여기서, 저장부(130)는 관계형 데이터베이스 보존 시스템 외부에 별도의 장치로 마련될 수 있다.
검증부(140)는 입력부(110)에 입력된 제1 SQL 문을 포함하는 데이터를 제2 관계형 데이터베이스의 제2 SQL 문과 매칭시켜 검증을 수행할 수 있다. 이때, 검증부(140)는 저장부(130)에 기저장된 데이터를 활용할 수 있는데, 이를 위해, 제1 SQL 문에서 사용되는 구문과 이에 매칭되는 제2 SQL 문이 서로 연관되어 저장부(130)에 미리 저장될 수 있다.
이를 위해, 저장부(130)는 데이터를 다음과 같이 분류하여 저장할 수 있다. 즉, 저장부(130)는 제1 SQL 문과 제2 SQL 문에 서로 동일하게 사용되는 구문에 대해서는 표준타입으로, 제1 SQL 문과 제2 SQL 문에 서로 다르게 사용되는 구문에 대해서는 고유타입으로 분류될 수 있다. 여기서, 고유타입은 제1 SQL 문의 A1 구문이 제2 SQL 문의 B1 구문과 연관되어 기저장된 것으로, 검증부(140)의 검증과정에서 A1 구문에 해당되는 구문이 매핑되면 B1 구문으로 자동 변환이 이루어지도록 구성될 수 있다.
출력부(160)는 앞서 A1 구문에서 B1 구문으로 자동 변환이 이루어진 데이터 또는 변환 가이드 데이터를 출력할 수 있다. 여기서, 변환 가이드 데이터는 A2 구문이 제2 관계형 데이터베이스에서 지원하지 않는 구문인 것을 가이드하거나, A2 구문을 그대로 사용할 시에 나타나는 문제점에 대해서 안내 후에 이와 유사한 제2 SQL 문의 B2 구문으로의 사용을 권장하는 정보를 표출하는 등 다양한 형태로 제공될 수 있다. 이때, 변환 가이드 데이터는 사용자가 더욱 손쉽게 활용할 수 있도록 PDF 등의 형태로 제공될 수 있다. 이에 따라, 본 발명에 따른 관계형 데이터베이스 보존 시스템은 제1 SQL 문의 A2 구문에 대해서 직접적으로 연관된 제2 SQL 문의 구문이 없는 경우에 변환 가이드 데이터를 제공할 수 있다.
테이블 생성부(170)는 저장부(130)에 저장된 XML 파일, 즉, XML 문서를 파싱하여 XML 문서의 각 엘리먼트(element)들을 테이블 형태로 변환한다.
이를 위해, 테이블 생성부(170)는 XML 문서를 파싱하는 파서(parser)(172)를 포함할 수 있다.
파서(172)는 XML 문서를 해독한다. XML 문서의 엘리먼트(element)는 계층 구조로 형성되어 있기 때문에, XML 문서는 모든 정보를 포함하는 트리 및 테이블의 형태로 나타내어 질 수 있다. 서브 엘리먼트(element)는 상위 엘리먼트(element)의 서브 노드로 나타내며 속성(attribute) 또한 속성이 정의된 엘리먼트(element)의 서브 노드로 인식될 수 있다.
파서(172)에는 트리 기반의 DOM(Document Object Model) 파서와 이벤트 기반의 SAX(Simple API for XML)가 있으며, DOM 파서는 XML의 구조와 정보로의 접근을 용이하게 하고, 그것의 조작을 가능하게 하는 표준 인터페이스를 제공하며, XML 문서를 계층적인 노드의 형태로 파싱할 수 있다.
반면에 SAX 파서는 XML 문서를 처리하기 위해 각각의 엘리먼트(element)에 대한 이벤트를 발생시켜 문서를 해석하는 파서를 의미하는 것이다.
도 1을 참조하면 파서(172)는 테이블 생성부(170)의 일 구성요소인 것으로 도시되었으나, 파서(172)는 XML 문서를 파싱할 수 있으면 그 종류는 무관하고, 테이블 생성부(170)와는 별개의 구성 요소일 수 있다.
태그 정보 생성부(180)는 테이블 생성부(170)에서 생성된 테이블에 소정의 검색 식별 태그 정보를 추가한다. 검색 식별 태그 정보는 사용자가 더욱 수월하게 제2 관계형 데이터베이스에 저장된 메타데이터를 조회할 수 있도록 하기 위한 정보로서, 태그 정보 생성부(180)에서 생성하여 테이블에 추가시킨다.
검색 식별 태그 정보는 사용자가 조회하고자 하는 메타데이터의 유형에 따라 제1 태그 정보, 제2 태그 정보 및 제3 태그 정보 등과 같이 그 종류를 달리할 수 있다. 각각의 태그 정보는 조회하고자 하는 메타데이터의 유형을 달리함을 나타내는 것이다.
예를 들어 발명의 이해 및 설명의 편의를 위해 사용자가 조회하고자 하는 메타데이터의 유형이 제2 관계형 데이터베이스에 저장된 물리적인 메타데이터, 제2 관계형 데이터베이스에서 가공된 메타데이터 및 리포트 생성자에게 직접적으로 표출되는 메타데이터의 3가지 유형이 있다고 가정한다.
즉, 상기 예에서 물리적인 메타데이터는 제2 관계형 데이터베이스에 저장될 때 아무런 가공 없이 그대로 저장된 메타데이터를 의미하는 것으로서, 엔티티(entity)명, 속성(attribute)명, 테이블(table)명, 컬럼(column)명, 및 테이블 간 연결(join)정보 등을 포함할 수 있다.
또한, 가공된 메타데이터는 제2 관계형 데이터베이스에 저장될 때 소정의 방법으로 가공된 메타데이터로서, 계산식 또는 물리적인 메타데이터와 가공된 메타데이터의 연결(join)정보 등을 포함할 수 있다.
또한, 리포트 생성자에게 직접적으로 표출되는 메타데이터는 메타데이터의 크기(Dimension) 정보, 측정 (Measure)정보, 필터(Filter) 정보 및 이들과 연결된 물리적인 테이블과 컬럼 정보 등을 포함할 수 있다.
상기 예와 같이 사용자가 조회하고자 하는 메타데이터의 유형에 따라 메타데이터를 포함하는 테이블들을 매핑하고, 이를 조회할 수 있는 프레임 정보를 미리 저장하면 사용자가 더욱 손쉽게 특정 유형의 메타데이터를 조회할 수 있다는 장점이 있다.
본 발명의 실시예에 따른 검색 식별 태그 정보를 테이블에 추가하는 방법은, XML 문서가 변환된 테이블에 새로운 속성을 첨부하고, 첨부된 속성에 검색 식별 태그 정보 값을 삽입하여 생성할 수 있다.
테이블에 첨부된 속성은 검색 식별 태그 정보가 삽입될 장소로서 속성을 첨부하는 방법은 다양한 방법으로 변경하여 실시가 가능하다. 예를 들면, 테이블에 필드(field)를 하나 추가하는 방법으로 구현될 수 있으며, 테이블에 연결 리스트(linked list)를 연결하여 구현될 수 있다.
상기와 같이 첨부된 속성에 검색 식별 태그 정보 값을 삽입하여 사용자가 메타데이터 조회시 해당 검색 식별 태그 정보를 선택하는 경우 선택된 검색 식별 태그 정보에 상응하는 테이블에 저장된 메타데이터를 사용자에게 제공할 수 있다.
또한, 뷰 생성부(200)는 태그 정보 생성부(180)에서 삽입된 검색 식별 태그 정보를 이용하여 제2 관계형 데이터베이스에 저장된 메타데이터를 조회하기 위한 조회화면을 생성할 수 있다. 뷰 생성부(200)가 조회화면을 생성하는 방법에 대해서는 후술하기로 한다.
매핑부(190)는 태그 정보 생성부(180)에서 검색 식별 태그 정보가 추가된 테이블 사이의 관계를 매핑한다. XML 문서를 파싱하면 복수 개의 테이블이 생성될 것이고 각 테이블에는 태그 정보 생성부(180)에서 추가된 소정의 검색 식별 태그 정보 값이 첨부되어 있다. 매핑부(190)는 검색 식별 태그 정보별로 그룹핑(grouping) 및 매핑(mapping)하여 각 테이블 간의 관계를 설정한다.
매핑하는 방법에 대해서는 다양한 방법으로 관련 분야의 통상의 지식을 가진 자에게 용이하게 변경 실시가 가능하다. 일 실시예로서, 메타데이터의 동일한 엘리먼트(element)끼리 연결하여 조회화면 구성시 같은 프레임에 구성되도록 할 수 있다.
즉, 매핑부(190)는 태그 정보 생성부(180)에서 추가된 검색 식별 태그 정보를 기준으로 동일한 검색 식별 태그 정보를 갖는 테이블끼리 매핑할 수 있다. 이와 같이 매핑하게 되는 경우 사용자가 특정 쿼리를 통해 조회를 요청하는 경우 매핑된 엘리먼트(element)들의 메타데이터를 사용자에게 제공할 수 있어 사용자는 더욱 손쉽게 관계형 데이터베이스에 저장된 메타데이터를 조회할 수 있다.
뷰 생성부(200)는 제2 관계형 데이터베이스에 저장된 메타데이터를 조회하기 위한 조회화면을 생성한다.
종래에는 사용자가 원하는 메타데이터를 조회하기 위해서 여러 단계를 거치거나 특정 항목을 조회하기 위하여 복잡한 구성의 폴더를 일일이 클릭하여 찾아야 한다는 문제점이 있었다.
뷰 생성부(200)는 테이블을 제2 관계형 데이터베이스에 저장하기 전에 검색 식별 태그 정보별로 고유한 조회화면을 생성한다. 뷰 생성부(200)가 조회화면을 생성하는 방법은 다양한 방법으로 변경실시 가능하다.
본 발명에 따른 뷰 생성부(200)는 조회화면을 구성하는 프레임 정보를 생성하고, 생성된 프레임에 테이블을 연결하여 조회화면을 구성할 수 있다.
설명 및 이해의 편의를 위해 예를 들어 설명하면, 검색 식별 태그 정보를 'A'라고 가정하고, 'A'와 관련된 메타데이터를 조회하기 위한 조회화면을 구성한다고 가정한다.
이 경우 뷰 생성부(200)는 'A'와 관련된 메타데이터를 조회하기 위한 프레임 정보를 생성하고, 'A' 검색 식별 태그 정보를 가진 테이블을 연결시키는 방법으로 조회화면을 구성할 수 있다. 즉, 'A'와 관련된 메타데이터를 조회하기 위해 구성하는 프레임 중 특정 공간에 'A' 검색 식별 태그 정보를 가진 테이블의 메타데이터가 출력될 수 있도록 상호간에 연결시키는 방법으로 구성될 수 있다.
이를 위해, 제2 관계형 데이터베이스에 해당되는 저장부(130)는 매핑부(190)에서 매핑된 테이블 사이의 관계를 저장할 수 있다. 또한, 저장부(130)는 뷰 생성부(200)에서 생성한 프레임 정보를 저장할 수 있다.
종래에는 XML 문서를 파싱하여 생성된 테이블 또는 트리 객체를 관계형 데이터베이스에 저장하여 사용자에게 제공하였기 때문에 사용자가 특정 메타데이터를 조회하는 데 매우 복잡한 절차를 거쳐야 한다는 문제점이 있었다. 제2 관계형 데이터베이스에 조회화면 구성을 위한 프레임 정보를 미리 저장해 두는 경우, 사용자에게 더욱 수월하게 메타데이터를 검색할 수 있는 조회화면을 제공할 수 있다는 장점이 있다.
도 2를 참조하면, 관계형 데이터베이스 보존 시스템의 기능을 실현 가능한 하드웨어에 대해서 설명한다. 도 2는 본 발명의 실시 형태에 관한 관계형 데이터베이스 보존 시스템의 기능을 실현 가능한 하드웨어의 일례를 도시한 블록도이다.
관계형 데이터베이스 보존 시스템이 갖는 기능은, 예컨대, 도 2에 도시하는 하드웨어 자원을 이용하여 실현하는 것이 가능하다. 즉, 관계형 데이터베이스 보존 시스템이 갖는 기능은, 컴퓨터 프로그램을 이용하여 도 2에 도시하는 하드웨어를 제어함으로써 실현된다.
도 2에 도시한 바와 같이, 이 하드웨어는, 주로, CPU(202), ROM(Read Only Memory)(204), RAM(206), 호스트 버스(208), 및 브리지(210)를 갖는다. 또한, 이 하드웨어는, 외부 버스(212), 인터페이스(214), 입력부(216), 출력부(218), 기억부(220), 드라이브(222), 접속 포트(224), 및 통신부(226)를 갖는다.
CPU(202)는, 예컨대, 연산 처리 장치 또는 제어 장치로서 기능하여, ROM(204), RAM(206), 기억부(220), 또는 리무버블 기록 매체(228)에 기록된 각종 프로그램에 기초하여 각 구성 요소의 동작 전반 또는 그 일부를 제어한다. ROM(204)은, CPU(202)에 판독되는 프로그램이나 연산에 이용하는 데이터 등을 저장하는 기억 장치의 일례이다. RAM(206)에는, 예컨대, CPU(202)에 판독되는 프로그램이나, 그 프로그램을 실행할 때 변화하는 각종 파라미터 등이 일시적 또는 영속적으로 저장된다.
이들 요소는, 예컨대, 고속의 데이터 전송이 가능한 호스트 버스(208)를 통해서 서로 접속된다. 한편, 호스트 버스(208)는, 예컨대, 브리지(210)를 통해서 비교적 데이터 전송 속도가 저속인 외부 버스(212)에 접속된다. 또한, 입력부(216)로서는, 예컨대, 마우스, 키보드, 터치 패널, 터치 패드, 버튼, 스위치, 및 레버 등이 이용된다. 또한, 입력부(216)로서는, 적외선이나 그 밖의 전파를 이용하여 제어 신호를 송신하는 것이 가능한 리모트 컨트롤러가 이용될 수 있다.
출력부(218)로서는, 예컨대, CRT(Cathode Ray Tube), LCD(Liquid Crystal Display), PDP(Plasma Display Panel), 또는 ELD(Electro-Luminescence Display) 등의 디스플레이 장치가 이용될 수 있다. 또한, 출력부(218)로서, 스피커나 헤드폰 등의 오디오 출력 장치, 또는 프린터 등이 이용될 수 있다.
기억부(220)는, 각종 데이터를 저장하기 위한 장치이다. 기억부(220)로서는, 예컨대, HDD 등의 자기 기억 디바이스가 이용된다. 또한, 기억부(220)로서, SSD(Solid State Drive)나 RAM 디스크 등의 반도체 기억 디바이스, 광기억 디바이스, 또는 광자기 기억 디바이스 등이 이용되어도 된다.
드라이브(222)는, 착탈 가능한 기록매체인 리무버블 기록 매체(228)에 기록된 정보를 판독하거나, 또는 리무버블 기록 매체(228)에 정보를 기록하는 장치이다. 리무버블 기록 매체(228)로서는, 예컨대, 자기 디스크, 광디스크, 광자기 디스크, 또는 반도체 메모리 등이 이용된다. 또한, 리무버블 기록 매체(228)에는, 관계형 데이터베이스 보존 시스템의 동작을 규정하는 프로그램이 저장될 수 있다.
접속 포트(224)는, 예컨대, USB(Universal Serial Bus) 포트, IEEE 1394 포트, SCSI(Small Computer System Interface), RS-232C 포트, 또는 광오디오 단자 등, 외부 접속 기기(230)를 접속하기 위한 포트이다. 외부 접속 기기(230)로서는, 예컨대, 프린터 등이 이용된다.
통신부(226)는, 네트워크(232)에 접속하기 위한 통신 디바이스이다. 통신부(226)로서는, 예컨대, 유선 또는 무선 LAN용 통신 회로, WUSB(Wireless USB)용 통신 회로, 휴대 전화 네트워크용 통신 회로 등이 이용될 수 있다. 네트워크(232)는, 예컨대, 유선 또는 무선에 의해 접속된 네트워크이다.
이상, 관계형 데이터베이스 보존 시스템의 하드웨어에 대해서 설명하였다. 또한, 상술한 하드웨어는 일례이며, 일부의 요소를 생략하는 변형이나, 새로운 요소를 추가하는 변형 등이 가능하다.
도 3은 본 발명의 실시예에 따른 관계형 데이터베이스 보존 방법을 나타낸 흐름도이다.
도 3을 참조하면, 관계형 데이터베이스 보존 시스템은 제1 관계형 데이터베이스에 저장된 데이터 집합을 제2 관계형 데이터베이스에 저장한다(S310). 이때, 관계형 데이터베이스 보존 시스템은 제1 관계형 데이터베이스 내 테이블에 대해서는 기설정된 조건을 만족하는 테이블을 XML 파일로 변환하여 제2 관계형 데이터베이스에 저장하고, 링크데이터에 대해서는 해당 물리적 파일의 위치 정보를 제2 관계형 데이터베이스 내 XML 파일에 삽입하여 저장할 수 있다.
도 4는 본 발명의 실시예에 따른 데이터베이스 전환 방법을 나타낸 흐름도이다.
도 4를 참조하면, 관계형 데이터베이스 보존 시스템은 제1 SQL 문을 수신한다(S410).
관계형 데이터베이스 보존 시스템은 수신한 제1 SQL 문을 매핑시킴으로써 검증을 수행한다(S420).
관계형 데이터베이스 보존 시스템은 매핑된 데이터에 대해서는 표준타입과 고유타입으로 분류하여 처리하되, 매핑되지 않은 데이터에 대해서는 기입력된 변환 가이드 데이터를 참조한다(S430).
관계형 데이터베이스 보존 시스템은 단계 S430의 결과를 출력한다(S440). 즉, 관계형 데이터베이스 보존 시스템은 제1 SQL 문의 고유타입에서 제2 SQL 문의 고유타입으로의 변환, 매핑되지 않은 데이터에 대한 변환 가이드 데이터 제공 및 매핑되지 않은 데이터에 대한 정보 제공 중에 선택되는 하나 이상을 출력할 수 있다.
도 5는 본 발명의 실시예에 따른 XML 기반의 메타데이터를 관계형 데이터베이스로 구성하여 메타데이터를 관리하는 방법을 나타낸 흐름도이다.
도 5를 참조하면, 테이블 생성부(170)는 XML 문서를 파싱하여 테이블을 생성한다(S510). XML 문서를 파싱하기 위해 테이블 생성부(170)는 파서(172)를 포함할 수 있으며, 파서(172)는 DOM 파서 또는 SAX 파서가 이용될 수 있음은 상기에서 설명한 바 있으므로 이에 대한 상세한 설명은 생략하기로 한다.
이후, 단계 S510에서 생성된 테이블에 소정의 검색 식별 태그 정보를 추가한다(S520). 검색 식별 태그 정보는 제2 관계형 데이터베이스에 저장된 메타데이터를 조회하기 위한 프레임 정보를 생성하고, 동일한 검색 식별 태그 정보를 갖는 테이블 사이의 관계를 매핑하기 위한 것은 상기에서 설명한 바와 같다.
검색 식별 태그 정보를 추가하는 방법으로 단계 S510에서 생성된 테이블에 속성을 첨부하고, 첨부된 속성에 검색 식별 태그 정보 값을 삽입함으로써 검색 식별 태그 정보를 추가할 수 있다. 검색 식별 태그 정보를 추가하는 방법은 이 외에도 다양한 방법으로 용이하게 변경 실시 가능하다.
이어서, 매핑부(190)는 테이블 사이의 관계를 매핑한다(S530). 테이블 사이의 매핑은 단계 S520에서 추가된 검색 식별 태그 정보를 이용하여 동일한 검색 식별 태그 정보를 갖는 테이블을 그룹핑(grouping)하는 형식으로 매핑할 수 있다.
이후 검색 식별 태그 정보별로 고유한 프레임 정보를 생성한다(S540). 검색 식별 태그 정보별로 조회화면의 구성의 상이함은 상기에서 설명한 바와 같으며, 검색 식별 태그 정보별로 다른 조회화면을 구성하는 프레임 정보를 미리 제2 관계형 데이터베이스에 저장함으로써, 사용자가 더욱 수월하게 메타데이터를 조회할 수 있는 장점이 있다.
이후, 단계 S520에서 검색 식별 태그 정보가 추가된 테이블, 단계 S530에서 매핑된 테이블 사이의 관계 정보 및 단계 S540에서 생성된 검색 식별 태그 정보별로 고유한 조회화면을 구성하는 프레임 정보를 제2 관계형 데이터베이스에 저장한다(S550).
전술한 방법은 다양한 수단을 통해 구현될 수 있다. 예를 들어, 본 발명의 실시예들은 하드웨어, 펌웨어(Firmware), 소프트웨어 또는 그것들의 결합 등에 의해 구현될 수 있다.
하드웨어에 의한 구현의 경우, 본 발명의 실시예들에 따른 방법은 하나 또는 그 이상의 ASICs(Application Specific Integrated Circuits), DSPs(Digital Signal Processors), DSPDs(Digital Signal Processing Devices), PLDs(Programmable Logic Devices), FPGAs(Field Programmable Gate Arrays), 프로세서, 컨트롤러, 마이크로컨트롤러 및 마이크로프로세서 등에 의해 구현될 수 있다.
펌웨어나 소프트웨어에 의한 구현의 경우, 본 발명의 실시예들에 따른 방법은 이상에서 설명된 기능 또는 동작들을 수행하는 모듈, 절차 또는 함수 등의 형태로 구현될 수 있다. 소프트웨어 코드는 메모리 유닛에 저장되어 프로세서에 의해 구동될 수 있다. 상기 메모리 유닛은 상기 프로세서 내부 또는 외부에 위치하여, 이미 공지된 다양한 수단에 의해 상기 프로세서와 데이터를 주고 받을 수 있다.
도 6 및 도 7은 본 발명의 실시예에 따른 관계형 데이터베이스 보존 시스템의 링크데이터 저장 방법을 보여주는 예시화면이다.
일반적인 제1 관계형 데이터베이스, 예컨대, 행정정보시스템은 실제 물리적 파일을 데이터베이스 내에 LOB 형태로 저장하면 데이터베이스 사이즈가 커져 관리가 어려워지기 때문에 실제 파일을 별도의 물리적 스토리지 공간에 저장하고, 데이터베이스에는 그 위치정보만을 저장한다.
이에, 본 발명에 따른 관계형 데이터베이스 보존 시스템은 도 6에 도시된 바와 같이, 제1 관계형 데이터베이스 내에 위치 정보만 존재하는 경우, 링크데이터에 대해서는 해당 물리적 파일의 위치 정보를 제2 관계형 데이터베이스 내 XML 파일에 삽입하여 저장할 수 있다. 즉, 관계형 데이터베이스 보존 시스템은 제2 관계형 데이터베이스 내 XML 파일 내 별도의 컬럼을 생성하여 해당 위치 정보를 저장한다.
또한, 관계형 데이터베이스 보존 시스템은 링크데이터의 물리적 파일에 대해서는 도 7에 도시된 바와 같이, 별도의 위치(710)를 지정하여 복사한다. 이때, 관계형 데이터베이스 보존 시스템은 링크데이터의 물리적 파일을 별도의 위치(710)에 압축하여 저장할 수 있다.
도 8 및 도 9는 본 발명의 실시예에 따른 관계형 데이터베이스 보존 시스템의 동작 원리를 설명하기 위한 예시화면이다.
사용자는 실행 창에서 설치 폴더로 이동한다.
사용자는 배치 파일(siardgui.bat)을 실행한다.
실행 로그가 출력되고 인터페이스 화면(Siard GUI)이 출력된다.
사용자는 도 8의 인터페이스 화면에서 File의 Download 메뉴를 실행시킨다.
사용자는 도 9의 창 화면에서 1. 데이터베이스를 선택한다. 2. 데이터베이스의 서버 위치를 입력한다. (IP Address) 3. 데이터베이스 이름(Database name)을 입력한다. 4. JDBC URL for database connection을 입력한다. 5. 다운로드할 데이터베이스 계정을 입력한다. 6. 다운로드할 데이터베이스 계정의 암호를 입력한다. 7. 파일 다운로드 방식을 선택한다. (파일 다운로드 방식은 2가지가 있다. 네트워크를 선택하면 sftp로 접속하여 파일을 다운로드한다. sftp 접속정보는 설치폴더/etc/sftp.properties에 명시되어 있다. 다운로드하는 파일들은 각 테이블에서 ORG_PATH 컬럼에 정의되어 있어야 한다.) 8. 저장 위치를 기입한다. (각 테이블의 ORG_PATH에 명시된 경로에 의해서 파일들을 이 위치로 복사한다. 파일 다운로드 방식에서 폴더 복사를 선택하면 이 항목을 명시해야 한다.) 9. 테이블 목록(데이터 베이스에 접속하여 원하는 테이블만 다운로드할 수 있도록 테이블을 선택할 수 있다.)
끝으로, 사용자는 위와 같이 설정하고 OK 버튼을 누른다.
이상에서 본 명세서에 개시된 실시예들을 첨부된 도면들을 참조로 설명하였다. 이와 같이 각 도면에 도시된 실시예들은 한정적으로 해석되면 아니되며, 본 명세서의 내용을 숙지한 당업자에 의해 서로 조합될 수 있고, 조합될 경우 일부 구성 요소들은 생략될 수도 있는 것으로 해석될 수 있다.
여기서, 본 명세서 및 청구범위에 사용된 용어나 단어는 통상적이거나 사전적인 의미로 한정해서 해석되어서는 아니 되며, 본 명세서에 개시된 기술적 사상에 부합하는 의미와 개념으로 해석되어야만 한다.
따라서 본 명세서에 기재된 실시예와 도면에 도시된 구성은 본 명세서에 개시된 실시예에 불과할 뿐이고, 본 명세서에 개시된 기술적 사상을 모두 대변하는 것은 아니므로, 본 출원시점에 있어서 이들을 대체할 수 있는 다양한 균등물과 변형예들이 있을 수 있음을 이해하여야 한다.
110: 입력부 120: 제1 변환부
130: 저장부 140: 검증부
150: 제2 변환부 160: 출력부
170: 테이블 생성부 172: 파서
180: 태그 정보 생성부 190: 매핑부
200: 뷰 생성부
130: 저장부 140: 검증부
150: 제2 변환부 160: 출력부
170: 테이블 생성부 172: 파서
180: 태그 정보 생성부 190: 매핑부
200: 뷰 생성부
Claims (12)
- 공공기관의 기록물관리 대상인 행정정보시스템의 데이터를 기록물의 보존기간별 책정기준에 따라 데이터를 선별하여 보존하기 위한 관계형 데이터베이스 보존 시스템에 있어서,
상기 관계형 데이터베이스 보존 시스템은 생산, 수집, 가공, 저장, 검색, 제공, 송신 및 수신을 위해 조합된 문자, 숫자, 도형 및 이미지에 대한 데이터세트 보존 방안으로 데이터베이스 덤프를 통해 각각의 DBMS에 종속된 형태의 보존 외에, DBMS에 관계없이 데이터세트를 보존 및 복원하고, 또한, 전체 데이터베이스 중 일부를 선별적으로 보전하기 위한 것으로,
제1 관계형 데이터베이스에 저장된 데이터 집합을 제2 관계형 데이터베이스에 저장하되, 상기 제1 관계형 데이터베이스 내 테이블에 대해서는 기설정된 조건을 만족하는 테이블을 XML 파일로 변환하여 상기 제2 관계형 데이터베이스에 저장하고, 링크데이터에 대해서는 해당 물리적 파일의 위치 정보를 상기 제2 관계형 데이터베이스 내 XML 파일에 삽입하여 저장하는 컨트롤러;
를 포함하는 관계형 데이터베이스 보존 시스템이되,
상기 데이터 집합은 데이터베이스 스키마 정의, 테이블, 및 데이터를 포함하고,
상기 컨트롤러는 상기 링크데이터의 물리적 파일에 대해서 별도의 위치를 지정하여 복사하고, 상기 제2 관계형 데이터베이스 내 XML 파일 내 별도의 컬럼을 생성하여 해당 위치 정보를 저장하고,
상기 기설정된 조건은 테이블의 보존기한이고,
상기 제2 관계형 데이터베이스는 SIARD(Software-Independent Archival of Relational Databases)이고,
상기 컨트롤러는 상기 제1 관계형 데이터베이스에 접근할 수 있는 제1 SQL(Structured Query Language) 문과 상기 제2 관계형 데이터베이스에 접근할 수 있는 제2 SQL 문 사이의 호환성을 분석하고, 호환이 가능한 경우 상기 제2 SQL 문을 출력하며, 호환이 불가능한 경우 상기 제1 SQL 문으로부터 상기 제2 SQL 문으로의 변환 가이드 데이터를 제공하고,
상기 컨트롤러는 상기 XML 파일을 파싱하여 테이블을 생성하고, 상기 생성된 테이블에 속성(attribute)을 첨부하며, 상기 속성에 검색 식별 태그 정보를 추가하고, 상기 검색 식별 태그 정보가 추가된 테이블 사이의 관계를 매핑한 후, 매핑된 테이블 사이의 관계를 상기 제2 관계형 데이터베이스에 저장하고,
상기 관계형 데이터베이스 보존 시스템은 입력부, 제1 변환부, 검증부 및 저장부를 포함하되,
상기 입력부는 상기 제1 관계형 데이터베이스로부터 데이터 집합을 수신하고, 사용자 단말기로부터 제1 SQL 문을 포함하는 데이터를 수신하고,
상기 제1 변환부는 상기 기설정된 기준인 관련 법인 "공공기록물 관리에 관한 법률 시행령" 별표 1 기록물의 보존기간별 책정 기준에 따라 테이블을 XML 파일로 변환하여 제2 관계형 데이터베이스에 저장하고, 링크데이터의 물리적 파일을 별도의 위치에 압축하여 저장하고,
상기 검증부는 상기 입력부에 입력된 제1 SQL 문을 포함하는 데이터를 제2 관계형 데이터베이스의 제2 SQL 문과 매칭시켜 검증을 수행하고,
상기 저장부는 제2 관계형 데이터베이스로서, 제1 변환부에 의해 변환된 데이터 집합을 저장하되, 상기 저장부는 제1 SQL 문과 제2 SQL 문에 서로 동일하게 사용되는 구문에 대해서는 표준타입으로, 제1 SQL 문과 제2 SQL 문에 서로 다르게 사용되는 구문에 대해서는 고유타입으로 분류하고,
또한, 상기 관계형 데이터베이스 보존 시스템은 사용자로 하여금 손쉽게 관계형 데이터베이스에 저장된 메타데이터를 조회할 수 있도록 테이블 생성부, 태그 정보 생성부, 매핑부, 및 뷰 생성부를 포함하되,
상기 테이블 생성부는 XML 문서를 파싱하는 파서(parser)를 포함하여 상기 저장부에 저장된 XML 파일을 파싱하여 XML 문서의 각 엘리먼트(element)들을 테이블 형태로 변환하고,
상기 태그 정보 생성부는 상기 테이블 생성부에서 생성된 테이블에 사용자가 수월하게 제2 관계형 데이터베이스에 저장된 메타데이터를 조회할 수 있도록 하기 위한 정보인 검색 식별 태그 정보를 추가하고,
상기 매핑부는 상기 태그 정보 생성부에서 추가된 검색 식별 태그 정보를 기준으로 동일한 검색 식별 태그 정보를 갖는 테이블끼리 매핑하고,
상기 뷰 생성부는 상기 태그 정보 생성부에서 삽입된 검색 식별 태그 정보를 이용하여 제2 관계형 데이터베이스에 저장된 메타데이터를 조회하기 위한 조회화면을 생성하고,
상기 제1 관계형 데이터베이스는 행정정보시스템의 데이터베이스이고,
상기 관계형 데이터베이스 보존 시스템은 사용자로부터 데이터베이스의 선택, 상기 데이터베이스의 서버 위치, 상기 데이터베이스의 이름, 다운로드할 데이터베이스 계정의 암호, 파일 다운로드 방식, 파일 저장 위치, 데이터 베이스 중 원하는 테이블을 다운로드 받을 수 있는 테이블 목록을 입력받을 수 있는 창을 출력하는 것을 특징으로 하는 관계형 데이터베이스 보존 시스템.
- 삭제
- 삭제
- 삭제
- 삭제
- 삭제
- 삭제
- 공공기관의 기록물관리 대상인 행정정보시스템의 데이터를 기록물의 보존기간별 책정기준에 따라 데이터를 선별하여 보존하기 위한 관계형 데이터베이스 보존 시스템에 있어서,
상기 관계형 데이터베이스 보존 시스템은 생산, 수집, 가공, 저장, 검색, 제공, 송신 및 수신을 위해 조합된 문자, 숫자, 도형 및 이미지에 대한 데이터세트 보존 방안으로 데이터베이스 덤프를 통해 각각의 DBMS에 종속된 형태의 보존 외에, DBMS에 관계없이 데이터세트를 보존 및 복원하고, 또한, 전체 데이터베이스 중 일부를 선별적으로 보전하기 위한 것으로,
제1 관계형 데이터베이스에 저장된 데이터 집합을 제2 관계형 데이터베이스에 저장하되, 상기 제1 관계형 데이터베이스 내 테이블에 대해서는 기설정된 조건을 만족하는 테이블을 XML 파일로 변환하여 상기 제2 관계형 데이터베이스에 저장하고, 링크데이터에 대해서는 해당 물리적 파일의 위치 정보를 상기 제2 관계형 데이터베이스 내 XML 파일에 삽입하여 저장하는 컨트롤러;
를 포함하는 관계형 데이터베이스 보존 시스템이되,
상기 데이터 집합은 데이터베이스 스키마 정의, 테이블, 및 데이터를 포함하고,
상기 컨트롤러는 상기 링크데이터의 물리적 파일에 대해서 별도의 위치를 지정하여 복사하고, 상기 제2 관계형 데이터베이스 내 XML 파일 내 별도의 컬럼을 생성하여 해당 위치 정보를 저장하고,
상기 기설정된 조건은 테이블의 보존기한이고,
상기 제2 관계형 데이터베이스는 SIARD(Software-Independent Archival of Relational Databases)이고,
상기 컨트롤러는 상기 제1 관계형 데이터베이스에 접근할 수 있는 제1 SQL(Structured Query Language) 문과 상기 제2 관계형 데이터베이스에 접근할 수 있는 제2 SQL 문 사이의 호환성을 분석하고, 호환이 가능한 경우 상기 제2 SQL 문을 출력하며, 호환이 불가능한 경우 상기 제1 SQL 문으로부터 상기 제2 SQL 문으로의 변환 가이드 데이터를 제공하고,
상기 컨트롤러는 상기 XML 파일을 파싱하여 테이블을 생성하고, 상기 생성된 테이블에 속성(attribute)을 첨부하며, 상기 속성에 검색 식별 태그 정보를 추가하고, 상기 검색 식별 태그 정보가 추가된 테이블 사이의 관계를 매핑한 후, 매핑된 테이블 사이의 관계를 상기 제2 관계형 데이터베이스에 저장하고,
상기 관계형 데이터베이스 보존 시스템은 입력부, 제1 변환부, 검증부 및 저장부를 포함하되,
상기 입력부는 상기 제1 관계형 데이터베이스로부터 데이터 집합을 수신하고, 사용자 단말기로부터 제1 SQL 문을 포함하는 데이터를 수신하고,
상기 제1 변환부는 상기 기설정된 기준인 관련 법인 "공공기록물 관리에 관한 법률 시행령" 별표 1 기록물의 보존기간별 책정 기준에 따라 테이블을 XML 파일로 변환하여 제2 관계형 데이터베이스에 저장하고, 링크데이터의 물리적 파일을 별도의 위치에 압축하여 저장하고,
상기 검증부는 상기 입력부에 입력된 제1 SQL 문을 포함하는 데이터를 제2 관계형 데이터베이스의 제2 SQL 문과 매칭시켜 검증을 수행하고,
상기 저장부는 제2 관계형 데이터베이스로서, 제1 변환부에 의해 변환된 데이터 집합을 저장하되, 상기 저장부는 제1 SQL 문과 제2 SQL 문에 서로 동일하게 사용되는 구문에 대해서는 표준타입으로, 제1 SQL 문과 제2 SQL 문에 서로 다르게 사용되는 구문에 대해서는 고유타입으로 분류하고,
또한, 상기 관계형 데이터베이스 보존 시스템은 사용자로 하여금 손쉽게 관계형 데이터베이스에 저장된 메타데이터를 조회할 수 있도록 테이블 생성부, 태그 정보 생성부, 매핑부, 및 뷰 생성부를 포함하되,
상기 테이블 생성부는 XML 문서를 파싱하는 파서(parser)를 포함하여 상기 저장부에 저장된 XML 파일을 파싱하여 XML 문서의 각 엘리먼트(element)들을 테이블 형태로 변환하고,
상기 태그 정보 생성부는 상기 테이블 생성부에서 생성된 테이블에 사용자가 수월하게 제2 관계형 데이터베이스에 저장된 메타데이터를 조회할 수 있도록 하기 위한 정보인 검색 식별 태그 정보를 추가하고,
상기 매핑부는 상기 태그 정보 생성부에서 추가된 검색 식별 태그 정보를 기준으로 동일한 검색 식별 태그 정보를 갖는 테이블끼리 매핑하고,
상기 뷰 생성부는 상기 태그 정보 생성부에서 삽입된 검색 식별 태그 정보를 이용하여 제2 관계형 데이터베이스에 저장된 메타데이터를 조회하기 위한 조회화면을 생성하고,
상기 제1 관계형 데이터베이스는 행정정보시스템의 데이터베이스이고,
상기 관계형 데이터베이스 보존 시스템은 사용자로부터 데이터베이스의 선택, 상기 데이터베이스의 서버 위치, 상기 데이터베이스의 이름, 다운로드할 데이터베이스 계정의 암호, 파일 다운로드 방식, 파일 저장 위치, 데이터 베이스 중 원하는 테이블을 다운로드 받을 수 있는 테이블 목록을 입력받을 수 있는 창을 출력하는 것을 특징으로 하는 관계형 데이터베이스 보존 시스템에 있어서,
상기 관계형 데이터베이스 보존 시스템이, 제1 관계형 데이터베이스에 저장된 데이터 집합을 제2 관계형 데이터베이스에 저장하는 단계를 포함하되,
상기 관계형 데이터베이스 보존 시스템은, 상기 제1 관계형 데이터베이스 내 테이블에 대해서는 기설정된 조건을 만족하는 테이블을 XML 파일로 변환하여 상기 제2 관계형 데이터베이스에 저장하고, 링크데이터에 대해서는 해당 물리적 파일의 위치 정보를 상기 제2 관계형 데이터베이스 내 XML 파일에 삽입하여 저장하는 것을 특징으로 하는 관계형 데이터베이스 보존 방법.
- 제8항에 있어서,
상기 관계형 데이터베이스 보존 시스템이 제1 SQL 문을 수신하는 제A-1 단계;
상기 관계형 데이터베이스 보존 시스템이 수신한 제1 SQL 문을 매핑시킴으로써 검증을 수행하는 제A-2 단계;
상기 관계형 데이터베이스 보존 시스템이 매핑된 데이터에 대해서는 표준타입과 고유타입으로 분류하여 처리하되, 매핑되지 않은 데이터에 대해서는 기입력된 변환 가이드 데이터를 참조하는 제A-3 단계; 및
상기 관계형 데이터베이스 보존 시스템이 상기 제A-3 단계의 결과를 출력하는 제A-4 단계를 포함하는 것을 특징으로 하는 관계형 데이터베이스 보존 방법.
- 제9항에 있어서,
상기 테이블 생성부가 XML 문서를 파싱하여 테이블을 생성하는 제B-1 단계;
상기 관계형 데이터베이스 보존 시스템이 상기 제B-1 단계에서 생성된 테이블에 소정의 검색 식별 태그 정보를 추가하는 제B-2 단계;
상기 매핑부가 테이블 사이의 관계를 매핑하는 제B-3 단계;
상기 관계형 데이터베이스 보존 시스템이 이후 검색 식별 태그 정보별로 고유한 프레임 정보를 생성하는 제B-4 단계; 및
상기 관계형 데이터베이스 보존 시스템이 상기 제B-2 단계에서 검색 식별 태그 정보가 추가된 테이블, 상기 제B-3 단계에서 매핑된 테이블 사이의 관계 정보 및 상기 제B-4 단계에서 생성된 검색 식별 태그 정보별로 고유한 조회화면을 구성하는 프레임 정보를 제2 관계형 데이터베이스에 저장하는 제B-5단계를 포함하는 것을 특징으로 하는 관계형 데이터베이스 보존 방법.
- 삭제
- 삭제
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
KR1020200136076A KR102453595B1 (ko) | 2020-10-20 | 2020-10-20 | 관계형 데이터베이스 보존 방법 및 시스템 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
KR1020200136076A KR102453595B1 (ko) | 2020-10-20 | 2020-10-20 | 관계형 데이터베이스 보존 방법 및 시스템 |
Publications (2)
Publication Number | Publication Date |
---|---|
KR20220052112A KR20220052112A (ko) | 2022-04-27 |
KR102453595B1 true KR102453595B1 (ko) | 2022-10-14 |
Family
ID=81391133
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
KR1020200136076A KR102453595B1 (ko) | 2020-10-20 | 2020-10-20 | 관계형 데이터베이스 보존 방법 및 시스템 |
Country Status (1)
Country | Link |
---|---|
KR (1) | KR102453595B1 (ko) |
Citations (10)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JP2001034619A (ja) | 1999-07-16 | 2001-02-09 | Fujitsu Ltd | Xmlデータの格納/検索方法およびxmlデータ検索システム |
US20050289175A1 (en) | 2004-06-23 | 2005-12-29 | Oracle International Corporation | Providing XML node identity based operations in a value based SQL system |
JP2006053724A (ja) | 2004-08-11 | 2006-02-23 | Hitachi Ltd | Xmlデータ管理方法 |
US20060149706A1 (en) | 2005-01-05 | 2006-07-06 | Microsoft Corporation | System and method for transferring data and metadata between relational databases |
KR100678123B1 (ko) | 2006-02-10 | 2007-02-02 | 삼성전자주식회사 | 관계형 데이터베이스에서의 xml 데이터 저장 방법 |
JP2008211290A (ja) | 2007-02-23 | 2008-09-11 | Canon Inc | データ処理装置、データ処理方法、記憶媒体、プログラム |
KR100899616B1 (ko) * | 2008-01-25 | 2009-05-27 | 주식회사 케이티프리텔 | 관계형 데이터베이스를 이용한 메타데이터 관리 방법 및시스템 |
KR101674924B1 (ko) | 2014-09-26 | 2016-11-22 | 삼성에스디에스 주식회사 | 데이터베이스 마이그레이션 방법 및 그 장치 |
KR101862779B1 (ko) | 2016-11-01 | 2018-05-30 | 광운대학교 산학협력단 | 컬럼 수준 비정규화를 이용한 데이터 마이그레이션 장치 및 방법 |
JP6677809B2 (ja) | 2016-06-23 | 2020-04-08 | 株式会社日立製作所 | アダプタ生成装置及び方法 |
Family Cites Families (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
KR100831551B1 (ko) * | 2001-09-28 | 2008-05-22 | 주식회사 케이티 | 관계형 데이터베이스를 이용해 문서를 저장, 검색 및 복구하는 장치 및 그 방법 |
KR20080084332A (ko) | 2007-03-16 | 2008-09-19 | (주)온디멘드 | 데이터베이스 마이그레이션 장치 및 방법 |
KR102230821B1 (ko) * | 2018-12-26 | 2021-03-19 | 한남대학교 산학협력단 | 데이터베이스 전환 시스템 및 이를 이용한 데이터베이스 전환 방법 |
TWM578817U (zh) * | 2019-01-07 | 2019-06-01 | 資拓宏宇國際股份有限公司 | 用於轉換資料系統之資料為關聯式資料格式之處理系統 |
-
2020
- 2020-10-20 KR KR1020200136076A patent/KR102453595B1/ko active IP Right Grant
Patent Citations (10)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JP2001034619A (ja) | 1999-07-16 | 2001-02-09 | Fujitsu Ltd | Xmlデータの格納/検索方法およびxmlデータ検索システム |
US20050289175A1 (en) | 2004-06-23 | 2005-12-29 | Oracle International Corporation | Providing XML node identity based operations in a value based SQL system |
JP2006053724A (ja) | 2004-08-11 | 2006-02-23 | Hitachi Ltd | Xmlデータ管理方法 |
US20060149706A1 (en) | 2005-01-05 | 2006-07-06 | Microsoft Corporation | System and method for transferring data and metadata between relational databases |
KR100678123B1 (ko) | 2006-02-10 | 2007-02-02 | 삼성전자주식회사 | 관계형 데이터베이스에서의 xml 데이터 저장 방법 |
JP2008211290A (ja) | 2007-02-23 | 2008-09-11 | Canon Inc | データ処理装置、データ処理方法、記憶媒体、プログラム |
KR100899616B1 (ko) * | 2008-01-25 | 2009-05-27 | 주식회사 케이티프리텔 | 관계형 데이터베이스를 이용한 메타데이터 관리 방법 및시스템 |
KR101674924B1 (ko) | 2014-09-26 | 2016-11-22 | 삼성에스디에스 주식회사 | 데이터베이스 마이그레이션 방법 및 그 장치 |
JP6677809B2 (ja) | 2016-06-23 | 2020-04-08 | 株式会社日立製作所 | アダプタ生成装置及び方法 |
KR101862779B1 (ko) | 2016-11-01 | 2018-05-30 | 광운대학교 산학협력단 | 컬럼 수준 비정규화를 이용한 데이터 마이그레이션 장치 및 방법 |
Non-Patent Citations (2)
Title |
---|
TWM578817 U |
충남대학교 산학협력단, "데이터세트 구조분석 및 진본성 보장 기록관리 기능모델 연구", 2015.12.10. 1부.* |
Also Published As
Publication number | Publication date |
---|---|
KR20220052112A (ko) | 2022-04-27 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US11907247B2 (en) | Metadata hub for metadata models of database objects | |
US11789945B2 (en) | Clause-wise text-to-SQL generation | |
US10963513B2 (en) | Data system and method | |
US20160063063A1 (en) | Database query system | |
US20020078068A1 (en) | Method and apparatus for flexible storage and uniform manipulation of XML data in a relational database system | |
US9171051B2 (en) | Data definition language (DDL) expression annotation | |
US8868556B2 (en) | Method and device for tagging a document | |
US9646004B2 (en) | Hierarchical database report generation with automated query generation for placeholders | |
US11176125B2 (en) | Blended retrieval of data in transformed, normalized data models | |
WO2024001493A1 (zh) | 一种可视化的数据分析方法及设备 | |
US10614062B2 (en) | Data model extension generation | |
CN112231407B (zh) | PostgreSQL数据库的DDL同步方法、装置、设备和介质 | |
WO2018127747A1 (en) | A method, apparatus and computer program product for user-directed database configuration, and automated mining and conversion of data | |
US8099663B2 (en) | Apparatus and method for document synchronization | |
US20210055928A1 (en) | Integration test framework | |
KR102453595B1 (ko) | 관계형 데이터베이스 보존 방법 및 시스템 | |
US8386500B2 (en) | Apparatus, system, and method for XML based disconnected data access for multivalued/hierarchical databases | |
US20090043785A1 (en) | Managing structured content stored as a binary large object (blob) | |
WO2015121715A1 (en) | Method of and system for generating metadata | |
US12061860B2 (en) | Uniform hierarchical view over diverse data formats | |
US9020972B1 (en) | System and method for constructing a database instruction | |
US20180349428A1 (en) | Action queue for hierarchy maintenance | |
CN110807017A (zh) | 基于Beautiful Soup解析技术的AWR报告解析方法 | |
US20240220559A1 (en) | Systems and methods for paginating search results retrieved from multiple databases | |
US20240220485A1 (en) | Systems and methods for paginating search results retrieved from databases that support cursor-based pagination |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
E902 | Notification of reason for refusal | ||
E701 | Decision to grant or registration of patent right |