KR20180006484A - Rdb 시스템 - Google Patents

Rdb 시스템 Download PDF

Info

Publication number
KR20180006484A
KR20180006484A KR1020187000034A KR20187000034A KR20180006484A KR 20180006484 A KR20180006484 A KR 20180006484A KR 1020187000034 A KR1020187000034 A KR 1020187000034A KR 20187000034 A KR20187000034 A KR 20187000034A KR 20180006484 A KR20180006484 A KR 20180006484A
Authority
KR
South Korea
Prior art keywords
record
class
property
instance
managing
Prior art date
Application number
KR1020187000034A
Other languages
English (en)
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 가부시키가이샤 메디아두 홀딩스
Publication of KR20180006484A publication Critical patent/KR20180006484A/ko

Links

Images

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/28Databases characterised by their database models, e.g. relational or object models
    • G06F16/284Relational databases
    • G06F17/30595
    • 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/22Indexing; Data structures therefor; Storage structures
    • G06F16/2282Tablespace storage structures; Management thereof
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F12/00Accessing, addressing or allocating within memory systems or architectures
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • 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/21Design, administration or maintenance of databases
    • 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
    • G06F17/30339

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Databases & Information Systems (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Data Mining & Analysis (AREA)
  • Software Systems (AREA)
  • Information Retrieval, Db Structures And Fs Structures Therefor (AREA)

Abstract

가변 구조의 RDB 시스템을 제공하는 것을 과제로 한다. RDB와, 상기 RDB에 대해서 처리를 실행하기 위한 처리부를 구비하고, 가변 구조의 RDB를 제공하기 위한 RDB 시스템으로서, 상기 RDB는, 데이터 저장을 위한 구조 단위를 정의하는 클래스를, 클래스 레코드로서 관리하는 클래스 테이블과, 각각의 상기 클래스에 대해서 관련지어지는 속성인 프로퍼티를, 상기 클래스 레코드와 관계성을 가지는 프로퍼티 레코드로서 관리하는 프로퍼티 테이블과, 각각의 상기 클래스에 속하는 실체인 인스턴스를, 상기 클래스 레코드와 관계성을 가지는 인스턴스 레코드로서 관리하는 인스턴스 테이블과, 상기 인스턴스가 각각의 상기 프로퍼티에 대해서 가지는 값을 나타내는 실체치를, 상기 인스턴스 레코드 및 프로퍼티 레코드와 관계성을 가지는 실체치 레코드로서 관리하는 실체치 테이블을 구비하고, 상기 처리부는, 상기 클래스 레코드의 관리를 행하기 위한 클래스 관리 수단과, 상기 프로퍼티 레코드의 관리를 행하기 위한 프로퍼티 관리 수단과, 상기 인스턴스 레코드의 관리를 행하기 위한 인스턴스 관리 수단과, 상기 실체치 레코드의 관리를 행하기 위한 실체치 관리 수단을 구비하는 것을 특징으로 한다.

Description

RDB 시스템
본 발명은, 가변 구조의 RDB(관계형 데이터베이스) 시스템에 관한 것이다.
종래로부터, 각 기술 분야·산업 분야에서 여러 가지의 정보를 데이타베이스화하고 있고, 여러 가지의 정보를 저장한 데이타베이스 시스템이 이용되고 있다. 예를 들면 고객 정보 데이타베이스나, 회사 정보 데이타베이스 등이 그 일례이며, RDB(관계형 데이터베이스)가 이용되고 있다.
현재, 데이타베이스 시스템으로서 RDB를 이용한 RDB 시스템이 널리 이용되고 있다. 그렇지만, RDB 시스템을 가동시키기 위해서는, 미리 데이터 테이블의 열(속성)을 지정해 둘 필요가 있다. 또한, 미리 데이터의 성질마다 데이터 테이블 그 자체도 정의해 둘 필요가 있다. 이 때문에, 가동 후에 데이터 테이블의 열을 증가시키는 경우나, 데이터 테이블간의 릴레이션의 추가나 변경 등을 행하는 경우에는, RDB, RDB 시스템의 처리 프로그램에 대해서, 큰 폭으로 변경을 행할 필요가 생기고 있었다.
이 때문에, 일반적인 RDB의 데이터 테이블을, 속성명 관리 테이블, 속성치 관리 테이블, 조(組, tuple) 데이터 관리 테이블로 변형하고, 데이터 테이블의 열(속성)을, 데이터 테이블의 행(tuple)으로서 취급하기 위한 RDB 시스템이 개발되었다(특허 문헌 1). 데이터 테이블의 관리 항목으로서 취급하는 열(속성)을, 데이터 개수로서 취급하는 행에 배치하도록 했으므로, 관리 항목인 속성의 추가 삭제를 유연하게 행하는 것이 가능해졌다.
일본 공개특허공보 2013-186774호
특허 문헌 1에 기재의 기술에 의해서, 종래의 RDB 시스템의 데이터 테이블에 있어서의 속성의 증감이나 변경을, 유연하게 행하는 것이 가능해졌다. 그렇지만, 종래의 RDB 시스템에 있어서의 테이블(표)을 증가시킬 수 없고, 관계성을 가진 복수의 데이터 테이블을, RDB 상에 가변 구조로 표현하는 것은 할 수 없다. 또한, 테이블에서 이용 가능한 데이터 타입이, 수치 내지는 사전에 정의된 문자열로만 제한되고 있다. 이 때문에, 데이터의 구조나 이용 가능한 데이터 타입, 데이터끼리의 관계성 등을 보다 유연하게 변화 가능하고, 이들의 변화에 관한 처리를 용이하게 행하는 것이 가능한 RDB 시스템이 요구되고 있었다.
본 발명은, 상기와 같은 실상에 비추어서 이루어진 것이며, 가변 구조의 RDB 시스템을 제공하는 것을 과제로 한다.
상기 과제를 해결하기 위해서, 본 발명은, RDB(관계형 데이터베이스)와, 상기 RDB에 대해서 처리를 실행하기 위한 처리부를 구비하고, 가변 구조의 RDB를 제공하기 위한 RDB 시스템으로서, 상기 RDB는, 데이터 저장을 위한 구조 단위를 정의하는 클래스를, 클래스 레코드로서 관리하는 클래스 테이블과, 각각의 상기 클래스에 대해서 관련지어지는 속성인 프로퍼티를, 상기 클래스 레코드와 관계성을 가지는 프로퍼티 레코드로서 관리하는 프로퍼티 테이블과, 각각의 상기 클래스에 속하는 실체인 인스턴스를, 상기 클래스 레코드와 관계성을 가지는 인스턴스 레코드로서 관리하는 인스턴스 테이블과, 상기 인스턴스가 각각의 상기 프로퍼티에 대해서 가지는 값을 나타내는 실체치를, 상기 인스턴스 레코드 및 프로퍼티 레코드와 관계성을 가지는 실체치 레코드로서 관리하는 실체치 테이블을 구비하고, 상기 처리부는, 입력된 클래스 정보에 기초하여 상기 클래스 레코드의 관리를 행하기 위한 클래스 관리 수단과, 입력된 프로퍼티 정보에 기초하여 상기 프로퍼티 레코드의 관리를 행하기 위한 프로퍼티 관리 수단과, 입력된 인스턴스 정보에 기초하여 상기 인스턴스 레코드의 관리를 행하기 위한 인스턴스 관리 수단과, 입력된 실체치 정보에 기초하여 상기 실체치 레코드의 관리를 행하기 위한 실체치 관리 수단을 구비하는 것을 특징으로 한다.
이러한 구성으로 하는 것으로, 종래의 RDB 시스템에 있어서의 복수의 테이블을, RDB 상에 있어서 가변 구조로 구축하는 것이 가능해진다. 이것에 의해, 테이블의 증감이나 각 테이블에 있어서의 정보 단위의 증가에 대응 가능한 RDB를 제공하는 것이 가능해지고, 종래 필요했던 RDB의 구조의 재검토나 재구축을 행할 필요가 없어진다.
또한, 관리자가 RDB의 스키마 추가나 변경에 관한 지식을 필요로 하지 않고, 클래스나 프로퍼티의 추가·변경·삭제를 용이하게 행하는 것이 가능해진다. 또한, 클래스나 프로퍼티가 증대되어도, RDB 상의 스키마는 증가되지 않는다. 이 때문에, 구조의 파악·메인테넌스·백업이라고 하는 작업을, 극히 단순하게 행할 수 있다.
또한, 인스턴스나 실체치의 등록·취득·변경은, 어느 클래스의 인스턴스에 대해서도 마찬가지 방법으로 실행 가능해진다. 이 때문에, 종래와 같이 복수의 표나 복수의 열의 각각 대응하는 개발을 필요로 하지 않고, 데이타베이스의 구축시의 비용을 큰 폭으로 저렴화할 수 있다.
본 발명의 바람직한 형태에서는, 상기 실체치 레코드에 있어서의 실체치는, 인스턴스를 적어도 지정한 참조치를, 값으로 하여 유지 가능한 것을 특징으로 한다.
본 발명의 바람직한 형태에서는, 상기 프로퍼티 레코드는, 상기 실체치 레코드에 있어서의 실체치의, 값의 타입을 나타내는 타입 정보를 가지는 것을 특징으로 한다.
본 발명의 바람직한 형태에서는, 상기 프로퍼티 레코드는, 상기 실체치 레코드에 있어서의 실체치의 유니크성을 나타내는 유니크성 정보를 가지는 것을 특징으로 한다.
본 발명의 바람직한 형태에서는, 상기 RDB는, 데이터 저장을 위해서 이용하는 언어를, 언어 레코드로서 관리하는 언어 테이블과, 상기 클래스의 언어별의 명칭을, 클래스 레코드 및 언어 레코드와 관계성을 가지는 클래스 언어 레코드로서 관리하는 클래스 언어 테이블과, 상기 프로퍼티의 언어별의 명칭을, 프로퍼티 레코드 및 언어 레코드와 관계성을 가지는 프로퍼티 언어 레코드로서 관리하는 프로퍼티 언어 테이블을 더 구비하고, 상기 처리부는, 입력된 언어 정보에 기초하여 상기 언어 레코드의 관리를 행하기 위한 언어 관리 수단과, 입력된 클래스 언어 정보에 기초하여 상기 클래스 언어 레코드의 관리를 행하기 위한 클래스 언어 관리 수단과, 입력된 프로퍼티 언어 정보에 기초하여 상기 프로퍼티 언어 레코드의 관리를 행하기 위한 프로퍼티 언어 관리 수단을 더 구비하고, 상기 실체치 레코드는, 언어 레코드와 관계성을 더 가지는 것을 특징으로 한다.
이러한 구성으로 하는 것으로, 다언어에 대응한 데이터를 관리 가능한 RDB 시스템을 제공하는 것이 가능해진다.
본 발명의 바람직한 형태에서는, 상기 프로퍼티 언어 레코드는, 상기 실체치 레코드에 있어서의 실체치의 입력 규칙을 나타내는 규칙 정보를 가지는 것을 특징으로 한다.
이러한 구성으로 하는 것으로, 언어마다 실체치에 대해서 입력 규칙을 설정할 수 있다.
본 발명의 바람직한 형태에서는, 상기 클래스 레코드 및 상기 프로퍼티 레코드는, 관리 표시시의 표시 순서를 나타내는 순서 정보를 가지는 것을 특징으로 한다.
이러한 구성으로 하는 것으로, 관리화면에서의 표시를 용이하게 행하는 것이 가능해진다. 또한, 클래스 레코드 및 프로퍼티 레코드 이외에도, 언어 테이블에 있어서의 언어 레코드 등, 다른 테이블의 레코드에 대해서도, 관리화면에서의 표시 순서를 나타내는 순서 정보를 가지고 있어도 상관없다.
본 발명은, 가변 구조의 RDB(관계형 데이터베이스)를 제공하기 위한 관리 프로그램으로서, 컴퓨터를, 클래스 테이블의 관리를 행하기 위한 클래스 관리 수단과, 프로퍼티 테이블의 관리를 행하기 위한 프로퍼티 관리 수단과, 인스턴스 테이블의 관리를 행하기 위한 인스턴스 관리 수단과, 실체치 테이블의 관리를 행하기 위한 실체치 관리 수단으로서 기능시키고, 상기 클래스 테이블은, 데이터 저장을 위한 구조 단위를 정의하는 클래스를, 클래스 레코드로서 관리하고, 상기 프로퍼티 테이블은, 각각의 상기 클래스에 대해서 관련지어지는 속성인 프로퍼티를, 상기 클래스 레코드와 관계성을 가지는 프로퍼티 레코드로서 관리하고, 인스턴스 테이블은, 각각의 상기 클래스에 속하는 실체인 인스턴스를, 상기 클래스 레코드와 관계성을 가지는 인스턴스 레코드로서 관리하고, 실체치 테이블은, 상기 인스턴스가 각각의 상기 프로퍼티에 대해서 가지는 값을 나타내는 실체치를, 상기 인스턴스 레코드 및 프로퍼티 레코드와 관계성을 가지는 실체치 레코드로서 관리하는 것을 특징으로 한다.
본 발명은, 가변 구조의 RDB(관계형 데이터베이스)를 제공하기 위한 서버 장치로서, 클래스 테이블의 관리를 행하기 위한 클래스 관리 수단과, 프로퍼티 테이블의 관리를 행하기 위한 프로퍼티 관리 수단과, 인스턴스 테이블의 관리를 행하기 위한 인스턴스 관리 수단과, 실체치 테이블의 관리를 행하기 위한 실체치 관리 수단을 구비하고, 상기 클래스 테이블은, 데이터 저장을 위한 구조 단위를 정의하는 클래스를, 클래스 레코드로서 관리하고, 상기 프로퍼티 테이블은, 각각의 상기 클래스에 대해서 관련지어지는 속성인 프로퍼티를, 상기 클래스 레코드와 관계성을 가지는 프로퍼티 레코드로서 관리하고, 인스턴스 테이블은, 각각의 상기 클래스에 속하는 실체인 인스턴스를, 상기 클래스 레코드와 관계성을 가지는 인스턴스 레코드로서 관리하고, 실체치 테이블은, 상기 인스턴스가 각각의 상기 프로퍼티에 대해서 가지는 값을 나타내는 실체치를, 상기 인스턴스 레코드 및 프로퍼티 레코드와 관계성을 가지는 실체치 레코드로서 관리하는 것을 특징으로 한다.
본 발명은, RDB(관계형 데이터베이스) 형식으로 데이타베이스 장치에 기억된 복수의 테이블을 이용하여, 가변 구조의 데이터 관리를 행하기 위한 데이터 관리 방법으로서, 데이터 저장을 위한 구조 단위를 정의하는 클래스를, 클래스 레코드로서 관리하는 클래스 테이블과, 각각의 상기 클래스에 대해서 관련지어지는 속성인 프로퍼티를, 상기 클래스 레코드와 관계성을 가지는 프로퍼티 레코드로서 관리하는 프로퍼티 테이블과, 각각의 상기 클래스에 속하는 실체인 인스턴스를, 상기 클래스 레코드와 관계성을 가지는 인스턴스 레코드로서 관리하는 인스턴스 테이블과, 상기 인스턴스가 각각의 상기 프로퍼티에 대해서 가지는 값을 나타내는 실체치를, 상기 인스턴스 레코드 및 프로퍼티 레코드와 관계성을 가지는 실체치 레코드로서 관리하는 실체치 테이블과, 클래스 테이블의 관리를 행하기 위한 클래스 관리 수단과, 프로퍼티 테이블의 관리를 행하기 위한 프로퍼티 관리 수단과, 인스턴스 테이블의 관리를 행하기 위한 인스턴스 관리 수단과, 실체치 테이블의 관리를 행하기 위한 실체치 관리 수단을 이용하여 데이터 관리를 행하는 것을 특징으로 한다.
본 발명은, 가변 구조의 관계형 데이터베이스로서, 데이터 저장을 위한 구조 단위를 정의하는 클래스를, 클래스 레코드로서 관리하는 클래스 테이블과, 각각의 상기 클래스에 대해서 관련지어지는 속성인 프로퍼티를, 상기 클래스 레코드와 관계성을 가지는 프로퍼티 레코드로서 관리하는 프로퍼티 테이블과, 각각의 상기 클래스에 속하는 실체인 인스턴스를, 상기 클래스 레코드와 관계성을 가지는 인스턴스 레코드로서 관리하는 인스턴스 테이블과, 상기 인스턴스가 각각의 상기 프로퍼티에 대해서 가지는 값을 나타내는 실체치를, 상기 인스턴스 레코드 및 프로퍼티 레코드와 관계성을 가지는 실체치 레코드로서 관리하는 실체치 테이블을 구비하는 것을 특징으로 한다.
본 발명에 의하면, 가변 구조의 RDB 시스템을 제공할 수 있다.
도 1은 본 발명의 실시형태 1에 관한 RDB 시스템의 블럭도이다.
도 2는 본 발명의 실시형태 1에 관한 RDB의 다언어 대응시의 ER도이다.
도 3은 본 발명의 실시형태 1에 관한 RDB의 다언어 비대응시의 ER도이다.
도 4는 본 발명의 실시형태 1에 관한 RDB의 데이터 테이블의 예이다.
도 5는 본 발명의 실시형태 1에 관한 RDB의 데이터 테이블의 예이다.
도 6은 본 발명의 실시형태 1에 관한 RDB의 데이터 테이블의 예이다.
도 7은 본 발명의 실시형태 1에 관한 RDB의 관리화면의 일례이다.
도 8은 본 발명의 실시형태 1에 관한 RDB의 관리화면의 일례이다.
도 9는 본 발명의 실시형태 1에 관한 RDB 시스템의 관리 처리시의 처리 플로우차트이다.
도 10은 본 발명의 실시형태 1에 관한 RDB 시스템의 출력 처리/입력 처리의 처리 플로우차트이다.
도 11은 본 발명의 실시형태 1에 관한 RDB 시스템의 출력 처리/입력 처리의 처리 플로우차트이다.
도 12는 본 발명의 실시형태 2에 관한 RDB 시스템의 블럭도이다.
도 13은 본 발명의 실시형태 2에 관한 RDB 시스템의 관리 처리시의 처리 플로우차트이다.
<실시형태 1>
이하, 도 1 ~ 도 11을 이용하여, 본 발명의 실시형태 1에 관한 RDB 시스템에 대해서 설명한다. 또한, 이하에 나타내는 실시형태는 본 발명의 일례이며, 본 발명을 이하의 실시형태로 한정하는 것은 아니다. 본 실시형태에서는, 본 실시형태에 관한 데이터 구조의 RDB에 대한 처리를 행하기 위한 처리부가, 애플리케이션 서버 내에 프레임워크로서 제공되는 경우를 나타낸다. 예를 들면, 본 실시형태에서는 RDB 시스템의 구성, 동작 등에 대해서 설명하지만, 마찬가지의 구성의 방법, 장치, 컴퓨터 프로그램, 기록 매체 등도, 마찬가지의 작용 효과를 가질 수 있다. 또한, 프로그램은, 기록 매체에 기억시켜도 좋다. 이 기록 매체를 이용하면, 예를 들면 컴퓨터에 상기 프로그램을 인스톨 할 수 있다. 여기서, 상기 프로그램을 기억한 기록 매체는, 예를 들면 CD-ROM 등의 비일과성(非一過性)의 기록 매체라도 좋다.
도 1은, 본 실시형태에 관한 RDB 시스템의 기능 블럭도이다. 부호 1은 본 실시형태에 관한 데이터 구조의 RDB를, 부호 2는 RDB(1)를 가지는 데이타베이스 장치를, 부호 3은 처리부를, 부호 4 유저 단말을, 부호 5는 특정의 업무 처리를 행하기 위한 응용 프로그램을 저장한 애플리케이션 서버를, 부호 6은 웹 서버를 각각 나타내고 있다. 웹 서버(6)는, 애플리케이션 서버(5)와 일체로 이루어져서 제공되어도 상관없다. 또한, 웹 서버(6)는 반드시 마련되어 있을 필요는 없다.
데이타베이스 장치(2)는, RDB 형식으로 데이터를 기억한, 읽기/쓰기 가능한 기억장치(21)와, 데이타베이스 관리 시스템(22)을 구비하고 있다. 데이타베이스 관리 시스템(22)은, 처리부(3)로부터의 요구를 받아들이는 수단과, 처리부(3)로부터의 요구에 기초하여 기억장치(21)에 기억된 RDB(1)를 관리하기 위한 RDB 관리 수단을 가지고 있다. 또한, 기억장치(21)에는, RDB(1) 이외의 데이터가 기억되고 있어도 상관없다.
애플리케이션 서버(5)는, 유저로부터의 요구(유저 리퀘스트)에 기초하여 처리부(3)에 대한 특정의 업무 처리를 요구하는 애플리케이션(51)과, 프레임워크(52)로서 제공되는 처리부(3)를 가지고 있다. 애플리케이션(51)은, 유저 리퀘스트에 기초하여 처리부(3)에 처리 요구를 행하고, 처리부(3)로부터 받은 데이터에 기초하는 출력을 행한다. 애플리케이션 서버(5)가 데이타베이스 장치(2)로부터 취득한 데이터나 처리 결과는, 웹 서버(6)를 통하여 유저 단말(4)에 보내진다.
처리부(3)는, 애플리케이션(51)으로부터의 처리 요구의 접수, 및 데이터의 출력을 행하기 위한 입출력부(31)와, 클래스 테이블의 레코드·필드의 추가, 변경, 삭제, 검색 등, 관리를 행하기 위한 클래스 관리 수단(32)과, 프로퍼티 테이블의 레코드·필드의 추가, 변경, 삭제, 검색 등, 관리를 행하기 위한 프로퍼티 관리 수단(33)과, 인스턴스 테이블의 레코드·필드의 추가, 변경, 삭제, 검색 등, 관리를 행하기 위한 인스턴스 관리 수단(34)과, 실체치 테이블의 레코드·필드의 추가, 변경, 삭제, 검색 등, 관리를 행하기 위한 실체치 관리 수단(35)과, 언어 테이블의 레코드·필드의 추가, 변경, 삭제, 검색 등, 관리를 행하기 위한 언어 관리 수단(36)과, 클래스 언어 테이블의 레코드·필드의 추가, 변경, 삭제, 검색 등, 관리를 행하기 위한 클래스 언어 관리 수단(37)과, 프로퍼티 언어 테이블의 레코드·필드의 추가, 변경, 삭제, 검색 등, 관리를 행하기 위한 프로퍼티 언어 관리 수단(38)을 구비하고 있다.
다음에, 도 2 ~ 도 6을 이용하여, 다언어 대응시의 RDB(1)의 데이터 모델 구조와, 상기 데이터 모델 구조에 있어서의 클래스 테이블, 프로퍼티 테이블, 인스턴스 테이블, 실체치 테이블, 언어 테이블, 클래스 언어 테이블, 프로퍼티 언어 테이블의 구체적인 예에 대해서 설명한다.
도 2는, 실시형태 1에 관한 다언어 대응의 RDB 시스템의 데이터 모델 구조를 나타내고, 각 테이블의 관련을 나타낸 ER도(Entity Relationship Diagram)이다. 실시형태 1에 관한 RDB(1)는, 클래스 테이블, 프로퍼티 테이블, 인스턴스 테이블, 실체치 테이블, 언어 테이블, 클래스 언어 테이블, 프로퍼티 언어 테이블을 가지고 있다. RDB 시스템을 다언어 대응으로 운용하지 않는 경우에는, 언어 테이블, 클래스 언어 테이블, 프로퍼티 언어 테이블이 마련되어 있을 필요는 없다. 도 3에는, 다언어 비대응의 RDB(1)의 데이터 모델 구조에 관한 ER도를 나타낸다.
도 4(a)는, 언어 테이블의 일례를 나타내는 도이다. 언어 테이블은, 데이터 저장을 위해서 이용하는 언어를, 언어 레코드로서 관리하고 있다. 본 실시형태에 있어서의 언어 레코드는, 주 키로서 언어 ID를 가지고, 또한, 언어의 명칭과, 후술하는 관리화면 상에서의 표시 순서를 나타내는 순서 정보를 가지고 있다. 실시형태 1에서는, 일본어(jpn) 및 영어(eng)의 2언어에 대응한 RDB(1)를 구성하는 경우의 예를 나타낸다. 여기에 또 다른 언어를 추가할 수도 있고, 언어의 추가에 대응한 유연한 데이타베이스를 구축할 수 있다.
도 4(b)는, 클래스 테이블의 일례를 나타내는 도이다. 클래스 테이블은, 데이터 저장을 위한 구조 단위를 정의하는 클래스를, 클래스 레코드로서 관리하고 있다. 본 실시형태에 있어서의 클래스 레코드는, 주 키로서 클래스 ID를 가지고, 또한, 상기 순서 정보를 가지고 있다. 이 클래스는, 일반적인 RDB에 있어서의 각 테이블을 정의하는 것에 해당한다.
도 4(c)는, 클래스 언어 테이블의 일례를 나타내는 도이다. 클래스 언어 테이블은, 클래스의 언어별의 명칭을, 클래스 레코드 및 언어 레코드와 관계성을 가지는 클래스 언어 레코드로서 관리하고 있다. 본 실시형태에 있어서의 클래스 언어 레코드는, 주 키로서 클래스 ID 및 언어 ID를 가지고, 또한, 언어마다의 클래스의 명칭을 가지고 있다. 클래스 언어는, 언어 테이블에서 설정되는 언어마다, 각 클래스의 명칭을 관리하기 위한 것이다. 다언어에 대응하지 않는 경우에는, 클래스 레코드가 클래스의 명칭을 가지고 있어도 좋다.
도 5(a)는, 프로퍼티 테이블의 일례를 나타내는 도이다. 프로퍼티 테이블은, 각각의 상기 클래스에 대해서 관련지어지는 속성인 프로퍼티를, 상기 클래스 레코드와 관계성을 가지는 프로퍼티 레코드로서 관리하고 있다. 본 실시형태에 있어서의 프로퍼티 레코드는, 주 키로서 프로퍼티 ID를 가지고, 또한, 상기 클래스 ID와 상기 순서 정보, 후술하는 실체치의 값 타입에 관한 타입 정보, 실체치의 유니크성 타입에 관한 유니크성 정보를 가지고 있다. 프로퍼티 레코드는, 또한, 실체치의 NOTNULL 제약, 실체치의 초기치의 설정에 관한 필드를 가지고 있어도 좋다. 프로퍼티는, 일반적인 RDB에 있어서의 각 테이블의 속성을 정의하는 것에 해당한다.
도 5(b)는, 프로퍼티 언어 테이블의 일례를 나타내는 도이다. 프로퍼티 언어 테이블은, 프로퍼티의 언어별의 명칭을, 프로퍼티 레코드 및 언어 레코드와 관계성을 가지는 프로퍼티 언어 레코드로서 관리하고 있다. 본 실시형태에 있어서의 프로퍼티 언어 레코드는, 주 키로서 프로퍼티 ID 및 언어 ID를 가지고, 또한, 언어마다의 프로퍼티의 명칭과, 언어마다의 실체치의 입력 규칙을 가지고 있다. 프로퍼티 언어는, 언어 테이블에서 설정되는 언어마다, 각 프로퍼티의 명칭을 관리하기 위한 것이다. 다언어에 대응하지 않는 경우에는, 프로퍼티 레코드가 프로퍼티의 명칭 및 언어마다의 실체치의 입력 규칙을 가지고 있어도 좋다.
도 6(a)는, 인스턴스 테이블의 일례를 나타내는 도이다. 인스턴스 테이블은, 각각의 상기 클래스에 속하는 실체인 인스턴스를, 상기 클래스 레코드와 관계성을 가지는 인스턴스 레코드로서 관리하고 있다. 본 실시형태에 있어서의 인스턴스 레코드는, 주 키로서 인스턴스 ID를 가지고, 또한, 상기 클래스 ID를 가지고 있다.
도 6(b)는, 실체치 테이블의 일례를 나타내는 도이다. 실체치 테이블은, 상기 인스턴스가 각각의 상기 프로퍼티에 대해서 가지는 값을 나타내는 실체치를, 상기 인스턴스 레코드 및 프로퍼티 레코드와 관계성을 가지는 실체치 레코드로서 관리하고 있다. 본 실시형태에 있어서의 실체치 레코드는, 주 키로서 인스턴스 ID, 프로퍼티 ID, 언어 ID를 가지고, 또한, 실체치로서 비유니크 문자열, 유니크 문자열, 비유니크 수치, 유니크 수치, 비유니크 일시, 유니크 일시, 비유니크 바이너리, 유니크 바이너리, 비유니크 인스턴스 참조, 유니크 인스턴스 참조를 가지고 있다. 비유니크 인스턴스 참조 및 유니크 인스턴스 참조는, 다른 인스턴스를 참조하기 위한 참조치이다. 본 실시형태에서는, 예를 들면, 인스턴스 ID를 지정하는 것으로, 실체로서 그룹의 인스턴스를 참조 가능하게 구성하고 있다. 또한, 인스턴스에 더하여 프로퍼티도 지정시키고, 다른 실체치를 참조치로서 유지 가능해도 좋다. 이 경우, 값의 타입 정보로서 실체치 참조를 추가해 두고, 실체치 레코드에는 유니크/비유니크 실체치 참조의 필드를 마련하면 좋다.
실체치로서 인스턴스 참조를 가지게 하는 것으로, 일반적인 RDB에 있어서의 릴레이션을 정의할 수 있고, 릴레이션을 유연하게 추가, 변경 등 가능한 RDB 시스템을 제공하는 것이 가능해진다. 예를 들면 도 4 ~ 6의 예에서는, 인스턴스 참조로서 인스턴스(i001)로 설정되는 그룹을 선택하는 구성으로 하고 있다. 이것에 의해, 인스턴스(i002)로 설정된 각 멤버와, 인스턴스(i001)로 설정되는 그룹의 릴레이션을 정의하고, 각 멤버가 소속하는 그룹을 설정할 수 있다. 이러한 구성으로 하는 것으로, 폭넓은 데이터형에 대응한 시스템을 제공할 수 있다. 이 때문에, 현실적인 시스템 운용시에 필요한 엄격한 데이터 관리를 실현 가능해지고, 여러 시스템에 적용할 수 있다.
또한, 본 실시형태의 실체치 테이블에 있어서, 프로퍼티 ID와 언어 ID와 유니크 문자열, 프로퍼티 ID와 언어 ID와 유니크 수치, 프로퍼티 ID와 언어 ID와 유니크 일시, 프로퍼티 ID와 언어 ID와 유니크 바이너리, 프로퍼티 ID와 언어 ID와 유니크 인스턴스 참조의 조합에는, 복합 유니크 제약이 마련되어 있다.
도 7, 도 8은, 유저 단말(4)에 표시되는 관리화면예를 나타낸다. 도 7은, 실체치를 관리할 때의 관리화면의 일례를 나타내는 도이다. 유저는, 이 관리화면으로부터 RDB(1)에 대해서 검색이나 레코드의 추가 등의 관리를 행할 수 있다. 도 8(a)는 프로퍼티를 관리할 때의 관리화면의 일례를 나타내는 도이다. 도 8(b)는, 프로퍼티 언어를 관리할 때의 관리화면의 일례를 나타내는 도이다. 클래스나 클래스 언어, 언어, 인스턴스에 대해서도 마찬가지의 관리화면에서 관리할 수 있다. 각 레코드는, 관리화면에서 이용하는 비고 등의 정보를 더 가지고 있어도 좋다.
다음에 도 9를 이용하여, 관리화면으로부터 레코드의 추가를 행할 때의 처리 플로우에 대해서 설명한다. 본 실시형태에서는, 프로퍼티 테이블에 프로퍼티 레코드를 추가할 때의 예를 나타낸다. 또한, 클래스 레코드나 인스턴스 레코드 등의 각 테이블의 레코드를 추가, 편집, 삭제하는 경우에 대해서도, 마찬가지의 처리 순서로 실행 가능하다. 또한, 검색 처리나 웹페이지의 표시 처리 등, 요구에 기초하여 소정의 데이터를 취득하는 경우에 대해서도, 마찬가지의 처리 순서로 실행 가능하다. 이 추가, 변경, 삭제, 검색 등에 관한 관리 처리는, 반드시 관리화면으로부터 행해질 필요는 없고, 본 실시형태에서 예시하는 관리화면으로부터 요구를 행하는 이외의 방법으로 행해져도 상관없다.
유저는, 유저 단말(4)의 웹 브라우저를 이용하여 웹 서버(6)에 액세스하고, 관리화면의 제공을 리퀘스트한다. 관리화면의 제공에 관한 유저 리퀘스트는, 웹 서버(6)에 의해서 애플리케이션 서버(5)에 전송된다. 애플리케이션 서버(5)는, 데이타베이스 장치(2)로부터 필요한 정보를 받아들이고, 애플리케이션(51), 웹 서버(6)를 통하여, 유저 단말(4)에 각 관리화면의 제공을 행한다(S1).
유저는, 제공된 프로퍼티 관리화면으로부터 프로퍼티 레코드의 신규 추가를 선택하고, 신규 프로퍼티의 추가 요구를 행한다(S2). 신규 프로퍼티를 추가할 때에, 유저는, 상기 프로퍼티가 대상으로 하는 클래스를 선택하고, 실체치의 타입 정보와, 유니크성 정보와, 프로퍼티 ID와, 순서 정보를 입력한다. 여기서, 소정의 항목, 예를 들면 프로퍼티 ID나 순서 정보 등은, 자동적으로 설정되도록 구성해도 좋다.
또한, 언어마다의 프로퍼티의 명칭 및, 언어마다의 실체치의 입력 규칙의 입력도 동시에 받아들이고, 프로퍼티 레코드에 더하여 프로퍼티 언어 레코드를 함께 관리 가능할 수 있도록 구성해도 상관없다. 클래스 레코드의 추가에 맞추어서 그 클래스 언어에 대해서도 함께 관리 가능한 구성 등, RDB(1)의 복수의 테이블에 관한 사항을 관리 가능하게 구성해도 좋다.
유저에 의해서 입력된 신규 프로퍼티에 관한 정보는, 신규 프로퍼티를 추가하기 위한 유저 리퀘스트로서 웹 서버(6)에 의해 애플리케이션 서버(5)에 전송된다(S3). 애플리케이션 서버(5)에서는, 받은 유저 리퀘스트를 애플리케이션(51)에서 처리하고, 처리부(3)에 대해서 프로퍼티 레코드의 추가 지시를 행한다(S4).
처리부(3)는, 애플리케이션(51)으로부터의 프로퍼티 레코드의 추가 지시를 입출력부(31)에서 받는다. 그리고, 받은 추가 지시에 기초하여, JDBC나 ODBC 등의 데이타베이스 드라이버를 경유하여, 프로퍼티 관리 수단(33)을 이용하여 데이타베이스 관리 시스템(22)에 액세스하고, 프로퍼티 추가의 요구를 행한다(S5). 데이타베이스 관리 시스템(22)은, 처리부(3)로부터 받은 신규 프로퍼티의 추가 지시에 기초하여, 프로퍼티 테이블에 새로운 프로퍼티 레코드를 추가한다(S6). 데이타베이스 장치(2)에 있어서의 처리 결과는, 애플리케이션(51)으로 전달되고, 웹 서버(6)에서 취급하기 위한 소정의 데이터로 가공되어서, 유저 단말(4)의 웹 브라우저에 통지된다(S7).
다음에 도 10을 이용하여, 유저에 의한 웹페이지를 통한 출력/입력 처리에 대해서 설명한다. 유저는, 유저 단말(4)의 웹 브라우저를 이용하여 웹 서버(6)에 액세스하고, 출력/입력 처리를 리퀘스트한다(S11). 유저 리퀘스트에는, 유저가 사용하는 브라우저의 언어 설정이 포함되어 있다. 웹 서버(6)는, 언어 설정을 가지는 유저 리퀘스트를 취득하고, 애플리케이션 서버(5)에 전송한다(S12).
언어 설정을 가지는 유저 리퀘스트를 받은 애플리케이션(51)은, 유저 리퀘스트에 포함되는 언어 설정을 판별한다. RDB(1)가 언어 설정된 언어에 대응하고 있지 않는 경우, 대응하고 있는 다른 언어를 지정하여 언어 정보로 한다. 애플리케이션(51)은, 이 언어 정보 및 유저 리퀘스트에 기초하여, 처리부(3)에 처리의 요구를 행한다(S13).
처리부(3)는, 받은 처리 요구에 기초하여, JDBC나 ODBC 등의 데이타베이스 드라이버를 경유하여, 데이타베이스 관리 시스템(22)에 액세스하고, 데이터의 처리 요구를 행한다(S14). 데이타베이스 관리 시스템은, 요구된 처리를 실행하고, 처리 결과를 출력한다(S15). 이 출력은, 애플리케이션(51)으로 전달되고, 웹 서버(6)에서 취급하기 위한 소정의 데이터로 가공된다(S16). 이 데이터를 받은 웹 서버(6)는, 유저 단말(4)의 웹 브라우저에 통지를 행한다(S17).
도 11(a)을 이용하여, S13에 있어서, 유저에 대해서 데이터의 출력 처리를 행할 때의 예에 대해서 설명한다. 예를 들면, 유저에 대해서 동적인 컨텐츠를 웹 브라우저에서 표시하는 경우나, 유저로부터 있는 데이터에 대한 출력 요구가 있었을 경우가 본 예에 해당한다.
언어 설정을 가지는 유저 리퀘스트를 받은 애플리케이션(51)은, 유저 리퀘스트에 기초하여, 출력 요구를 받고 있는 실체치를 특정한다(S13). 언어의 특정은, 판별된 언어 정보에 기초하여 행해진다(A1). 언어 설정의 언어가 RDB(1)에서 이용 가능한 언어에 대응하고 있는 경우, 언어 설정의 언어가 출력 대상의 데이터의 언어가 된다. 이용 가능한 언어에 대응하고 있지 않는 경우는, 소정의 언어가 출력 대상의 데이터의 언어가 된다.
유저 리퀘스트에 기초하여, 출력 대상의 실체치에 관한 인스턴스 및 프로퍼티가 특정된다(A2). A1에서 결정된 언어와, A2에서 특정된 인스턴스 및 프로퍼티에 기초하여, 실체치의 레코드 중의 하나의 실체치가 특정된다(A3).
유저 리퀘스트에 포함되는 모든 실체치를 특정할 수 있다면(A4 Y), 프레임워크에의 처리 요구를 행한다(A5). 그리고, S14로 진행되고, 특정된 실체치의 데이터를, 실체치 관리 수단(35)을 이용하여 RDB(1)로부터 취득한다. 이 인스턴스에 대한 복수의 실체치를 취득하고 싶은 경우나, 클래스의 전체 데이터를 취득하고 싶은 경우에는, A2 및 A3의 처리를 반복하면 좋다(A4 N). 또한, 프레임워크, 데이타베이스 관리 시스템에의 처리 요구나, A4에 있어서의 반복의 판정 등은, 다른 타이밍에서 행해도 상관없다. 예를 들면, 프레임워크에의 처리 요구를 A3 후에 행하도록 하고, 반복의 판정(A4)은, S15에서 데이타베이스 관리 시스템으로부터 받은 후 등에 행해도 상관없다.
또한, 한 언어가 있는 클래스에 포함되는 실체치 데이터 전부를 취득하고 싶은 경우에는, 유저 리퀘스트로서 클래스를 지정하는 정보와 언어 설정을 받아도 좋다. 이 경우, 우선, 처리부(3)를 통하여 RDB(1)로부터 지정된 클래스를 포함하는 인스턴스를 검색하여 받고, 이 인스턴스를 포함하고, 언어 정보에 대응한 실체치 데이터를 전체건 취득하도록 처리부(3)에 요구해도 좋다.
도 11(b)를 이용하여, S13에 있어서, 유저로부터의 데이터의 입력 처리를 행할 때의 예에 대해서 설명한다. 예를 들면, 입력 폼으로부터 유저의 데이터를 취득하여 기억하는 경우나, 주문 데이터를 기억하는 경우가 본 예에 해당한다.
언어 설정을 가지는 유저 리퀘스트를 받은 애플리케이션(51)은, 유저 리퀘스트에 기초하여, 입력 요구를 받고 있는 인스턴스를 특정한다(S13). 애플리케이션(51)은, 언어 설정으로부터, 언어 정보를 판별한다(B1). 이 언어 설정은, 실체치의 언어의 특정에 이용해도 좋다. 또한, 클래스에 의해서 언어별로 데이터 저장의 구조 단위를 정의하고 있는 경우에는, 클래스의 특정 등에 이용해도 좋다.
유저 리퀘스트에 기초하여, 입력 대상의 실체치에 관한 클래스 및 프로퍼티가 특정된다(B2). 언어는, 언어 설정 이외의 유저 리퀘스트에 기초하여 결정되도록 구성해도 좋고, 언어 설정에 기초하여 특정된 언어 정보에 기초하여 결정되어도 좋다.
유저의 신규 데이터를 등록하는 경우, 처리부(3)에 대해서, B2에서 특정된 클래스에 속하는 신규 인스턴스의 작성 요구를 행한다. 작성된 인스턴스와, B2에서 특정된 프로퍼티 및 언어에 기초하여, 하나의 실체치 데이터가 특정된다(B3).
유저 리퀘스트에 포함되는 모든 실체치를 특정할 수 있다면(B4 Y), 프레임워크에의 처리 요구를 행한다(B5). 그리고, S14로 진행되고, 특정된 실체치의 데이터를, 실체치 관리 수단(35)을 이용하여 RDB(1)에 기억한다. 이 인스턴스에 대한 복수의 실체치를 기억하고 싶은 경우는, B2 및 B3의 처리를 반복하면 좋다(B4 N).
또한, 한 인스턴스에 대한 데이터를 덮어쓰기하고 싶은 경우에는, 유저 리퀘스트로서 인스턴스를 지정하는 정보와, 프로퍼티를 지정하는 정보와, 언어 설정을 받아도 좋다. 이 경우, 특정되는 실체치 레코드를 덮어쓰기하도록 처리부(3)에 요구하면 좋다.
본 발명에 의하면, 종래의 RDB 시스템에 있어서의 복수의 테이블을, RDB 상에 있어서 가변 구조로 구축하는 것이 가능해진다. 이것에 의해, 테이블의 증감이나 각 테이블에 있어서의 정보 단위의 증가에 대응 가능한 RDB를 제공하는 것이 가능해진다.
또한, 종래의 RDB와 같이, 데이터의 성질마다 데이터 테이블 그 자체를 정의해 둘 필요가 없어진다. 또한, 종래의 RDB에 있어서의 데이터 테이블간의 릴레이션의 추가나 변경을, 극히 용이하게 행하는 것이 가능해진다.
또한, 유연하게 언어를 추가할 수 있는 다언어 데이터를 관리 가능한 RDB 시스템을 제공하는 것이 가능해진다.
<실시형태 2>
도 12, 도 13을 이용하여, 본 발명의 실시형태 2에 관한 RDB 시스템에 대해서 설명한다. 또한, 상기 실시형태에 있어서, 앞의 실시형태와 기본적으로 동일한 구성요소에 대해서는, 동일한 부호를 부여하여 그 설명을 간략화한다.
실시형태 2에서는, 데이타베이스 관리 시스템(22)의 기본 기능으로서, 본 발명에 관한 데이터 구조의 RDB(1)를 관리하는 각각의 관리 수단이 마련되어 있는 경우에 대해서 설명한다. 도 12에 나타내는 바와 같이, 데이타베이스 관리 시스템(22)은, 애플리케이션 서버(5)로부터의 요구에 기초하여 기억장치(21)에 기억된 RDB를 관리하기 위한 RDB 관리 수단(23)과, 애플리케이션 서버로부터의 요구를 받아들이는 입출력부(31)와, 클래스 관리 수단(32)과, 프로퍼티 관리 수단(33)과, 인스턴스 관리 수단(34)과, 실체치 관리 수단(35)과, 언어 관리 수단(36)과, 클래스 언어 관리 수단(37)과, 프로퍼티 언어 관리 수단(38)을 구비하고 있다.
또한, 실시형태 1과 마찬가지로, RDB 시스템을 도 3에 나타내는 바와 같이 다언어 비대응으로 운용하는 경우에는, 언어 테이블, 클래스 언어 테이블, 프로퍼티 언어 테이블이 마련되어 있을 필요는 없다. 웹 서버(6)는, 애플리케이션 서버(5)와 일체로 이루어져서 제공되어도 상관없다. 또한, 웹 서버(6)는, 반드시 마련되어 있을 필요는 없다.
도 13을 이용하여, 본 실시형태에 있어서의 RDB(1)의 관리 처리에 관한 처리 플로우에 대해서 설명한다. 본 실시형태에서는, 실체치 테이블에 실체치 레코드를 추가할 때의 예를 나타낸다. 또한, 클래스 레코드나 프로퍼티 레코드 등의 각 테이블의 레코드를 추가, 편집, 삭제 등, 관리하는 경우에 대해서도, 마찬가지의 처리 플로우로 실행 가능하다. 또한, 검색 처리나 웹페이지의 표시 처리 등, 요구에 기초하여 소정의 데이터를 취득하는 경우에 대해서도, 마찬가지의 처리 플로우로 실행이 가능하다.
유저는, 유저 단말(4)의 웹 브라우저를 이용하여 웹 서버(6)에 액세스하고, 관리화면의 제공을 리퀘스트한다. 관리화면의 제공에 관한 유저 리퀘스트는, 웹 서버(6)에 의해서 애플리케이션 서버(5)에 전송된다. 애플리케이션 서버(5)는, 데이타베이스 장치(2)로부터 필요한 정보를 받아들이고, 애플리케이션(51), 웹 서버(6)를 통하여, 유저 단말(4)에 각 관리화면의 제공을 행한다(S21).
유저는, 제공된 실체치의 관리화면으로부터 실체치 레코드의 신규 추가를 선택하고, 신규 실체치의 추가 요구를 행한다(S22). 신규 실체치를 추가할 때에, 유저는, 상기 실체치가 대상으로 하는 인스턴스, 프로퍼티, 언어를 선택하고, 실체치를 입력한다. 이 실체치의 입력에서는, 선택한 프로퍼티에 대해서 프로퍼티 레코드에서 설정된 값의 타입 정보 및 유니크성 정보, 선택한 언어 및 프로퍼티에 대해서 프로퍼티 언어 레코드에서 설정된 실체치의 입력 규칙의 제약을 받는다. 여기서, 또한, RDB(1)의 복수의 테이블에 관한 사항을 관리 가능하게 구성해도 좋다.
유저에 의해서 입력된 신규 실체치에 관한 정보는, 신규 실체치를 추가하기 위한 유저 리퀘스트로서, 웹 서버(6)를 통하여 애플리케이션 서버(5)에 전송된다(S23). 애플리케이션 서버(5)에서는, 받은 유저 리퀘스트를 애플리케이션(51)에서 처리하고, JDBC나 ODBC 등의 데이타베이스 드라이버를 경유하여, 입출력부(31)에 액세스한다(S24). 그리고, 실체치 관리 수단(35)는, 받은 추가 지시에 기초하여, 실체치 테이블에 새로운 실체치 레코드를 추가한다(S25). 데이타베이스 장치(2)에 있어서의 처리 결과는, 애플리케이션(51)으로 전달되고, 웹 서버(6)에서 취급하기 위한 소정의 데이터로 가공되고, 유저 단말(4)의 웹 브라우저에 통지된다(S26).
본 발명에 의하면, 종래의 RDB 시스템에 있어서의 복수의 테이블을, RDB 상에 있어서 가변 구조로 구축하는 것이 가능해진다. 이것에 의해, 테이블의 증감이나 각 테이블에 있어서의 정보 단위의 증가에 대응 가능한 RDB를 제공하는 것이 가능해진다.
또한, 종래의 RDB와 같이, 데이터의 성질마다 데이터 테이블 그 자체를 정의해 둘 필요가 없어진다. 또한, 종래의 RDB에 있어서의 데이터 테이블간의 릴레이션의 추가나 변경을, 극히 용이하게 행하는 것이 가능해진다.
또한, 유연하게 언어를 추가할 수 있는 다언어 데이터를 관리 가능한 RDB 시스템을 제공하는 것이 가능해진다.
또한, 본 발명에 관한 데이터 구조의 RDB를 관리하기 위한 관리 수단을 데이타베이스 관리 시스템의 기본 기능에 넣는 것으로, 읽기의 일관성이 증가되고, 효과적으로 본 발명을 제공할 수 있다.
본 발명에 의해서, 대규모이며 변경이 빈번히 행해지는 데이터를 관리하는 경우에 적절한, 가변 구조, 다언어 대응의 RDB 시스템을 제공할 수 있다.
1: RDB
2: 데이타베이스 장치
21: 기억장치
22: 데이타베이스 관리 시스템
23: RDB 관리 수단
3: 처리부
31: 입출력부
32: 클래스 관리 수단
33: 프로퍼티 관리 수단
34: 인스턴스 관리 수단
35: 실체치 관리 수단
36: 언어 관리 수단
37: 클래스 언어 관리 수단
38: 프로퍼티 언어 관리 수단
4: 유저 단말
5: 애플리케이션 서버
51: 애플리케이션
52: 프레임워크
6: 웹 서버

Claims (10)

  1. RDB(관계형 데이터베이스)와, 상기 RDB에 대해서 처리를 실행하기 위한 처리부를 구비하고, 가변 구조의 RDB를 제공하기 위한 RDB 시스템으로서,
    상기 RDB는, 데이터 저장을 위한 구조 단위를 정의하는 클래스를, 클래스 레코드로서 관리하는 클래스 테이블과,
    각각의 상기 클래스에 대해서 관련지어지는 속성인 프로퍼티(property)를, 상기 클래스 레코드와 관계성을 가지는 프로퍼티 레코드로서 관리하는 프로퍼티 테이블과,
    각각의 상기 클래스에 속하는 실체인 인스턴스를, 상기 클래스 레코드와 관계성을 가지는 인스턴스 레코드로서 관리하는 인스턴스 테이블과,
    상기 인스턴스가 각각의 상기 프로퍼티에 대해서 가지는 값을 나타내는 실체치를, 상기 인스턴스 레코드 및 프로퍼티 레코드와 관계성을 가지는 실체치 레코드로서 관리하는 실체치 테이블를 구비하고,
    상기 처리부는, 입력된 클래스 정보에 기초하여 상기 클래스 레코드의 관리를 행하기 위한 클래스 관리 수단과,
    입력된 프로퍼티 정보에 기초하여 상기 프로퍼티 레코드의 관리를 행하기 위한 프로퍼티 관리 수단과,
    입력된 인스턴스 정보에 기초하여 상기 인스턴스 레코드의 관리를 행하기 위한 인스턴스 관리 수단과,
    입력된 실체치 정보에 기초하여 상기 실체치 레코드의 관리를 행하기 위한 실체치 관리 수단를 구비하는 것을 특징으로 하는 RDB 시스템.
  2. 제 1 항에 있어서,
    상기 실체치 레코드에 있어서의 실체치는, 인스턴스를 적어도 지정한 참조치를, 값으로 하여 유지 가능한 것을 특징으로 하는 RDB 시스템.
  3. 제 1 항 또는 제 2 항에 있어서,
    상기 프로퍼티 레코드는, 상기 실체치 레코드에 있어서의 실체치의, 값의 타입을 나타내는 타입 정보를 가지는 것을 특징으로 하는 RDB 시스템.
  4. 제 1 항 내지 제 3 항 중 어느 한 항에 있어서,
    상기 프로퍼티 레코드는, 상기 실체치 레코드에 있어서의 실체치의 유니크성을 나타내는 유니크성 정보를 가지는 것을 특징으로 하는 RDB 시스템.
  5. 제 1 항 내지 제 4 항 중 어느 한 항에 있어서,
    상기 RDB는, 데이터 저장을 위해서 이용하는 언어를, 언어 레코드로서 관리하는 언어 테이블과,
    상기 클래스의 언어별의 명칭을, 클래스 레코드 및 언어 레코드와 관계성을 가지는 클래스 언어 레코드로서 관리하는 클래스 언어 테이블과,
    상기 프로퍼티의 언어별의 명칭을, 프로퍼티 레코드 및 언어 레코드와 관계성을 가지는 프로퍼티 언어 레코드로서 관리하는 프로퍼티 언어 테이블을 더 구비하고,
    상기 처리부는, 입력된 언어 정보에 기초하여 상기 언어 레코드의 관리를 행하기 위한 언어 관리 수단과,
    입력된 클래스 언어 정보에 기초하여 상기 클래스 언어 레코드의 관리를 행하기 위한 클래스 언어 관리 수단과,
    입력된 프로퍼티 언어 정보에 기초하여 상기 프로퍼티 언어 레코드의 관리를 행하기 위한 프로퍼티 언어 관리 수단을 더 구비하고,
    상기 실체치 레코드는, 언어 레코드와 관계성을 가지는 것을 특징으로 하는 RDB 시스템.
  6. 제 5 항에 있어서,
    상기 프로퍼티 언어 레코드는, 상기 실체치 레코드에 있어서의 실체치의 입력 규칙을 나타내는 규칙 정보를 가지는 것을 특징으로 하는 RDB 시스템.
  7. 제 1 항 내지 제 6 항 중 어느 한 항에 있어서,
    상기 클래스 레코드 및 상기 프로퍼티 레코드는, 관리 표시시의 표시 순서를 나타내는 순서 정보를 가지는 것을 특징으로 하는 RDB 시스템.
  8. 가변 구조의 RDB(관계형 데이터베이스)를 제공하기 위한 관리 프로그램으로서, 컴퓨터를,
    클래스 테이블의 관리를 행하기 위한 클래스 관리 수단과,
    프로퍼티 테이블의 관리를 행하기 위한 프로퍼티 관리 수단과,
    인스턴스 테이블의 관리를 행하기 위한 인스턴스 관리 수단과,
    실체치 테이블의 관리를 행하기 위한 실체치 관리 수단으로서 기능시키고,
    상기 클래스 테이블은, 데이터 저장을 위한 구조 단위를 정의하는 클래스를, 클래스 레코드로서 관리하고,
    상기 프로퍼티 테이블은, 각각의 상기 클래스에 대해서 관련지어지는 속성인 프로퍼티를, 상기 클래스 레코드와 관계성을 가지는 프로퍼티 레코드로서 관리하고,
    인스턴스 테이블은, 각각의 상기 클래스에 속하는 실체인 인스턴스를, 상기 클래스 레코드와 관계성을 가지는 인스턴스 레코드로서 관리하고,
    실체치 테이블은, 상기 인스턴스가 각각의 상기 프로퍼티에 대해서 가지는 값을 나타내는 실체치를, 상기 인스턴스 레코드 및 프로퍼티 레코드와 관계성을 가지는 실체치 레코드로서 관리하는 것을 특징으로 하는 관리 프로그램.
  9. 가변 구조의 RDB(관계형 데이터베이스)를 제공하기 위한 서버 장치로서,
    클래스 테이블의 관리를 행하기 위한 클래스 관리 수단과,
    프로퍼티 테이블의 관리를 행하기 위한 프로퍼티 관리 수단과,
    인스턴스 테이블의 관리를 행하기 위한 인스턴스 관리 수단과,
    실체치 테이블의 관리를 행하기 위한 실체치 관리 수단을 구비하고,
    상기 클래스 테이블은, 데이터 저장을 위한 구조 단위를 정의하는 클래스를, 클래스 레코드로서 관리하고,
    상기 프로퍼티 테이블은, 각각의 상기 클래스에 대해서 관련지어지는 속성인 프로퍼티를, 상기 클래스 레코드와 관계성을 가지는 프로퍼티 레코드로서 관리하고,
    인스턴스 테이블은, 각각의 상기 클래스에 속하는 실체인 인스턴스를, 상기 클래스 레코드와 관계성을 가지는 인스턴스 레코드로서 관리하고,
    실체치 테이블은, 상기 인스턴스가 각각의 상기 프로퍼티에 대해서 가지는 값을 나타내는 실체치를, 상기 인스턴스 레코드 및 프로퍼티 레코드와 관계성을 가지는 실체치 레코드로서 관리하는 것을 특징으로 하는 서버 장치.
  10. RDB(관계형 데이터베이스) 형식으로 데이타베이스 장치에 기억된 복수의 테이블을 이용하여, 가변 구조의 데이터 관리를 행하기 위한 데이터 관리 방법으로서,
    데이터 저장을 위한 구조 단위를 정의하는 클래스를, 클래스 레코드로서 관리하는 클래스 테이블과,
    각각의 상기 클래스에 대해서 관련지어지는 속성인 프로퍼티를, 상기 클래스 레코드와 관계성을 가지는 프로퍼티 레코드로서 관리하는 프로퍼티 테이블과,
    각각의 상기 클래스에 속하는 실체인 인스턴스를, 상기 클래스 레코드와 관계성을 가지는 인스턴스 레코드로서 관리하는 인스턴스 테이블과,
    상기 인스턴스가 각각의 상기 프로퍼티에 대해서 가지는 값을 나타내는 실체치를, 상기 인스턴스 레코드 및 프로퍼티 레코드와 관계성을 가지는 실체치 레코드로서 관리하는 실체치 테이블과,
    클래스 테이블의 관리를 행하기 위한 클래스 관리 수단과, 프로퍼티 테이블의 관리를 행하기 위한 프로퍼티 관리 수단과, 인스턴스 테이블의 관리를 행하기 위한 인스턴스 관리 수단과, 실체치 테이블의 관리를 행하기 위한 실체치 관리 수단을 이용하여 데이터 관리를 행하는 것을 특징으로 하는 데이터 관리 방법.
KR1020187000034A 2015-06-08 2016-03-10 Rdb 시스템 KR20180006484A (ko)

Applications Claiming Priority (3)

Application Number Priority Date Filing Date Title
JP2015116117A JP5877488B1 (ja) 2015-06-08 2015-06-08 Rdbシステム
JPJP-P-2015-116117 2015-06-08
PCT/JP2016/057508 WO2016199466A1 (ja) 2015-06-08 2016-03-10 Rdbシステム

Publications (1)

Publication Number Publication Date
KR20180006484A true KR20180006484A (ko) 2018-01-17

Family

ID=55440549

Family Applications (1)

Application Number Title Priority Date Filing Date
KR1020187000034A KR20180006484A (ko) 2015-06-08 2016-03-10 Rdb 시스템

Country Status (7)

Country Link
US (1) US20180357297A1 (ko)
EP (1) EP3306492A1 (ko)
JP (1) JP5877488B1 (ko)
KR (1) KR20180006484A (ko)
CN (1) CN107636652A (ko)
CA (1) CA2988688A1 (ko)
WO (1) WO2016199466A1 (ko)

Families Citing this family (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN107704367A (zh) * 2017-10-10 2018-02-16 郑州云海信息技术有限公司 一种资源周期信息展示方法和装置
CN108710660A (zh) * 2018-05-11 2018-10-26 上海核工程研究设计院有限公司 一种数据库的物项属性参数建模和存储方法

Family Cites Families (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2008197976A (ja) * 2007-02-14 2008-08-28 Fujitsu Ltd 連結情報生成プログラム及び連結情報生成方法
JP5324797B2 (ja) * 2007-02-26 2013-10-23 Soop株式会社 データ管理システム
JP2010157004A (ja) * 2008-12-26 2010-07-15 Toshiba Corp 情報編集支援装置、方法及びプログラム
CN102314647A (zh) * 2011-09-29 2012-01-11 广州中浩控制技术有限公司 一种利用xbrl进行的企业数据存储的方法
JP2013186774A (ja) * 2012-03-09 2013-09-19 Kansei Kogyo Kk 下水道維持管理のためのデータベースシステム
CN103870252A (zh) * 2012-12-11 2014-06-18 镇江金钛软件有限公司 资源管理方法和装置

Also Published As

Publication number Publication date
CN107636652A (zh) 2018-01-26
EP3306492A1 (en) 2018-04-11
WO2016199466A1 (ja) 2016-12-15
JP2017004183A (ja) 2017-01-05
JP5877488B1 (ja) 2016-03-08
US20180357297A1 (en) 2018-12-13
CA2988688A1 (en) 2016-12-15

Similar Documents

Publication Publication Date Title
EP4020248A1 (en) Technique for generating views of archived business data
US10872093B2 (en) Dynamically switching between data sources
US9535965B2 (en) System and method for specifying metadata extension input for extending data warehouse
CN105144080B (zh) 用于元数据管理的系统
RU2406115C2 (ru) Доступ к сложным данным
US9396284B2 (en) Method and system for implementing efficient updatable relational views over XML data
US8527867B2 (en) Enabling users to edit very large XML data
US20180144061A1 (en) Edge store designs for graph databases
US20140136472A1 (en) Methodology supported business intelligence (BI) software and system
US20180357330A1 (en) Compound indexes for graph databases
WO2017156144A1 (en) Source independent query language
JP7279524B2 (ja) データ管理プログラム、データ管理方法およびデータ管理システム
US20080263018A1 (en) Method and System for Mapping Business Objects to Relational Database Tables
KR20180006484A (ko) Rdb 시스템
JP4747213B2 (ja) 文書を収集するためのシステムおよびプログラム
JP2018109898A (ja) データマイグレーションシステム
JP6677809B2 (ja) アダプタ生成装置及び方法
Balster BIBFRAMEing for non-BIBFRAMErs: An introduction to current and future cataloging practices
Koch et al. Representation of CityGML instance models in BaseX
Yarabarla Learning Apache Cassandra
Ellison et al. Towards Platform Independent Database Modelling in Enterprise Systems
Brahmia et al. Schema evolution in conventional and emerging databases
Begum An Invigorating Perspective of a Practical Aspect of NoSQL Database
Begum A Deeper Examination of NoSQL Database Models and Characteristics
WO2023188049A1 (ja) メタデータ管理システム、メタデータ管理方法、プログラム

Legal Events

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