JP2003006010A - Method and device for controlling data transition, and processing program of the same - Google Patents
Method and device for controlling data transition, and processing program of the sameInfo
- Publication number
- JP2003006010A JP2003006010A JP2001189013A JP2001189013A JP2003006010A JP 2003006010 A JP2003006010 A JP 2003006010A JP 2001189013 A JP2001189013 A JP 2001189013A JP 2001189013 A JP2001189013 A JP 2001189013A JP 2003006010 A JP2003006010 A JP 2003006010A
- Authority
- JP
- Japan
- Prior art keywords
- record
- data
- parent
- child
- migration control
- Prior art date
- Legal status (The legal status 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 status listed.)
- Pending
Links
Landscapes
- Information Retrieval, Db Structures And Fs Structures Therefor (AREA)
Abstract
Description
【0001】[0001]
【発明の属する技術分野】本発明は、データベース基盤
の異なるシステム間のデータ移行技術に関し、特に、ネ
ットワーク構造データベース基盤のデータをリレーショ
ナルデータベース基盤のデータに移行するデータ移行制
御装置とその方法およびその処理プログラムに関する。BACKGROUND OF THE INVENTION 1. Field of the Invention The present invention relates to a data migration technique between systems having different database bases, and more particularly, to a data migration control device for migrating network structure database base data to relational database base data, its method and its processing. Regarding the program.
【0002】[0002]
【従来の技術】近年、コンピュータシステムで利用され
るデータベース(以下、DBという)はリレーショナル
データベース(以下、RDBという)が主流になってい
るが、従来のネットワーク構造データベース(以下、ネ
ットワーク構造DBという)で構築されたシステムは、
現在でも多く存在している。ネットワーク構造DBは、
データレコードにポインタを用いて、親レコードと子レ
コードとの親子関係を定義・対応させ、階層木構造に従
って記録するシステムである。2. Description of the Related Art In recent years, a relational database (hereinafter referred to as RDB) has become mainstream as a database (hereinafter referred to as DB) used in a computer system, but a conventional network structure database (hereinafter referred to as network structure DB). The system built with
Many still exist today. The network structure DB is
This is a system in which a pointer is used for a data record to define and associate a parent-child relationship between a parent record and a child record, and records according to a hierarchical tree structure.
【0003】このネットワーク構造DBの利用主体で
は、データ操作やシステム運用がより容易なRDBへの
システム移行への要望が非常に強い。DBシステムの移
行方法は、例えば、特開平10−307742号公報
(以下、文献1という)に示されている。この文献1で
は、ネットワーク構造DBの個々のレコードをRDBに
移行する際に、ポインタを参照してリレーションキーを
追加することで、移行前の親レコードおよび子レコード
を、それぞれリレーションシップを有する各表にそれぞ
れ記憶させている。The users who use this network structure DB have a very strong demand for system migration to an RDB, which facilitates data operation and system operation. A DB system migration method is disclosed in, for example, Japanese Patent Laid-Open No. 10-307742 (hereinafter referred to as Document 1). In this document 1, when each record of the network structure DB is migrated to the RDB, a relation key is added by referring to a pointer, so that the parent record and the child record before the migration are each table having a relationship. Have each remembered.
【0004】[0004]
【発明が解決しようとする課題】ネットワーク構造DB
では、レコードの親子関係はポインタで管理されてお
り、親レコードにアクセスした時点において、関連する
子レコードの情報は絞り込まれている。このため、子レ
コードをアクセスする際に生じるI/Oは比較的少な
い。[Problem to be Solved by the Invention] Network structure DB
In, the parent-child relationship of records is managed by pointers, and the information of related child records is narrowed down when the parent record is accessed. Therefore, the I / O generated when accessing the child record is relatively small.
【0005】しかしながら、上述の文献1のような方法
で移行する場合、移行後のアプリケーションは、親レコ
ードに対応する表と、子レコードに対応する表のそれぞ
れに対して、リレーションシップを検索するアクセス命
令を発するため、I/O回数が増加する。このため、処
理能力の低下を招くことになる。この問題を解消するた
めには、ネットワーク構造DB基盤のデータを、RDB
基盤に移行する際に、データ構造の見直し・変更を行う
必要がある。データ構造の変更は、そのデータを処理対
象とするアプリケーションの処理ロジック全体に大きく
影響する。このために、その変更に伴う改修量が多くな
り、これに比例して、DBシステムの移行のための作業
時間・作業費用の負担は大きくなっていた。However, when the migration is performed by the method described in the above-mentioned Document 1, the application after migration has access to search the relationship between the table corresponding to the parent record and the table corresponding to the child record. Since the instruction is issued, the number of I / Os increases. As a result, the processing capacity is lowered. In order to solve this problem, the data of network structure DB base is changed to RDB.
It is necessary to review and change the data structure when moving to the base. The change in the data structure greatly affects the entire processing logic of the application that processes the data. For this reason, the amount of renovation accompanying the change has increased, and in proportion to this, the burden of work time and work cost for migrating the DB system has increased.
【0006】本発明は、上述のような課題に鑑みてなさ
れ、その目的は、アプリケーション移行後の性能を低下
させることなく短時間で、ネットワーク構造DB基盤の
データをRDB基盤のデータに移行するデータ移行制御
装置とその方法およびその処理プログラムを提供するこ
とにある。The present invention has been made in view of the above problems, and an object thereof is data for migrating network structure DB-based data to RDB-based data in a short time without degrading the performance after application migration. It is to provide a migration control device, its method, and its processing program.
【0007】[0007]
【課題を解決するための手段】(1)上記目的を達成す
るために、本発明に係るデータ移行制御装置は、ポイン
タにより親子関係が親レコードと子レコードとの間で構
築されてなるネットワーク構造データベース基盤のデー
タを、RDB基盤のデータに移行するデータ移行制御装
置において、親レコードをRDBの表に移行し、これと
対応して、この親レコードと親子関係にある子レコード
を、表の親レコードが移行された行と同じ行に移行する
レコード移行手段を有することを特徴とする。(1) In order to achieve the above object, a data migration control device according to the present invention is a network structure in which a parent-child relationship is constructed between a parent record and a child record by a pointer. In a data migration control device for migrating database-based data to RDB-based data, a parent record is migrated to an RDB table, and correspondingly, a child record having a parent-child relationship with this parent record is converted into a table parent. It is characterized by having a record transfer means for transferring a record to the same line as the line to which the record has been transferred.
【0008】(2)また、本発明に係るデータ移行制御
装置は、上記(1)において、親子関係に基づき参照し
た親レコードと子レコードとの各々に対し、レコードを
構成する複数のデータ型に対応する抽象データ型を定義
し、この抽象データ型が定義された親レコードおよび子
レコードに対してリレーショナルデータベースでのデー
タ操作を行うためのユーザ定義関数を生成する抽象デー
タ型移行手段をさらに有することを特徴とする。(2) Further, in the data migration control device according to the present invention, in the above (1), for each of the parent record and the child record referred to based on the parent-child relationship, a plurality of data types constituting the record are created. An abstract data type migration means for defining a corresponding abstract data type and for generating a user-defined function for performing data operation in a relational database with respect to a parent record and a child record in which the abstract data type is defined. Is characterized by.
【0009】[0009]
【発明の実施の形態】以下に本発明の実施の形態を、図
1〜図9を用いて詳細に説明する。図1は、第1の実施
形態における、データ移行制御装置を含むDBシステム
全体の構成例を示すブロック図である。図2は、第1の
実施形態において、データ型移行処理部の動作の概略を
示すためのフローチャートである。図3は、第1の実施
形態における、データ型移行処理部の動作をさらに詳細
に説明するための図である。図4は、第1の実施形態に
おける、レコード移行処理部の動作の概略を示すための
フローチャートである。図5は、第1の実施形態におけ
る、レコード移行処理部の動作をさらに詳細に説明する
ための図である。図6は、第2の実施形態における、デ
ータ移行制御装置を含むDBシステム全体の構成例を示
すブロック図である。図7は、第2の実施形態におけ
る、データ移行制御装置に設けられたデータ操作命令変
更処理部の動作の概略を示すためのフローチャートであ
る。図8は、第2の実施形態における、データ操作命令
変更処理部の動作をさらに詳細に説明するための図であ
る。図9は、第2の実施形態における、データ操作命令
変更処理部によって変換されたアプリケーションの、レ
コード検索時処理例を説明するための図である。BEST MODE FOR CARRYING OUT THE INVENTION Embodiments of the present invention will be described in detail below with reference to FIGS. FIG. 1 is a block diagram showing a configuration example of the entire DB system including a data migration control device in the first exemplary embodiment. FIG. 2 is a flow chart for outlining the operation of the data type migration processing unit in the first embodiment. FIG. 3 is a diagram for explaining the operation of the data type migration processing unit according to the first embodiment in more detail. FIG. 4 is a flowchart showing an outline of the operation of the record migration processing unit in the first embodiment. FIG. 5 is a diagram for explaining the operation of the record migration processing unit according to the first embodiment in more detail. FIG. 6 is a block diagram showing a configuration example of the entire DB system including the data migration control device in the second exemplary embodiment. FIG. 7 is a flowchart for outlining the operation of the data operation instruction change processing unit provided in the data migration control device according to the second embodiment. FIG. 8 is a diagram for explaining the operation of the data operation instruction change processing unit in the second embodiment in more detail. FIG. 9 is a diagram for explaining a record search processing example of the application converted by the data operation instruction change processing unit according to the second embodiment.
【0010】(第1の実施形態)図1には、本発明に係
るデータ移行制御装置100が用いられる、DB移行シ
ステムの全体図を示している。このDB移行システム
は、データ移行制御装置100、ネットワーク階層DB
システム110およびRDBシステム120を有して構
成されている。データ移行制御装置100は、ネットワ
ーク階層DBシステム110とRDBシステム120と
に接続されている。(First Embodiment) FIG. 1 shows an overall view of a DB migration system in which a data migration control device 100 according to the present invention is used. This DB migration system includes a data migration control device 100 and a network hierarchy DB.
It has a system 110 and an RDB system 120. The data migration control device 100 is connected to the network hierarchy DB system 110 and the RDB system 120.
【0011】ネットワーク階層DBシステム110は、
DB定義112、およびネットワーク階層DB114を
有して構成されている。ネットワーク階層DBシステム
110は、上述したように、データレコードにポインタ
を用いて、親レコードと子レコードとの親子関係を定義
・対応させ、階層木構造に従って記録するシステムであ
る。DB定義112には、この親子関係が定義されてい
る。ネットワーク階層DB114には、親子関係に基づ
いた諸データが記憶されている。RDBシステム120
は、表自体には階層構造を持たず、表内の特定の列デー
タを介して他の表とリレーションシップが相互に定義さ
れている。The network hierarchy DB system 110 is
It has a DB definition 112 and a network hierarchy DB 114. As described above, the network hierarchy DB system 110 is a system that uses a pointer to a data record to define and associate a parent-child relationship between a parent record and a child record, and records according to a hierarchical tree structure. This parent-child relationship is defined in the DB definition 112. The network hierarchy DB 114 stores various data based on the parent-child relationship. RDB system 120
Does not have a hierarchical structure in the table itself, and the relationship with other tables is mutually defined through specific column data in the table.
【0012】データ移行制御装置100は、データ型移
行処理部102、およびレコード移行処理部104を有
して構成されている。データ型移行処理部102は、ネ
ットワーク階層DBシステム110のDB定義112の
データ型を参照して、RDBシステム120に表定義1
22として同じデータ型を有するDB定義を生成する。
レコード移行処理部104は、ネットワーク階層DBシ
ステム110のネットワーク階層DB114に記憶され
た諸データを、RDB124に記憶させる。The data migration control device 100 comprises a data type migration processing unit 102 and a record migration processing unit 104. The data type migration processing unit 102 refers to the data type of the DB definition 112 of the network hierarchy DB system 110, and sets the table definition 1 to the RDB system 120.
A DB definition having the same data type as 22 is generated.
The record migration processing unit 104 causes the RDB 124 to store various data stored in the network layer DB 114 of the network layer DB system 110.
【0013】以下に、図1に示したデータ移行制御装置
100の動作を図2〜図6を用いて説明する。The operation of the data migration control device 100 shown in FIG. 1 will be described below with reference to FIGS.
【0014】初めに、図2,3を用いて、図1に示した
データ型移行処理部102の動作について説明する。図
2はデータ型移行処理部102の動作の概略を示してい
る。データ型移行処理部102は、ネットワーク階層D
Bシステム110のDB定義として記憶された、レコー
ド型A112−1およびレコード型B112−2の関連
情報が定義されているDB定義112の親子集合AB
(図示しない)から、レコード型A112−1、レコー
ド型B112−2のレコード型の定義を取得する。デー
タ型移行処理部102は、レコード型A112−1を抽
象データ型とする抽象データ型A122−1として、ま
た、レコード型B112−2を抽象データ型とする抽象
データ型B122−2として、それぞれのデータ型を対
応させて作成する(ステップS201)。抽象データ型
A122−1,抽象データ型B122−2のデータ操作
を行うため定義された関数である、レコードAのユーザ
ー定義関数、レコードBのユーザー定義関数をそれぞれ
作成する(ステップS202)。First, the operation of the data type migration processing unit 102 shown in FIG. 1 will be described with reference to FIGS. FIG. 2 shows an outline of the operation of the data type migration processing unit 102. The data type migration processing unit 102 uses the network layer D.
Parent-child set AB of DB definition 112 in which related information of record type A 112-1 and record type B 112-2 is stored, which is stored as DB definition of B system 110
From (not shown), the record type definitions of the record type A 112-1 and the record type B 112-2 are acquired. The data type migration processing unit 102 uses the record type A112-1 as an abstract data type A122-1 as an abstract data type and the record type B112-2 as an abstract data type B122-2 as an abstract data type B122-2. The data types are created in association with each other (step S201). A user-defined function of record A and a user-defined function of record B, which are functions defined for performing data operations of the abstract data type A 122-1 and the abstract data type B 122-2, are created (step S202).
【0015】他に移行対象となるレコード型が、DB定
義として記憶されているか否かを検索する(ステップS
203)。移行対象となる他のレコード型がなければ、
移行対象となる親子集合型があるか否かを検索する(ス
テップS204)。移行対象の親子集合型がなければ、
作成した抽象データ型を基に、RDBでの表情報を定義
した表定義を作成する(ステップS207)。移行対象
の親子集合型があれば、親子集合型に対応する抽象デー
タ型を作成する(ステップS205)。さらに、他の移行
対象の親子集合型があるかを検索する(ステップS20
6)。移行対象の親子集合型があれば、再度、親子集合
型に対応する抽象データ型を作成するステップS205
に戻り、以後同様の処理が行われる。In addition, it is searched whether or not the record type to be migrated is stored as a DB definition (step S).
203). If there are no other record types to be migrated,
It is searched whether or not there is a parent-child set type to be transferred (step S204). If there is no parent-child set type to be migrated,
A table definition defining table information in the RDB is created based on the created abstract data type (step S207). If there is a parent-child set type to be migrated, an abstract data type corresponding to the parent-child set type is created (step S205). Furthermore, it is searched whether there is another parent-child set type to be migrated (step S20).
6). If there is a parent-child set type to be migrated, again create an abstract data type corresponding to the parent-child set type in step S205.
Then, the same processing is performed thereafter.
【0016】次に、図3を用いて、図2で説明したデー
タ型移行処理部102(図3ではデータ型移行処理部3
00に対応)の詳細を説明する。DB定義として、レコ
ード型A312(図1のレコード型A112−1に対
応)、レコード型B314(図1のレコード型B112
−2に対応)、および親子関係情報316(図1では特
に図示せず)が定義されている。Next, with reference to FIG. 3, the data type migration processing unit 102 described in FIG. 2 (the data type migration processing unit 3 in FIG. 3 will be described.
(Corresponding to 00) will be described in detail. As the DB definition, a record type A312 (corresponding to the record type A112-1 in FIG. 1), a record type B314 (record type B112 in FIG. 1).
-2), and parent-child relationship information 316 (not particularly shown in FIG. 1) are defined.
【0017】データ型移行処理部300は、このレコー
ド型A312を基に、レコードAの抽象データ型の定義
322aと、レコードAのユーザー定義関数の定義32
2bを生成する。抽象データ型の定義322aのデータ
型は、移行前のレコードA312と同じである。レコー
ドAのユーザー定義関数322bは、SQL(構造化照
会言語)データの操作・実行を可能とする関数である。Based on the record type A312, the data type migration processing unit 300 defines the abstract data type definition 322a of the record A and the user-defined function definition 32 of the record A.
2b is generated. The data type of the abstract data type definition 322a is the same as that of the record A312 before the migration. The user-defined function 322b of the record A is a function that enables manipulation / execution of SQL (structured query language) data.
【0018】同様に、データ型移行処理部300は、レ
コード型B314を基に、レコードBの抽象データ型の
定義324aと、レコードBのユーザー定義関数の定義
324bを生成する。抽象データ型の定義324aのデ
ータ型は、移行前のレコードB314と同じである。レ
コードBのユーザー定義関数324bは、SQLデータ
の操作・実行を可能とする関数である。Similarly, the data type migration processing unit 300 generates the abstract data type definition 324a of the record B and the user-defined function definition 324b of the record B based on the record type B314. The data type of the abstract data type definition 324a is the same as that of the record B314 before migration. The user-defined function 324b of the record B is a function that enables manipulation / execution of SQL data.
【0019】また、データ型移行処理部300は、親子
集合AB定義316を基に、レコードABという名称の
抽象データ型の定義326aと、レコードABという名
称の定義326bとを生成する。抽象データ型の定義3
26aは、レコード型ABを定義している。このレコー
ド型ABは、定義322aの抽象データ型のレコードA
の列と、定義324aの抽象データ型のレコードBの繰
り返し構造の列とで構成されている。Further, the data type migration processing section 300 generates an abstract data type definition 326a named record AB and a definition 326b named record AB based on the parent-child set AB definition 316. Abstract data type definition 3
26a defines a record type AB. This record type AB is an abstract data type record A of the definition 322a.
And the column of the repeating structure of the record B of the abstract data type of the definition 324a.
【0020】ここで、繰り返し構造の列とは、配列構造
の列のうち、配列の要素数が可変であるものをさしてお
り、多値属性の列の一種である。レコードBの列を繰り
返し構造の列とすることで、親子関係を同一レコード内
に表現している。表定義326bは、定義326aで宣
言したレコード型ABという抽象データ型のレコードA
Bという名称の列で構成され、レコードABの表の論理
構造を定義している。Here, the column of the repeating structure refers to a column of the array structure in which the number of elements of the array is variable, and is a kind of the column of the multi-valued attribute. By making the column of record B a column having a repeating structure, the parent-child relationship is expressed in the same record. The table definition 326b is a record A of an abstract data type called the record type AB declared in the definition 326a.
It is composed of a column named B and defines the logical structure of the table of record AB.
【0021】次に、図4、5を用いて、図1に示したレ
コード移行処理部104の動作について説明する。Next, the operation of the record migration processing unit 104 shown in FIG. 1 will be described with reference to FIGS.
【0022】図4は、図1におけるレコード移行処理部
104の動作の概略を示している。レコード移行処理部
104は、ネットワーク階層DB114の親レコード
(ここではレコードA114−1)を検索する(ステッ
プS401)。レコード移行処理部104は、親レコー
ドが存在するか否かを判定する(ステップS402)。
レコード移行処理部104は、親レコードが存在すれ
ば、対応するレコードである、ネットワーク階層DB1
14の子レコード(ここではレコードB114−2)を
検索する(ステップS403)。レコード移行処理部1
04は、子レコードが存在するか否かを判定する(ステ
ップS404)。存在したならば、レコード移行処理部
104は、親レコードと子レコードとを対応するRDB
124の行に記憶する(ステップS405)。上記ステ
ップ404において、子レコードが存在しなければ、親
レコードのみを対応するRDB124の行に記憶する
(ステップS406)。FIG. 4 shows an outline of the operation of the record migration processing section 104 in FIG. The record migration processing unit 104 searches the parent record (here, the record A114-1) in the network hierarchy DB 114 (step S401). The record migration processing unit 104 determines whether or not a parent record exists (step S402).
If the parent record exists, the record migration processing unit 104 is the corresponding record, which is the network hierarchy DB 1.
The 14 child records (here, record B114-2) are searched (step S403). Record migration processing unit 1
04 determines whether a child record exists (step S404). If it exists, the record migration processing unit 104 assigns the parent record and the child record to the corresponding RDB.
It is stored in line 124 (step S405). If there is no child record in step 404, only the parent record is stored in the corresponding row of the RDB 124 (step S406).
【0023】次に、図5を用いて、図1のレコード移行
処理部104(図5ではレコード移行処理部500に対
応)の動作を詳細に説明する。ネットワーク階層DBシ
ステム510内においては、親レコードであり、かつ、
内容「A1」を有する親レコード531と、内容「A
2」532を有する親レコード532とを有する。ま
た、親レコード531の子レコードであり内容「B1」
を有する子レコード533と、親レコード532の子レ
コードであり内容「B2」を有する子レコード534,
内容「B3」を有する子レコード535とを有する。な
お、図1における親レコードA114−1が図4の親レ
コード531,532に、図1における子レコードA1
14−2が図4の子レコード533,534,535に
それぞれ対応している。Next, the operation of the record migration processing unit 104 of FIG. 1 (corresponding to the record migration processing unit 500 in FIG. 5) will be described in detail with reference to FIG. In the network hierarchy DB system 510, it is a parent record, and
The parent record 531 having the content “A1” and the content “A1”
2 ”532 and the parent record 532. In addition, the content is “B1” which is a child record of the parent record 531.
A child record 533 having a parent record 532 and a child record 534 having a content “B2” which is a child record of the parent record 532.
Child record 535 having the content “B3”. The parent record A114-1 in FIG. 1 is replaced with the parent records 531 and 532 in FIG. 4 and the child record A1 in FIG.
14-2 corresponds to the child records 533, 534 and 535 of FIG. 4, respectively.
【0024】レコード移行処理部500は、親レコード
531と子レコード533とを参照し、RDB520内
の行551内に記憶する。親レコード531と列データ
541とは同一内容「A1」である。子レコード533
と列データ543とは同一内容「B1」である。親レコ
ード531と子レコード533とが親子関係にあるとい
う関連性は、RDBシステム520内の同一の行551
に記憶され識別される。The record migration processing unit 500 refers to the parent record 531 and the child record 533 and stores them in the row 551 in the RDB 520. The parent record 531 and the column data 541 have the same content “A1”. Child record 533
And the column data 543 have the same content “B1”. The relationship that the parent record 531 and the child record 533 have a parent-child relationship is related to the same line 551 in the RDB system 520.
Stored and identified in.
【0025】同様に、レコード移行処理部500は、親
レコード532と子レコード534,535とを参照
し、RDB520内の行552内に記憶する。親レコー
ド532と列データ542とは同一内容「A2」であ
る。子レコード534と列データ544とは同一内容
「B2」である。子レコード535と列データ545と
は同一内容「B3」である。親レコード531と子レコ
ード534,535とが親子関係にあるという関連性
は、RDBシステム520内の同一の行552に記憶さ
れ識別される。Similarly, the record migration processing section 500 refers to the parent record 532 and the child records 534 and 535 and stores them in the row 552 in the RDB 520. The parent record 532 and the column data 542 have the same content “A2”. The child record 534 and the column data 544 have the same content “B2”. The child record 535 and the column data 545 have the same content “B3”. The relationship that the parent record 531 and the child records 534 and 535 have a parent-child relationship is stored and identified in the same row 552 in the RDB system 520.
【0026】繰り返し構造の列には、同一の行内に複数
個のデータをもつことができる。このため、列データ5
44,545は共に同一の行552内に記憶されてい
る。このように、ネットワーク階層DB510における
親子関係にあるレコードを、RDB520の同一の行に
記憶することでその関連性を識別できるようになる。A column having a repeating structure can have a plurality of data in the same row. Therefore, column data 5
Both 44 and 545 are stored in the same row 552. In this way, by storing records having a parent-child relationship in the network hierarchy DB 510 in the same row of the RDB 520, it becomes possible to identify the relationship.
【0027】本発明に係るデータ移行制御装置では、I
/O回数の増加を抑制するようなデータ構造を作成する
ようにネットワーク構造DB基盤のデータからRDB基
盤のデータに移行する処理を行うことで、データ処理性
能を低下させることなくシステム移行処理を行うことが
できる。In the data migration control device according to the present invention, I
By performing a process of migrating from network structure DB-based data to RDB-based data so as to create a data structure that suppresses an increase in the number of / Os, system migration processing is performed without degrading data processing performance. be able to.
【0028】(第2の実施形態)図6には、本発明に係
るデータ移行制御装置600が用いられる、DB移行シ
ステムの全体図を示している。このDB移行システム
は、データ移行制御装置600、ネットワーク階層DB
システム610およびRDBシステム620を有して構
成されている。本実施形態において、データ移行制御装
置600は、図1に比べて、さらにデータ操作命令変更
処理部606を有している。また、本実施形態では、図
1に比べて、ネットワーク階層DBシステム610、お
よびRDBシステム620に、アプリケーションが記憶
されていることがさらに明示されている。データ移行制
御装置600は、ネットワーク階層DBシステム610
とRDBシステム620とに接続されている。(Second Embodiment) FIG. 6 shows an overall view of a DB migration system in which a data migration control device 600 according to the present invention is used. This DB migration system includes a data migration control device 600, a network hierarchy DB
It has a system 610 and an RDB system 620. In the present embodiment, the data migration control device 600 further includes a data operation command change processing unit 606 as compared with FIG. Further, in the present embodiment, it is further clarified that the application is stored in the network hierarchy DB system 610 and the RDB system 620, as compared with FIG. The data migration control device 600 includes a network hierarchy DB system 610.
And the RDB system 620.
【0029】以下に、図7〜図9を用いて、図6に示し
たデータ移行制御装置600の特徴的な処理を行うデー
タ操作命令変更処理部606動作について説明する。The operation of the data operation command change processing unit 606 which performs the characteristic processing of the data migration control device 600 shown in FIG. 6 will be described below with reference to FIGS. 7 to 9.
【0030】図7はデータ操作命令変更処理部606の
動作の概略を説明するためのフローチャートである。ま
ず、データ操作命令変更処理部606は、アプリケーシ
ョン記憶部616に記憶された、データ操作命令を検索
する(ステップS701)。FIG. 7 is a flow chart for explaining the outline of the operation of the data operation command change processing unit 606. First, the data operation instruction change processing unit 606 retrieves the data operation instruction stored in the application storage unit 616 (step S701).
【0031】データ操作命令変更処理部606は、デー
タ操作命令が検索の命令か否かを判定し(ステップS7
02)、検索の命令であればさらに操作対象のレコード
が親レコードか否かを判定する(ステップS703)。
親レコードであれば、親レコードに対応する抽象データ
型を持つ列に対する検索SQLに変換する(ステップS
704)。上記ステップS703の判定の結果、親レコ
ードでなければ、子レコードに対応する抽象データ型を
持つ列に対する検索SQLに変換する(ステップS70
5)。The data operation command change processing unit 606 determines whether or not the data operation command is a search command (step S7).
02), if it is a search command, it is further determined whether or not the operation target record is a parent record (step S703).
If it is a parent record, it is converted into a search SQL for a column having an abstract data type corresponding to the parent record (step S
704). If the result of determination in step S703 is not a parent record, it is converted to search SQL for a column having an abstract data type corresponding to the child record (step S70).
5).
【0032】次にデータ操作命令が更新の命令か否かを
判定し(ステップS706)、更新の命令であれば、さ
らに操作対象のレコードが親レコードか否かを判定する
(ステップS707)。親レコードであれば、親レコー
ドに対応する抽象データ型を持つ列に対する更新SQL
に変換する(ステップS708)。親レコードでなけれ
ば子レコードに対応する抽象データ型を持つ列に対する
更新SQLに変換する(ステップS709)。Next, it is determined whether or not the data operation instruction is an update instruction (step S706), and if it is an update instruction, it is further determined whether or not the operation target record is a parent record (step S707). If it is a parent record, update SQL for a column having an abstract data type corresponding to the parent record
(Step S708). If it is not the parent record, it is converted into the update SQL for the column having the abstract data type corresponding to the child record (step S709).
【0033】次に、データ操作命令が記憶の命令か否か
を判定し(ステップS710)、記憶の命令であれば、
さらに操作対象のレコードが親レコードか否かを判定す
る(ステップS711)。親レコードであれば、親レコ
ードに対応する抽象データ型を持つ列に対する記憶SQ
Lに変換する(ステップS712)。親レコードでなけ
れば、子レコードに対応する抽象データ型を持つ列に対
する更新SQLに変換する(ステップS713)。Next, it is determined whether or not the data operation instruction is a storage instruction (step S710).
Further, it is determined whether or not the operation target record is a parent record (step S711). If it is a parent record, the storage SQ for the column having the abstract data type corresponding to the parent record
Convert to L (step S712). If it is not the parent record, it is converted into the update SQL for the column having the abstract data type corresponding to the child record (step S713).
【0034】次に、データ操作命令が削除の命令か否か
を判定し(ステップS714)、削除の命令であれば、
さらに操作対象のレコードが親レコードか否かを判定す
る(ステップS715)。親レコードであれば、親レコ
ードに対応する抽象データ型を持つ列に対する削除SQ
Lに変換する(ステップS716)。親レコードでなけ
れば、子レコードに対応する抽象データ型を持つ列に対
する更新SQLに変換する(ステップS717)。最後
にすべてのデータ操作命令をサーチしたか否かを判定し
(ステップS718)、まだ残りがあれば最初のステッ
プS701に戻り引き続き処理を行い、残りがなければ
終了する。Next, it is judged whether or not the data operation instruction is a deletion instruction (step S714).
Further, it is determined whether or not the operation target record is a parent record (step S715). If it is a parent record, delete SQ for the column having the abstract data type corresponding to the parent record
Convert to L (step S716). If it is not the parent record, it is converted into the update SQL for the column having the abstract data type corresponding to the child record (step S717). Finally, it is determined whether or not all the data operation commands have been searched (step S718), and if there is any remaining, the process returns to the first step S701 to continue the processing, and if there is no remaining, the process ends.
【0035】次に、図8を用いて、既存のアプリケーシ
ョンの変更について、レコード検索の場合の例とレコー
ド更新の場合の例とについて説明する。Next, with reference to FIG. 8, an example of a record search and an example of a record update will be described regarding the modification of an existing application.
【0036】図8は、本発明のデータ操作命令変更処理
部800(図6の操作命令変更処理部606に対応)で
変更したアプリケーション処理部のレコード検索時のデ
ータアクセス処理の例を示している。図8中のネットワ
ーク階層DBシステム810(図6のネットワーク階層
DBシステム610に対応)における検索例で、RDB
システム820(図6のRDBシステム620に対応)
における検索例である。ネットワーク階層DBシステム
810における検索例では、FIG. 8 shows an example of data access processing at the time of record retrieval of the application processing section changed by the data operation instruction change processing section 800 (corresponding to the operation instruction change processing section 606 of FIG. 6) of the present invention. . In the search example in the network hierarchy DB system 810 (corresponding to the network hierarchy DB system 610 in FIG. 6) in FIG.
System 820 (corresponding to RDB system 620 in FIG. 6)
Is an example of a search in In the search example in the network hierarchy DB system 810,
【0037】 (a1) FIND FIRST レコードA WHERE 項目AA=?? GET レコードA (b1) FIND NEXT レコードB IN 親子集合AB GET レコードB (c1) FIND NEXT レコードB IN 親子集合AB GET レコードB[0037] (A1) FIND FIRST record A WHERE item AA =? ? GET record A (B1) FIND NEXT record B IN parent-child set AB GET record B (C1) FIND NEXT record B IN parent-child set AB GET record B
【0038】というデータ操作命令が記述されているこ
ととする。(a1)では親レコードである「レコード
A」に対して項目AAに対する検索条件を指定したFI
ND文でレコード検索を行い、ヒットしたレコードをG
ET文で取得する。RDBシステム820の行852を
例として以下に説明する。なお、「A1」、「B1」な
どはそのレコードの内容を示している。この例では内容
「A2」のレコード832が取得されている。(b1)
では子レコードである「レコードB」に対する親子集合
内検索である。FIND文で検索を行い、ヒットしたレ
コードをGET文で取得する。この例では「A2」の親
レコードの子レコードである「B2」のレコード834
が取得されている。(c1)は(b1)と同様の子レコ
ードに対する親子集合内検索であり、子レコードである
「B3」のレコード835が取得される。It is assumed that the data operation instruction is written. In (a1), the FI specifying the search condition for the item AA for the parent record “record A”
Perform a record search with the ND sentence, and find the record that hit
Get by ET sentence. The row 852 of the RDB system 820 will be described below as an example. Note that "A1", "B1", etc. indicate the contents of the record. In this example, the record 832 having the content “A2” is acquired. (B1)
Then, it is a search in the parent-child set for the child record “record B”. The FIND sentence is used for retrieval, and the hit record is obtained by the GET sentence. In this example, the record 834 of “B2”, which is a child record of the parent record of “A2”
Has been acquired. (C1) is a search within the parent-child set for the child record similar to (b1), and the record 835 of the child record "B3" is acquired.
【0039】このようなデータ操作をデータ操作変更プ
ログラム800により変更すると以下のようになる。When such data operation is changed by the data operation change program 800, it becomes as follows.
【0040】 (a2) DECLARE カーソルA CURSOR FOR SELECT レコードAB.レコードA FROM レコードAB WHERE レコードAB.レコードA.項目AA=?? OPEN カーソルA FETCH カーソルA INTO :PA (b2) DECLARE カーソルB CURSOR FOR SELECT Y.CB FROM レコードAB AS X UNNEST(X.レコードAB.レコードB)AS Y(CB) WHERE X.レコードAB.レコードA.項目AA=?? OPEN カーソルB FETCH カーソルB INTO :PB (c2) FETCH カーソルB INTO :PB[0040] (A2) DECLARE cursor A CURSOR FOR SELECT record AB. Record A FROM record AB WHERE Record AB. Record A. Item AA =? ? OPEN cursor A FETCH cursor A INTO: PA (B2) DECLARE cursor B CURSOR FOR SELECT Y. CB FROM Record AB AS X UNNEST (X. record AB. Record B) AS Y (CB) WHERE X. Record AB. Record A. Item AA =? ? OPEN cursor B FETCH cursor B INTO: PB (C2) FETCH cursor B INTO: PB
【0041】(a2)は(a1)のデータ操作をRDB
用に変換したものである。ネットワーク階層DBにおけ
るFIND文はRDBではSELECT文に対応させ、
さらにRDBに対する検索結果を1件づつ取り扱うため
にカーソルを利用する方法であるDECLARE CU
RSOR文に置き換える。DECLARE CURSO
R文の中の検索の記述では、(a1)で検索対象となる
レコード名「レコードA」を(a2)では検索対象とな
る表名として「レコードAB」に、検索対象となる列名
として「レコードAB.レコードA」にそれぞれ置き換
える。さらに、検索条件式は(a1)で「項目AA=?
?」となっているものを(a2)では列名を追加して
「レコードAB.レコードA.項目AA=??」に置き
換える。DECLARE CURSOR文の次にはOP
EN文を記述して、カーソルを利用した検索ができるよ
うにする。(a1)で検索結果を受け取る命令であるG
ET文は(a2)ではFETCH文に置き換える。これ
により、(a2)では(a1)の検索結果と同じ値であ
る「A2」の列データ842を受け取ることができる。(A2) RDB the data operation of (a1)
It was converted for. The FIND statement in the network hierarchy DB corresponds to the SELECT statement in RDB,
In addition, DECLARE CU is a method that uses a cursor to handle search results for RDB one by one.
Replace with RSOR statement. DECLARE CURSO
In the description of the search in the R sentence, the record name “record A” to be searched in (a1) is set to “record AB” as the table name to be searched in (a2), and the column name to be searched is “record AB”. Record AB. Record A ". Furthermore, the search condition expression is (a1) and "item AA =?
? The column name is added in (a2) and replaced with “record AB. Record A. item AA = ??”. OP after DECLARE CURSOR statement
Describe the EN sentence to enable searching using the cursor. G which is an instruction to receive the search result in (a1)
The ET sentence is replaced with the FETCH sentence in (a2). As a result, in (a2), the column data 842 of "A2", which is the same value as the search result in (a1), can be received.
【0042】(b2)は(b1)のデータ操作をRDB
用に変換したものである。ネットワーク階層DBにおけ
る子レコード検索は、RDBでは子レコード部分に対応
する繰り返し構造の列に対する検索に置き換える。この
とき、SQL文のUNNEST機能を使用することによ
り繰り返し構造の列の各要素をひとつの表の行のように
扱うことができるようにする。UNNEST機能は国際
規格SQL99で追加された機能で、配列構造の列の部
分を表にみたてて配列の要素を表の中の行のように参照
できる機能である。(B2) RDB the data operation of (b1)
It was converted for. In the RDB, the child record search in the network hierarchy DB is replaced with a search for a column having a repeating structure corresponding to the child record part. At this time, the UNNEST function of the SQL statement is used so that each element of the column of the repeating structure can be treated like a row of one table. The UNNEST function is a function added in the international standard SQL99, and is a function of referring to a column portion of an array structure in a table and referring to array elements like a row in the table.
【0043】この考え方をベースにして、(a2)の場
合と同様にネットワーク階層DBにおけるFIND文は
RDBではSELECT文に対応させ、さらにRDBに
対する検索結果を1件づつ取り扱うためにカーソルを利
用する方法であるDECLARE CURSOR文に置
き換える。DECLARE CURSOR文の中の検索
の記述では、記述の便宜上の理由により表名「レコード
AB」の別名「X」を宣言して使用し、繰り返し構造の
列の部分「X.レコードAB.レコードB」をUNNE
ST機能により表にみたててそれを別名「Y(CB)」
と宣言して使用している。On the basis of this idea, as in the case of (a2), the FIND statement in the network hierarchy DB is made to correspond to the SELECT statement in RDB, and the cursor is used to handle the search results for RDB one by one. Is replaced with the DECLARE CURSOR statement. In the description of the search in the DECLARE CURSOR statement, the alias "X" of the table name "record AB" is declared and used for convenience of description, and the column portion "X. record AB. Record B" of the repeating structure is used. UNNE
It is also called "Y (CB)" by looking at it by the ST function.
Is declared and used.
【0044】(b1)の検索では検索条件は特に指定さ
れていないが、これは親子集合内検索であり、ネットワ
ーク階層DBの親レコードと子レコードはRDBでは一
つの表の同じ行に対応させるために、親レコードに対す
る検索条件に相当する(a2)の「レコードAB.レコ
ードB=??」の検索条件を、(b2)のデータ操作の
対象となる行を特定するための検索条件として追加す
る。DECLARE CURSOR文の次にはOPEN
文を記述して、カーソルを利用した検索ができるように
する。(b1)で検索結果を受け取る命令であるGET
文は(b2)ではFETCH文に置き換える。これによ
り、(b2)では(b1)の検索結果と同じ値である
「B2」の列データ844を受け取ることができる。In the search of (b1), the search condition is not specified, but this is a search within the parent-child set, and the parent record and the child record of the network hierarchy DB correspond to the same row of one table in the RDB. In addition, the search condition of “record AB. Record B = ??” of (a2) corresponding to the search condition for the parent record is added as a search condition for identifying the row for the data operation of (b2). . After the DECLARE CURSOR statement, OPEN
Write a sentence so that you can search using the cursor. GET which is an instruction to receive the search result in (b1)
The sentence is replaced with the FETCH sentence in (b2). As a result, in (b2), the column data 844 of "B2" having the same value as the search result of (b1) can be received.
【0045】(c2)は(c1)のデータ操作をRDB
用に変換したものである。(c1)のFIND文は(b
1)の検索後の次の子レコード検索でありRDBでは
(b2)で宣言したカーソルをそのまま使用できるた
め、RDBでは他の命令に置き換えない。(c1)で検
索結果を受け取る命令であるGET文は(c2)ではF
ETCH文に置き換える。これにより、(c2)では
(c1)の検索結果と同じ値である「B3」の列データ
845を受け取ることができる。なお、ネットワーク階
層DBシステム810のレコード831,833に関し
ても上述の操作を適用することでRDBシステム820
の行851に移行することができる。(C2) RDB is the data operation of (c1)
It was converted for. The FIND sentence of (c1) is (b
Since it is the next child record search after the search in 1) and the cursor declared in (b2) can be used as it is in RDB, it is not replaced with another instruction in RDB. The GET statement that is an instruction to receive the search result in (c1) is F in (c2).
Replace with ETCH sentence. Accordingly, in (c2), the column data 845 of "B3", which is the same value as the search result in (c1), can be received. Note that the RDB system 820 can also be applied by applying the above-described operation to the records 831 and 833 of the network hierarchy DB system 810.
Line 851 of FIG.
【0046】図9は本発明のデータ操作命令変更処理部
900(図6のデータ操作命令変更処理部606に対
応)で変更したアプリケーションプログラムのレコード
更新時の処理例を示している。ネットワーク階層DBシ
ステム910(図6のネットワーク階層DBシステム6
10に対応)における更新例と、RDBシステム920
(図6のRDBシステム620に対応)とにおける更新
例である。FIG. 9 shows an example of processing when a record of an application program changed by the data operation instruction change processing unit 900 (corresponding to the data operation instruction change processing unit 606 of FIG. 6) of the present invention is updated. Network hierarchy DB system 910 (network hierarchy DB system 6 of FIG. 6)
(Corresponding to 10) and the RDB system 920
(Corresponding to the RDB system 620 in FIG. 6).
【0047】ネットワーク階層DBシステム910にお
ける更新例では、
(d1)
STORE レコードA
(e1)
STORE レコードBIn the update example in the network hierarchy DB system 910, (d1) STORE record A (e1) STORE record B
【0048】というデータ操作命令が記述されている。
(d1)では親レコードである「レコードA」に対する
レコードの追加を行う。ここでは、RDBシステム92
0内の行953を取り上げて以下に説明する。なお、
「A1」、「B1」などはそのレコードの内容を示して
いる。この例では「A3」のレコード936が追加され
ている。(e1)では子レコードである「レコードB」
に対するレコードの追加を行う。この例ではレコード9
36の子レコードとして「B4」のレコード937が追
加される。このようなデータ操作をデータ操作変更プロ
グラム900により変更すると以下のようになる。The data operation command is described.
In (d1), a record is added to the parent record “record A”. Here, the RDB system 92
Row 953 in 0 will be described below. In addition,
“A1”, “B1”, etc. indicate the contents of the record. In this example, a record 936 of “A3” is added. In (e1), "Record B", which is a child record
Record is added to. Record 9 in this example
A record 937 of “B4” is added as a child record of 36. When such a data operation is changed by the data operation change program 900, it becomes as follows.
【0049】 (d2) INSERT INTO レコードAB(レコードAB.レコードA) VAL UES(レコードA(:PAA,:PAB) (e2) UPDATE レコードAB ADD レコードAB.レコードB(*)= レコードB(:PBA,:PBB) WHERE レコードAB.レコードA.項目AA=:PAA[0049] (D2) INSERT INTO record AB (record AB. Record A) VAL UES (Record A (: PAA,: PAB) (E2) UPDATE record AB ADD record AB. Record B (*) = Record B (: PBA,: PBB) WHERE record AB. Record A. Item AA =: PAA
【0050】(d2)のデータ操作は(d1)のデータ
操作をRDB用に変換したものである。ネットワーク構
造DBにおける親レコードに対するSTORE文はRD
BではINSERT文に置き換える。(d1)で更新対
象となるレコード名「レコードA」を、(d2)では更
新対象となる表名として「レコードAB」、更新対象と
なる列名として「レコードAB.レコードA」に置き換
える。記憶する値はVALUESで指定するが記憶対象
となる列が抽象データ型の列のためVALUESにはユ
ーザ定義関数「レコードA(:PAA,:PAB)」
(PAA、PABはパラメタ名)を指定する。(d2)
のデータ操作により「A3」の内容の列データ946が
記憶される。The data operation (d2) is a conversion of the data operation (d1) for RDB. The STORE statement for the parent record in the network structure DB is RD
In B, it is replaced with the INSERT statement. The record name “record A” to be updated in (d1) is replaced with “record AB” as the table name to be updated and “record AB. Record A” as the column name to be updated in (d2). The value to be stored is specified by VALUES, but the column to be stored is an abstract data type column, so the user-defined function “record A (: PAA,: PAB)” is stored in VALUES.
(PAA and PAB are parameter names) is specified. (D2)
The column data 946 having the content of "A3" is stored by the data operation of.
【0051】(e2)のデータ操作は(e1)のデータ
操作をRDB用に変換したものである。ネットワーク構
造DBにおける子レコードに対するSTORE文はRD
BではUPDATE文での繰り返し構造の列の要素の追
加に置き換える。なおRDBシステムにはUPDATE
文のADD指定によって繰り返し構造の列の要素の追加
を行う機能が実装されているものとする。(e1)で更
新対象となるレコード名「レコードB」を、(e2)で
は更新対象となる表名として「レコードAB」、更新対
象となる列名として「レコードAB.レコードB
(*)」に置き換える。記憶する値はADDで指定する
が記憶対象となる列が抽象データ型の列のため‘=’の
右辺にはユーザ定義関数「レコードB(:PBA,:P
BB)」(PBA、PBBはパラメタ名)を指定する。The data operation of (e2) is a conversion of the data operation of (e1) for RDB. The STORE statement for the child record in the network structure DB is RD
In B, replacement is performed by adding an element of the column of the repeating structure in the UPDATE statement. UPDATE for the RDB system
It is assumed that the function of adding the element of the column of the repeating structure is mounted by the ADD designation of the sentence. In (e1), the record name “record B” to be updated is set to “record AB” as the table name to be updated in (e2), and “Record AB. Record B” as the column name to be updated.
(*) ”. The value to be stored is specified by ADD, but since the column to be stored is an abstract data type column, the user-defined function “record B (: PBA,: P
BB) "(PBA and PBB are parameter names) are designated.
【0052】さらに、UPDATEの対象となる行を特
定するための条件であるWHERE指定を追加する。U
PDATEの対象となる行は(d2)で追加した行であ
るから、(d2)で記憶した値のうち表「レコードA
B」の主キーに対応する値をWHERE条件に指定する
ことで更新対象となる行を特定する。図5の例では表
「レコードAB」の主キーが「レコードAB.レコード
A.項目AA」と仮定し、WHERE条件には「レコー
ドAB.レコードA.項目AA=:PAA」(PAAは
パラメタ名)を指定する。(e2)のデータ操作により
「B4」の内容の列データ947が記憶される。なお、
ネットワーク階層DBシステム910のレコード93
1,932とそれに対応する子レコードに関しても上述
の操作を適用することでRDBシステム820の行95
1,952にそれぞれ移行することができる。Furthermore, a WHERE specification which is a condition for specifying the line to be the object of UPDATE is added. U
Since the target row of PDATE is the row added in (d2), the table "record A" of the values stored in (d2)
By specifying the value corresponding to the primary key "B" in the WHERE condition, the row to be updated is specified. In the example of FIG. 5, it is assumed that the primary key of the table “record AB” is “record AB. Record A. item AA”, and the WHERE condition is “record AB. Record A. item AA =: PAA” (where PAA is a parameter name). ) Is specified. The column data 947 having the content of "B4" is stored by the data operation of (e2). In addition,
Record 93 of network hierarchy DB system 910
By applying the above-mentioned operation to 1,932 and the child record corresponding thereto, the line 95 of the RDB system 820
1, 952 respectively.
【0053】このように、データ操作命令変更処理を行
うことで、アプリケーションについてもデータ移行と同
時に更新することができ、さらに移行作業時間を短縮し
て行うことができるようになる。As described above, by performing the data operation command change processing, the application can be updated at the same time as the data migration, and the migration work time can be shortened.
【0054】なお、本発明は、上述の図1〜図9を用い
て説明した例に限定されるものではなく、その要旨を逸
脱しない範囲において種々の変更が可能である。例え
ば、第1の実施形態において、抽象データ型を用いて複
数のデータ構造を受入れ可能としたが、予め受入れるデ
ータ型を設定しておいてもよい。The present invention is not limited to the examples described with reference to FIGS. 1 to 9 described above, and various modifications can be made without departing from the scope of the invention. For example, in the first embodiment, a plurality of data structures can be accepted using the abstract data type, but the accepted data type may be set in advance.
【0055】また、第1,2の実施形態では、ネットワ
ーク階層DBシステム内において、子レコードは便宜的
に1又は2つであったが、3つ以上の子レコードが設定
されていても当然に適用可能である。In the first and second embodiments, the number of child records is 1 or 2 for the sake of convenience in the network hierarchy DB system. However, it is natural that three or more child records are set. Applicable.
【0056】また、上述の実施形態、および上述の種々
の変更を行った形態において、その処理を行うプログラ
ムをアプリケーションソフトとして、ハードディスク等
の記録媒体に格納しておいてもよい。このようにすれ
ば、CD−ROM等の可搬型記録媒体にプログラム等を
格納して売買したり、携帯することができるようにな
る。なお、図8,9で記載したプログラムは一例を示し
たものであり、当然これに限られるものではない。Further, in the above-described embodiment and the above-described various modifications, the program for performing the processing may be stored in a recording medium such as a hard disk as application software. This makes it possible to store the program or the like in a portable recording medium such as a CD-ROM and sell or carry it. It should be noted that the programs described in FIGS. 8 and 9 are merely examples, and the programs are not limited to these.
【0057】[0057]
【発明の効果】本発明に係るデータ移行制御装置とその
方法およびそのプログラムによれば、I/O回数の増加
を抑制するデータ構造を作成するようにネットワーク構
造DB基盤のデータからRDB基盤のデータに移行する
処理を行うことで、データ処理性能を低下させることな
く、かつ短時間でシステム移行処理を行うことができ
る。According to the data migration control device, the method thereof, and the program thereof according to the present invention, the network structure DB-based data is changed to the RDB-based data so as to create the data structure for suppressing the increase of the I / O frequency. By performing the process of migrating to, the system migration process can be performed in a short time without degrading the data processing performance.
【図1】第1の実施形態における、データ移行制御装置
を含むDBシステム全体の構成例を示すブロック図であ
る。FIG. 1 is a block diagram showing a configuration example of an entire DB system including a data migration control device according to a first embodiment.
【図2】第1の実施形態において、データ型移行処理部
の動作の概略を示すためのフローチャートである。FIG. 2 is a flowchart showing an outline of an operation of a data type migration processing unit in the first embodiment.
【図3】第1の実施形態における、データ型移行処理部
の動作をさらに詳細に説明するための図である。FIG. 3 is a diagram for explaining the operation of a data type migration processing unit in the first embodiment in more detail.
【図4】第1の実施形態における、レコード移行処理部
の動作の概略を示すためのフローチャートである。FIG. 4 is a flowchart showing an outline of an operation of a record migration processing unit in the first embodiment.
【図5】第1の実施形態における、レコード移行処理部
の動作をさらに詳細に説明するための図である。FIG. 5 is a diagram for explaining the operation of a record migration processing unit in the first embodiment in more detail.
【図6】第2の実施形態における、データ移行制御装置
を含むDBシステム全体の構成例を示すブロック図であ
る。FIG. 6 is a block diagram showing a configuration example of an entire DB system including a data migration control device according to a second exemplary embodiment.
【図7】第2の実施形態における、データ移行制御装置
に設けられたデータ操作命令変更処理部の動作の概略を
示すためのフローチャートである。FIG. 7 is a flowchart showing an outline of an operation of a data operation command change processing unit provided in a data migration control device in the second embodiment.
【図8】第2の実施形態における、データ操作命令変更
処理部の動作をさらに詳細に説明するための図である。FIG. 8 is a diagram for explaining the operation of the data operation instruction change processing unit in the second embodiment in more detail.
【図9】第2の実施形態における、データ操作命令変更
処理部によって変換されたアプリケーションの、レコー
ド検索時処理例を説明するための図である。FIG. 9 is a diagram for explaining a record search processing example of an application converted by a data operation instruction change processing unit in the second embodiment.
100,600,:データ移行制御装置
102,300,602,:データ型移行処理部
104,500,604,:レコード移行処理部
110,310,510,610,810910:ネッ
トワーク階層DBシステム
112,612:DB定義
114,614:ネットワーク階層DB
120,320,520,620,820,920:R
DBシステム
122,622,:表定義
124,624,:RDB
606,800,900:データ操作命令変更処理部
616,626:アプリケーション記憶部100, 600 ,: data migration control device 102, 300, 602 ,: data type migration processing unit 104, 500, 604 ,: record migration processing unit 110, 310, 510, 610, 810910: network hierarchy DB system 112, 612: DB definition 114, 614: Network hierarchy DB 120, 320, 520, 620, 820, 920: R
DB systems 122, 622: table definitions 124, 624, RDB 606, 800, 900: data operation command change processing units 616, 626: application storage unit
───────────────────────────────────────────────────── フロントページの続き (72)発明者 外山 雄司 神奈川県横浜市中区尾上町6丁目81番地 日立ソフトウェアエンジニアリング株式会 社内 Fターム(参考) 5B082 CA10 ─────────────────────────────────────────────────── ─── Continued front page (72) Inventor Yuji Toyama 6-81 Onoe-cho, Naka-ku, Yokohama-shi, Kanagawa Hitachi Software Engineering Stock Association In-house F-term (reference) 5B082 CA10
Claims (5)
子レコードとの間で構築されてなるネットワーク構造デ
ータベース基盤のデータを、リレーショナルデータベー
ス基盤のデータに移行するデータ移行制御装置におい
て、 前記親レコードをリレーショナルデータベースの表に移
行し、これと対応して、該親レコードと該親子関係にあ
る前記子レコードを、前記表の該親レコードが該移行さ
れた行と同じ行に移行するレコード移行手段を有するこ
とを特徴とするデータ移行制御装置。1. A data migration control device for migrating network structure database-based data, in which a parent-child relationship is constructed between a parent record and a child record by a pointer, to relational database-based data, wherein the parent record is a relational one. Record transfer means for transferring to a database table and correspondingly transferring the child record having the parent-child relationship with the parent record to the same row as the row to which the parent record of the table has been transferred; A data migration control device characterized by the above.
おいて、 前記親子関係に基づき参照した前記親レコードと前記子
レコードとの各々に対し、レコードを構成する複数のデ
ータ型に対応する抽象データ型を定義し、前記抽象デー
タ型が定義された該親レコードおよび該子レコードに対
してリレーショナルデータベースでのデータ操作を行う
ためのユーザ定義関数を生成する抽象データ型移行手段
をさらに有することを特徴とするデータ移行制御装置。2. The data migration control device according to claim 1, wherein, for each of the parent record and the child record referred to based on the parent-child relationship, abstract data corresponding to a plurality of data types forming a record. An abstract data type migration means for defining a type and generating a user-defined function for performing data operation in the relational database with respect to the parent record and the child record in which the abstract data type is defined. Data migration control device.
御装置において、 前記ネットワーク構造データベース用に作成され、アプ
リケーションの実行処理を行うデータ処理命令を、前記
レコード移行手段で対応づけられたリレーショナルデー
タベースの前記表に対するデータ処理命令に変更するデ
ータ操作命令変更手段をさらに有することを特徴とする
データ移行制御装置。3. The data migration control device according to claim 1, wherein a data processing command created for the network structure database and executing an application execution process is associated with the record migration means. The data migration control device further comprising a data operation command changing means for changing the data processing command for the above table.
の親子関係が構築されているネットワーク構造データベ
ース基盤のデータを、リレーショナルデータベース基盤
のデータに移行するデータ移行制御方法において、 前記親レコードをリレーショナルデータベースの表に移
行し、これと対応して、該親レコードと該親子関係が構
築されている前記子レコードを、前記表の該親レコード
が該移行された行と同じ行にレコードに移行することを
特徴とするデータ移行制御方法。4. A data migration control method for migrating network structure database-based data in which a parent-child relationship between a parent record and a child record is constructed by a pointer to a relational database-based data, wherein the parent record is a relational database table. And correspondingly, the child record having the parent-child relationship with the parent record is moved to the same row as the row to which the parent record of the table is moved. Data migration control method.
おける各処理を、コンピュータに実行させるためのデー
タ移行制御プログラム。5. A data migration control program for causing a computer to execute each process in the data migration control method according to claim 4.
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
JP2001189013A JP2003006010A (en) | 2001-06-22 | 2001-06-22 | Method and device for controlling data transition, and processing program of the same |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
JP2001189013A JP2003006010A (en) | 2001-06-22 | 2001-06-22 | Method and device for controlling data transition, and processing program of the same |
Publications (1)
Publication Number | Publication Date |
---|---|
JP2003006010A true JP2003006010A (en) | 2003-01-10 |
Family
ID=19028002
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
JP2001189013A Pending JP2003006010A (en) | 2001-06-22 | 2001-06-22 | Method and device for controlling data transition, and processing program of the same |
Country Status (1)
Country | Link |
---|---|
JP (1) | JP2003006010A (en) |
Cited By (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JP2020004049A (en) * | 2018-06-27 | 2020-01-09 | 富士ゼロックス株式会社 | Information processing device and information processing program |
-
2001
- 2001-06-22 JP JP2001189013A patent/JP2003006010A/en active Pending
Cited By (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JP2020004049A (en) * | 2018-06-27 | 2020-01-09 | 富士ゼロックス株式会社 | Information processing device and information processing program |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
JP3023441B2 (en) | Database division management method and parallel database system | |
CN110799960B (en) | System and method for database tenant migration | |
JP2571660B2 (en) | Method and system for manipulating distributed heterogeneous data in a data processing system | |
JP2908810B2 (en) | Database | |
RU2406115C2 (en) | Accessing complex data | |
JP2004530216A (en) | Integration of tablespaces of different block sizes | |
JP2011524047A (en) | Recall hierarchical data | |
CN110799961A (en) | System and method for creating and deleting tenants in database | |
JP2001101042A (en) | System and method for managing data | |
US7958154B2 (en) | Apparatus, system, and method for command manager support for pluggable data formats | |
US7984072B2 (en) | Three-dimensional data structure for storing data of multiple domains and the management thereof | |
JP2003006010A (en) | Method and device for controlling data transition, and processing program of the same | |
JP3060225B2 (en) | Database management method and system | |
JP2002007365A (en) | Database dividing and managing method and parallel- database system | |
JP3172793B1 (en) | Database management method | |
JP3236999B2 (en) | Database management method and system | |
JPS62131349A (en) | Data base processing system | |
JP3156199B2 (en) | Database management method and system | |
JP3599055B2 (en) | Storage device management method and system | |
JP3060222B2 (en) | Database management method and system | |
JP2023132379A (en) | Database system and data management method | |
JP3060224B2 (en) | Database management method and system | |
JP3060223B2 (en) | Database management method and system | |
JP2004355651A (en) | Data storage method and data management system | |
CN117194372A (en) | Data migration method, device, electronic equipment and storage medium |