JP3751476B2 - データベースシステム、およびその制御方法、ならびにその制御プログラムを記録したコンピュータ読み取り可能な記録媒体 - Google Patents
データベースシステム、およびその制御方法、ならびにその制御プログラムを記録したコンピュータ読み取り可能な記録媒体 Download PDFInfo
- Publication number
- JP3751476B2 JP3751476B2 JP18627999A JP18627999A JP3751476B2 JP 3751476 B2 JP3751476 B2 JP 3751476B2 JP 18627999 A JP18627999 A JP 18627999A JP 18627999 A JP18627999 A JP 18627999A JP 3751476 B2 JP3751476 B2 JP 3751476B2
- Authority
- JP
- Japan
- Prior art keywords
- reflection
- information storage
- storage device
- database system
- data
- 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.)
- Expired - Fee Related
Links
Images
Landscapes
- Information Retrieval, Db Structures And Fs Structures Therefor (AREA)
Description
【発明の属する技術分野】
本発明は、複数の情報蓄積装置の間で情報の同期をとるデータベースシステム、およびその制御方法、ならびにその制御プログラムを記録したコンピュータ読み取り可能な記録媒体に関するものである。
【0002】
【従来の技術】
文書群と文書検索用インデックスとを備えた文書検索システムや、原本とその複製を備えた分散データベースシステムでは、データを蓄積した複数の情報蓄積装置の間で内容の同期を取る(シンクロナイズする)必要がある。
【0003】
ここで、一つの情報蓄積装置への書換えを他の情報蓄積装置へ反復的に反映する方法について、以下の四つの従来例をあげる。
〔従来例1〕
文書群の検索を高速化するために、検索用インデックスデータをあらかじめ作成しておくという方法がある(公開特許公報「特開平5−61910号公報(公開日:平成5年(1993)3月12日)」、他)。この場合、新規文書が追加されたり、既存文書が修正または削除された場合、それをインデックスに反映する必要がある。すなわち、インデックスを部分的に、または全体を作りなおす必要がある。
【0004】
図10に、上記の方法を適用した文書編集装置のDFD(データフロー図)の例を示す。
【0005】
ここで、DFDの表記方法について説明する。楕円は、プロセスと呼ばれ、データの変換を表す。プロセスは一つ以上の入力と一つ以上の出力を持つ。なお、プロセスという用語は、ある種のコンピュータシステムでは実行中のプログラムを意味するが、本明細書では上記の意味で使用する。長方形は、アクターと呼ばれ、データを生産または消費することによって、能動的にデータの流れを駆動する。水平な二本の平行線は、データストアと呼ばれ、データの格納およびアクセスの要求があればそれに応じる。データストアの入力はデータの格納を意味し、出力はアクセスを意味する。なお、データストアそのものは自発的に動作しない。実線の矢印は、データフロー(データの流れ)を表し、プロセス、アクター、データストアの入力や出力となる。また、破線の矢印は、制御フローと呼ばれ、あるプロセスの計算結果が別のプロセスの計算を行うか否かを決めることを表す。ただし、DFDが表現するのは、データの流れと計算の仕様であり、制御の流れや動作の順序は本筋でない。
【0006】
以下、図10を参照して、上記文書編集装置について説明する。上記文書編集装置は、利用者の操作により、文書を作成し、作成した文書を蓄積、および印刷する。また、作成済みの文書を検索、印刷、修正、および削除する。文書の検索には、インデックス法を用い、高速に全文検索を行う。
【0007】
上記文書編集装置は、文書ファイル群の書換え(新規、修正、および削除)を定期的にインデックスに反映する。この反映処理の間隔は、利用者が設定する。反映処理は、文書ファイル群を走査し、インデックスに未反映の文書を探す処理を含む。ここで、未反映の文書とは、前回の反映処理以降に新規作成、修正、または削除された文書である。
【0008】
端末51は、利用者用の端末装置である。端末51は、文書の作成、修正、削除、印刷、および検索を行う。端末51は、キーボード入力装置、画面表示装置、および印字装置(プリンタ)を備えている。
【0009】
文書ファイル群52は、利用者が作成した文書ファイルの蓄積である。文書ファイル群52は、修正、削除、印刷、および検索の対象となる。
【0010】
文書の編集プロセス54は、利用者の操作に応じて文書を編集する。文書の編集プロセス54は、文書を作成、修正、削除、および印刷する。
【0011】
文書の検索プロセス56は、利用者の操作に応じて文書を検索する。文書の検索プロセス56は、利用者が端末51より与える検索条件に合致する文書を、インデックス62より探し、見つかれば文書ファイル群52から該当文書を読み出して、該当する部分を端末51の画面に表示して利用者に示す。
【0012】
インデックス62は、検索の際に用いる、高速な検索を実現するための、検索用インデックスデータである。
【0013】
インデックス化プロセス71は、文書ファイル群52を元に、インデックス62を作成する。インデックス化プロセス71は、文書ファイルの新規作成、修正、および削除があれば、それをインデックス62に反映する。
【0014】
最終反映時刻72は、最後にインデックス化プロセス71を実行開始した時刻である。最終反映時刻72は、インデックス化プロセス71に着手する都度、更新される。
【0015】
反映間隔73は、インデックス化プロセス71を実行すべき時間の間隔を、分(minute)を単位にして表した値である。反映間隔73は、利用者が端末51を介して変更できる。
【0016】
時間の比較プロセス74は、最終反映時刻72から現在までに経過した時間と、反映間隔73を比較し、前者が後者より小さくなければ、インデックス化プロセス71を開始させる。
〔従来例2〕
図11および図12を用いて、複数の工場を持つ会社が、各工場が管理する仕入先DB(データベース)を、相互乗り入れさせる場合について説明する。図11は、上記仕入先DBシステムの構成を示すDFDだが、繁雑さを避けるため、端末81を札幌工場Bnにだけ描いた。なお、実際には図12のように、本社工場Hと神戸工場Bsにも端末端末81がある。
【0017】
各工場Bn,Bsの仕入先DB82は、仕入先の名称、地域コード、連絡先、取扱い品目の部品コード、単価、および標準納期を格納する。通常、自工場構内の仕入先DB82で地元業者を検索することが多いが、他工場の仕入先DB82も検索できる。
【0018】
他工場の仕入先DB82を含めた広域検索の便宜を図るため、総目次84を設ける。すなわち、各工場Bn,Bsは、各仕入先の名称、地域コード、および部品コードをまとめたデータを、定期的に本社工場Hへ送信する。本社工場Hでは、各工場Bn,Bsからのデータを合成プロセス83によって合成し、工場コードを付して、総目次84を作成する。総目次84は、本社工場Hから各工場Bn,Bsへ送信され、各工場Bn,Bsに同一のコピーが置かれる。
【0019】
広域検索は次の手順による。まず、総目次84を部品コードで検索し、その部品を扱う仕入先と、その工場コードを得る。そして、工場コードが表す工場の仕入先DB82を遠隔検索し、詳細な情報を得る。
〔従来例3〕
図13および図14を用いて、低速回線で結ばれた本支店間で、電子電話帳データを共有する電子電話帳システムについて説明する。図13は、上記電子電話帳システムの構成を示すDFDだが、DB停止時に他店のDBを検索する機能については、繁雑を避けるため図14に示した。
【0020】
まず、電子電話帳92を本店Hに設置して、検索の都度、各支店Bn,Bsから本店Hへ通信することが可能である。しかし、低速回線を経由しての検索は遅すぎて不便な場合が多い。そこで、本店Hに置かれている電子電話帳(原本)92の複製である電子電話帳(複製)96を、各支店Bn,Bsに置く必要がある。こうすれば、平常時の検索は、高速な自店の構内回線だけを経由して行うことができる。そして、故障または保守作業で自店構内の電子電話帳(複製)96の停止中に限り、他店の電子電話帳92,96を検索することができる。
【0021】
この場合、本支店間でのデータの一貫性を保つために、本店Hが電子電話帳DBの原本を管理して、各支店Bn,Bsによる変更(変更プロセス94)は各支店Bn,Bsが本店Hに依頼(変更依頼93)することによって行われる。そのため、本店Hの電子電話帳(原本)92のDBは、更新機能を持つ。そして、本店Hおよび各支店Bn,Bsからの変更依頼93は、随時、本店Hの電子電話帳(原本)92に反映される。各支店Bn,Bsの電子電話帳(複製)96のDBは簡易型で、検索しか出来ない。よって、定期的に支店DB(電子電話帳(複製)96)を停止して、本店DB(電子電話帳(原本)92)の内容を書き写す必要がある。
〔従来例4〕
図15および図14を用いて、低速回線で結ばれた本支店間で、電子電話帳データを共有する電子電話帳システムについて説明する(公開特許公報「特開平10−149308号公報(公開日:平成10年(1998)6月2日)」、他)。図15は、上記電子電話帳システムの構成を示すDFDだが、DB停止時に他店のDBを検索する機能については、繁雑を避けるため図14に示した。
【0022】
本従来例の電子電話帳システムは、前記従来例3の電子電話帳システムと類似しているが、各支店Bn,BsのDB(電子電話帳97)も、本店HのDBと同様に更新機能を持つ点が相違している。
【0023】
すなわち、各支店Bn,Bsによる更新は、本店Hに依頼せず、自店内の電子電話帳97を自ら更新する。そして、本店Hおよび各支店Bn,BsのDB(電子電話帳97)は、同期プロセス98により、定期的にデータ交換して、データの同期を取ることによって、本支店間でのデータの一貫性を保つ。
【0024】
【発明が解決しようとする課題】
上記の従来例1から従来4では、追加の情報蓄積装置、すなわちインデックス、総目次、および複製(レプリカ)を導入している。その目的は、検索を高速化することである。また、電子電話帳の複製の例では、DB停止中も検索可能になり、可用性を高めることにも役立っている。
【0025】
しかしながら、上記の従来例1から従来4では、おのおのの情報蓄積装置の間で、どのようなタイミングで内容の同期を取るかが問題となる。寸分の狂いもなく同一の内容を持つことが、極めて重要である場合には、書換えを直ちに反映する必要がある。例えば、文書に書換え(新規文書の追加、既存文書の修正・削除)があれば、直ちにインデックスを作り直す。あるいは、電子電話帳データに変更があれば、直ちに変更を配信する。ただし、相応の設備増強(高速インデクサ、高速回線)が必要である。
【0026】
このような用途では、多少の誤差は許容されることが多い。そして、反映処理は定期的に実行される。ここで、反映処理の時間間隔は、用途や設備の負荷状態等に応じて、適切に調整しなければ、良い効果が得られない。
【0027】
すなわち、反映の頻度が低すぎれば、最新でない情報を読んでしまう確率が大きくなる。反映処理を、情報の読み書きに対して非同期的に行う以上、このような誤りは本質的に避けられない。そのため、誤り率が大きくならないよう考慮する必要がある。このような誤り率が大きくなるのは、反映の頻度が低すぎる場合であり、情報蓄積装置の相互間に生ずる誤差が過大になるためである。
【0028】
逆に、反映の頻度が高すぎれば、設備(装置や回線)の負荷を無駄に増大し、設備の能力を無駄遣いすることになる。特に、小刻みに修正される情報や一時的にしか存在しない情報が少なくない場合、無駄が多くなる。結果として、情報の読み書きという本来の作業をかえって遅くすることになる。また、電子電話帳の場合、DBを必要以上に停止させることになる。これは、文書やDBの検索を高速化するという目的に反する。
【0029】
以上のように、反映処理を行う最適な反映頻度は、用途や設備の負荷状態等に応じて、適切に調整する必要がある。しかし、最適な反映頻度は、情報を書き換える頻度によって変化する。したがって、追加の情報蓄積装置を導入した効果を上げるには、反映頻度を適切に調節し続けなければならない。
【0030】
本発明は、上記の問題点を解決するためになされたもので、その目的は、複数の情報蓄積装置の間で情報の同期をとるデータベースシステムにおいて、同期の誤差と、設備の負荷に関して、最適なバランスを維持することができるデータベースシステム、およびその制御方法、ならびにその制御プログラムを記録したコンピュータ読み取り可能な記録媒体を提供することにある。
【0031】
【課題を解決するための手段】
本発明のデータベースシステムは、上記の課題を解決するために、第1の情報蓄積装置と、第2の情報蓄積装置と、第1の情報蓄積装置に対して行われた変更を、間欠的に第2の情報蓄積装置へ反映する反映手段と、第1の情報蓄積装置の内容と第2の情報蓄積装置の内容との誤差の程度に応じて、上記反映手段の起動を制御する反映制御手段とを備えていることを特徴としている。
【0032】
また、本発明のデータベースシステムの制御方法は、上記の課題を解決するために、第1の情報蓄積装置と第2の情報蓄積装置とを備えたデータベースシステムの制御方法であって、第1の情報蓄積装置に対して行われた変更を、間欠的に第2の情報蓄積装置へ反映する反映処理と、第1の情報蓄積装置の内容と第2の情報蓄積装置の内容との誤差の程度に応じて、上記反映処理の起動を制御する反映制御処理とを含んでいることを特徴としている。
【0033】
また、本発明のコンピュータ読み取り可能な記録媒体は、上記の課題を解決するために、第1の情報蓄積装置と第2の情報蓄積装置とを備えたデータベースシステムを制御するための制御プログラムを記録したコンピュータ読み取り可能な記録媒体であって、第1の情報蓄積装置に対して行われた変更を、間欠的に第2の情報蓄積装置へ反映する反映処理と、第1の情報蓄積装置の内容と第2の情報蓄積装置の内容との誤差の程度に応じて、上記反映処理の起動を制御する反映制御処理とを、コンピュータに実行させるためのプログラムを記録していることを特徴としている。
【0034】
上記の各構成により、例えば、文書検索システムでは、第1の情報蓄積装置に検索対象の情報が、第2の情報蓄積装置に検索補助用の情報(インデックス)がそれぞれ蓄積される。また例えば、分散データベースシステムでは、第1の情報蓄積装置に原本の情報が、第2の情報蓄積装置に複製の情報が蓄積される。そして、上記データベースシステムでは、複数の情報蓄積装置群において、一部の情報蓄積装置(第1の情報蓄積装置)になされた変更を、他の情報蓄積装置(第2の情報蓄積装置)へ繰り返し反映することによって、データベースシステム全体の情報の一貫性を確保する。
【0035】
ここで、上記データベースシステムでは、反映制御処理によって、第1の情報蓄積装置の内容と第2の情報蓄積装置の内容との誤差の程度(未反映率)に応じて、反映処理の起動が制御される。例えば、未反映率が基準値を超えた時に、反映処理を起動して、第1の情報蓄積装置に対して行われた更新を第2の情報蓄積装置に反映させることができる。
【0036】
このように、上記データベースシステムでは、未反映率を算出する負荷が、反映処理の負荷と比べて、ほとんど無視できる場合に、反映処理の起動を直接的かつ単純に自動制御することができる。すなわち、複数の情報蓄積装置(データベース等)群の間で、一定の誤差を許容しつつ、内容を同一化するデータベースシステムにおいて、反映処理の時期を、利用者の手動操作あるいは単純な一定時間間隔とせず、状況に応じて動的に制御することによって、情報の同一性と装置の負荷という相反する二つの要素のバランスを最適に維持できる。
【0037】
本発明のデータベースシステムは、上記の課題を解決するために、さらに、上記反映制御手段は、第1の情報蓄積装置の内容と第2の情報蓄積装置の内容との誤差の程度に基づいて、上記反映手段を間欠的に起動する反映間隔を設定する反映間隔設定手段を備えていることを特徴としている。
【0038】
また、本発明のデータベースシステムの制御方法は、上記の課題を解決するために、さらに、上記反映制御処理は、第1の情報蓄積装置の内容と第2の情報蓄積装置の内容との誤差の程度に基づいて、上記反映処理を間欠的に起動する反映間隔を設定する反映間隔設定処理を含んでいることを特徴としている。
【0039】
また、本発明のコンピュータ読み取り可能な記録媒体は、上記の課題を解決するために、さらに、上記プログラムは、上記反映制御処理が、第1の情報蓄積装置の内容と第2の情報蓄積装置の内容との誤差の程度に基づいて、上記反映処理を間欠的に起動する反映間隔を設定する反映間隔設定処理を含んでいることを特徴としている。
【0040】
上記の各構成により、さらに、上記データベースシステムでは、反映間隔設定処理によって、第1の情報蓄積装置の内容と第2の情報蓄積装置の内容との誤差の程度(未反映率)に応じて、反映間隔を設定して、反映間隔ごとに反映処理が起動するように制御することが可能になる。例えば、未反映率と基準値とを比較して得られた比較結果に基づいて、反映処理を起動する反映間隔を適宜加減しながら、運用することができる。
【0041】
このように、上記データベースシステムでは、未反映率を算出する負荷が反映処理の負荷と比べて無視できない場合に、反映間隔を加減するという間接的な方法によって、反映時期を自動制御することができる。すなわち、複数の情報蓄積装置(データベース等)群の間で、一定の誤差を許容しつつ、内容を同一化するデータベースシステムにおいて、反映処理の時期を、利用者の手動操作あるいは単純な一定時間間隔とせず、状況に応じて動的に制御することによって、過剰頻度による設備への過負荷や、過少頻度による情報精度の低下を防ぎながら、情報の同一性と装置の負荷という相反する二つの要素のバランスを最適に維持できる。
【0042】
【発明の実施の形態】
〔実施の形態1〕
本発明の一実施の形態について図1および図2に基づいて説明すれば、以下のとおりである。
【0043】
本実施の形態は、本発明に係るデータベースシステムを、文書検索機能を備えた文書編集装置へ適用した例である。なお、本実施の形態は、前記従来例1で説明した装置への応用例に相当する。また、本実施の形態は、前記従来例2で説明した仕入先DBも対しても、同様に応用できる。
【0044】
上記文書編集装置は、利用者の操作により、文書を作成し、作成した文書を蓄積、および印刷する。また、作成済みの文書を検索、印刷、修正、および削除する。文書の検索には、インデックス法を用い、高速に全文検索を行う。
【0045】
本実施の形態では、従来例1と同じく、文書ファイル群の書換え(新規、修正、および削除)を、繰り返しインデックスに反映する。この反映処理の間隔を自動調整するのが、上記文書編集装置の特徴である。
【0046】
ここで、上記反映処理は、文書ファイル群を走査し、インデックスに未反映の文書を探す処理を含む。また、未反映の文書とは、前回の反映処理以降に新規作成、修正、または削除された文書である。
【0047】
この場合、間隔が短すぎる場合の無駄は、未反映の文書を探すために文書ファイル群を走査する負荷である。そして、本実施の形態に係る文書編集装置は、この無駄を防ぎつつ検索の品質を保つことができる。
【0048】
図1は、本実施の形態に係る文書編集装置の機能の概略を示すデータフロー図(DFD)である。なお、DFDの記法については、前記の従来例1で説明したとおりである。
【0049】
上記文書編集装置は、アクターである端末1と、データストアである文書ファイル群(第1の情報蓄積装置)2、インデックス(第2の情報蓄積装置)12、最終反映時刻22、反映間隔23、未反映率の基準26と、プロセスである文書の編集プロセス4、文書の検索プロセス6、インデックス化プロセス(反映手段、反映処理)21、時間の比較プロセス(反映制御手段、反映制御処理)24、反映間隔の調整プロセス(反映間隔設定手段、反映間隔設定処理)25、未反映率の算出プロセス27とを含んで構成されている。
【0050】
アクターである上記端末1は、利用者用の端末装置であり、キーボード入力装置、画面表示装置、および印字装置(プリンタ)等を備えて構成されている。端末1は、文書の作成、修正、削除、印刷、および検索を行う。
【0051】
つぎに、各データストアについて説明する。
【0052】
上記文書ファイル群2は、利用者が作成した文書ファイルを蓄積した情報蓄積装置であり、修正、削除、印刷、および検索の対象である。また、文書ファイル群2は、内容を反映する対象である。
【0053】
上記インデックス12は、検索の際に用い、高速な検索を実現するための検索用インデックスデータである。
【0054】
上記最終反映時刻22は、インデックス化プロセス21(後述)による反映を最後に実行した時刻である。最終反映時刻22は、インデックス化プロセス21に着手する都度更新されて、記憶される。
【0055】
上記反映間隔23は、インデックス化プロセス21を実行すべき時間の間隔であり、分(minute)単位で表される。反映間隔23は、反映間隔の調整プロセス25(後述)によって設定される都度更新されて、記憶される。
【0056】
上記未反映率の基準26は、反映間隔の調整プロセス25(後述)で反映間隔(頻度)を調整するための基準値を与える。未反映率の基準26は、利用者によって端末1から入力・調整され、記憶される。
【0057】
つぎに、各プロセスについて説明する。
【0058】
上記文書の編集プロセス4は、利用者の操作に応じて文書を編集して、文書ファイル群2の内容を書き換える。具体的には、文書の編集プロセス4は、文書の作成、修正、削除、および印刷を行う。
【0059】
上記文書の検索プロセス6は、利用者の操作に応じて文書ファイル群2から文書(情報)を検索する。具体的には、利用者が、端末1より与える検索条件に合致する文書を、インデックス12より探す。そして、インデックス12中に見つかれば文書ファイル群2から該当文書を読み出して、該当の部分を端末1の画面に表示して利用者に示す。
【0060】
上記インデックス化プロセス21は、文書ファイル群2に対して行われた書換えを、インデックス12へ反映する。すなわち、インデックス化プロセス21は、文書ファイル群2を元に、インデックス12を作成する。具体的には、インデックス化プロセス21は、文書ファイルの新規作成、修正、および削除が行われれば、それをインデックス12に反映する。なお、上記文書編集装置では、インデックス化プロセス21を起動する時間間隔が自動調整される。
【0061】
上記時間の比較プロセス24は、最終反映時刻22から現在までに経過した時間と反映間隔23とを比較し、前者が後者より小さくなければインデックス化プロセス21を開始させる。
【0062】
上記反映間隔の調整プロセス25は、未反映率を基準値と比較して、反映間隔23を調整する。反映間隔の調整プロセス25は、後で図2を用いて詳述するが、次の三つの内部処理を含んでいる。すなわち、反映間隔の調整プロセス25は、未反映率を基準値と比較する内部処理と、未反映率が過小ならば反映間隔23を増やす内部処理と、未反映率が過大ならば反映間隔23を減らす内部処理とを含んでいる。
【0063】
上記未反映率の算出プロセス27は、現在の未反映率を計算または推定し、フィードバックする。すなわち、未反映率の算出プロセス27は、インデックス化プロセス21の都度、インデックスの誤差を示す未反映率を求め、フィードバックする。
【0064】
ここで、インデックス化プロセス21は、インデックス12に未反映の文書を見つけ出し、その文書に対して処理を行う。そのため、インデックス化プロセス21の処理中に未反映文書の数が求まることになる。よって、上記文書編集装置は、未反映率の算出プロセス27をインデックス化プロセス21の内部処理として構成してもよい。
【0065】
さらに、インデックス化プロセス21では、あわせて未反映率の算出プロセス27および反映間隔の調整プロセス25を行う。未反映率の算出プロセス27および反映間隔の調整プロセス25をこまめに行うほど、反映間隔の精度は向上する。しかし、上記文書編集装置では、未反映率の算出プロセス27および反映間隔の調整プロセス25を、インデックス化プロセス21の際にだけ行う。なぜならば、上記文書編集装置では、未反映率の算出プロセス27の頻度を上げることで増大する負荷が、インデックス化プロセス21の頻度を上げることで増大する負荷に、ほぼ等しいからである。
【0066】
図2のフローチャートを用いて、上記反映間隔の調整プロセス25の手順を説明する。なお、フローチャート中の各ステップにおける演算式は一例であり、これに限定されない。
【0067】
反映間隔の調整プロセス25の手順の特徴は、次の二つである。第一に、品質を基準と同等か、やや上回るレベルに保つ。第二に、未反映率は揺れ動くので、一時的な波動に大きく影響されないよう配慮する。そのために、過剰品質に対しては、慎重を期して、品質を少しずつ下げてゆく。逆に、品質の欠陥に対しては、速やかに品質を上げるが、元に戻せる仕組みを用意する。
【0068】
ステップS11では、誤差の過大を検出する。すなわち、品質の欠陥、反映間隔23の過大を検出する。未反映率が基準より大きければ(YES)、品質を回復するために、ステップS16へ移行して、反映間隔23を縮める。具体的には、未反映率(誤差)が反映間隔23に比例するものと考え、未反映率とその基準との比率によって調整する。すなわち、未反映率が基準のF倍であれば、反映間隔23をF分の1にする。
【0069】
ステップS21およびS25では、逆に、誤差の過小を検出する。すなわち、過剰品質、反映間隔の過小を検出する。そして、ステップS21,S25,S22において、過剰品質を3ランクに分けて、それぞれ異なる数式を適用して反映間隔を長くする。
【0070】
ステップS11,S21,S25での判別がいずれもNOであれば、品質が適正範囲にあると判断して、反映間隔23をそのまま維持する。なお、図2のフローチャートでは、未反映率が基準に対して、0.75から1.0の範囲内の場合である。
【0071】
ここで、過剰品質の処置について説明を加える。一時的な現象に反応して品質を急に下げると、次回に大きな欠陥を出すおそれがある。そのため、品質の欠陥を検出した場合よりも、調整を小幅にとどめる。
【0072】
基本的には、品質過剰の程度が大きいほど、品質を大きく下げる。ただし、その傾きは品質欠陥時よりも緩やかにする(S26)。図2のフローチャートでは、基準値に対する未反映率の割合である基準比をF(未反映率が基準のF倍)として、欠陥時には反映間隔23に(1/F)を乗じている(S16)。これに対し、品質過剰時には、反映間隔23に(3/8F)+(1/2)を乗じている(S26)。ただし、2倍を限度とする(S21,S24)。このように、品質をゆっくりと下げることによって、一時的な波動に対処することができる。
【0073】
逆に、一時的な波動によって品質を上げすぎた場合には、復旧を加速する(S22,S23)。基準比Fが4分の1以下で、かつ前回の基準比Fが4以上だった場合、前回の欠陥は一過性のものであった可能性が高い。そこで、縮めすぎた反映間隔23を、前回の半分まで一気に戻す。つまり、慎重を期して、一度には復旧させず、復旧を加速する程度にとどめている。
【0074】
なお、図1に示すように、上記文書編集装置では、反映処理(インデックス化プロセス21)を行う時点でのみ反映間隔の調整プロセス25を行うので、後述する参考例2のようにステップS12,S13(図8)は必要ない。
【0075】
ここで、上記の各ステップの演算式について説明する。
【0076】
(1)品質の適正範囲について
上述のように、品質の適正範囲を0.75≦F≦1.0に設定している。適正品質下限を1.0に近づけ過ぎると、反映間隔が振動しやすくなり、未反映率が正しく求められなくなる。逆に、適正品質下限を低くしすぎると、制御が弱まって品質が過剰気味になるため、装置の負荷が増大する。ゆえに、適正品質下限を反映間隔が振動しない程度の適当な値に設定する必要がある。そこで、本実施の形態では、適正品質下限を0.75に設定した。
【0077】
(2)欠陥時の係数について
上述のように、品質の欠陥が発生した時には、係数(1/F)を反映間隔に乗じる。これにより、次回以降の未反映率が1程度になると期待できる。なお、欠陥の防止を重視する場合には、係数を例えば(0.9/F)とすればよい。ただし、過度に係数を小さく(調整を厳しく)すると、反映間隔が振動しやすくなる。
【0078】
(3)品質過剰時の係数について
上述のように、品質過剰時には、係数(3/8F)+(1/2)を反映間隔に乗じる。ただし、この係数は2を上限とする。この係数は、欠陥時の係数(1/F)よりも調整を緩やかに、すなわち、係数を1に近づけている。また、係数を(1/F)の関数と見たときに、関数が不連続にならないようになっている。すなわち、不連続関数を避けて、調整を安定化している。このように、調整を緩やかにすること、および、係数に上限を設けることは、ともに一時的な波動への対処として有効である。
【0079】
(4)復旧を加速する度合いについて
上述のように復旧を加速すると、反映間隔が2倍以上になる。この2という下限値と、品質過剰時の係数における上限値2とは、調整を安定化するために意図的に一致させている。また、前回の反映間隔をそのまま採用する代わりに、その0.5倍の値を採用するのは、慎重を期して、一度には復旧させず、復旧を加速する程度にとどめるためである。なお、復旧を加速するだけであるため、Fの期待値は0.5に過ぎず、F<0.75である可能性が相当ある。その場合には、通常の品質過剰として扱う。
【0080】
以上のように、本実施の形態に係るデータベースシステムは、一つ以上の情報蓄積装置を対象とする検索の便宜を図るために、検索補助用の情報を生成し、別の一つ以上の情報蓄積装置に蓄え、検索対象の情報蓄積装置に対して行われた書換えを、間欠的に検索補助用の情報へ反映するとともに、反映処理の時期を自動制御する。
【0081】
また、本実施の形態に係るデータベースシステムは、反映処理が間欠的であるために情報蓄積装置群の相互間に生ずる誤差の度合いを計算もしくは推定し、求めた誤差の過去一回以上の値を時期を制御する指標として用いる。
【0082】
さらに、本実施の形態に係るデータベースシステムは、ある情報蓄積装置に蓄積された内容のうち、書換えがまだ他の情報蓄積装置へ反映されていないものの比率を計算もしくは推定し、情報蓄積装置群の相互間に生ずる誤差を表す指標として、上記の比率を用いる。
【0083】
加えて、本実施の形態に係るデータベースシステムは、ある情報蓄積装置に蓄積された内容のうち、書換えがまだ他の情報蓄積装置へ反映されていないものの比率を計算もしくは推定しフィードバックする処理について、上記の処理を行う。
【0084】
したがって、本実施の形態に係る文書編集装置は、文書群からインデックスへの反映時期を自動制御する。すなわち、上記文書編集装置は、所定の条件または計算によって反映(インデックス化プロセス21)の時間間隔(反映間隔23)を加減し、あるいは、所定の条件を満たしたときに反映を開始し、あるいは、所定の条件を満たさないときには反映を開始しない。その条件として、例えば未反映率、すなわち文書ファイル群2への書換えがインデックス12へ反映されていない比率を使う。
【0085】
よって、上記のように反映の時期を自動制御することにより、過剰頻度による設備への過負荷や、過少頻度による情報精度の低下を防ぎながら、文書ファイル群2への書換えをインデックス12に間欠的に反映することができる。
【0086】
なお、上記文書編集装置は、従来例2の装置に対しても同様に、仕入先DBから総目次への反映時期の自動制御に応用できる。
【0087】
また、上記文書編集装置は、原本(文書ファイル群2)の書換えとは独立して、反映処理(インデックス化プロセス21)が未反映率の算出プロセス27を駆動する。そして、上記文書編集装置は、現在の未反映率と基準値とを比較して得られた比較結果に基づいて、反映処理(インデックス化プロセス21)を開始する反映間隔23を加減する。
【0088】
すなわち、上記文書編集装置では、未反映率を算出する負荷が反映処理の負荷と比べて無視できないため、反映間隔を加減するという間接的な方法によって、反映時期の自動制御を実現している。
【0089】
〔参考例1〕
本発明の参考例について図3から図6に基づいて説明すれば、以下のとおりである。なお、説明の便宜上、前記の実施の形態1において示した部材と同一の機能を有する部材には、同一の符号を付し、その説明を省略する。
【0090】
本参考例は、本発明に係るデータベースシステムを、本支店間にまたがる電子電話帳システムへ適用した例である。なお、本参考例は、前記従来例3で説明した装置への応用例に相当する。よって、全体の構成は従来例3の装置と同じである。
【0091】
図5および図6は、本参考例に係る電子電話帳システムの全体の構成を示すDFDである。なお、DFDの記法については、前記の従来例1で説明したとおりである。
【0092】
図5に示すように、上記電子電話帳システムは、低速回線で結ばれた本店Hおよび各支店Bn,Bsの間で、電子電話帳データを共有するデータベースシステム(設備)である。ここで、上記電子電話帳システムは、回線速度が低速であり、対話型の遠隔検索には不適であるため、各支店Bn,Bsに本店DB(database)2′の複製である支店DB12′を置く。そして、平常時の検索は、高速な構内回線だけを経由して、自店のDB2′,12′のみに対して行う。そして、故障または保守作業で自店構内のDBの停止中に限り、他店のDBを検索する(図6)。なお、図6では、支店DB12′が停止した場合に、北支店Bnの支店端末11が本店DB2′および南支店Bsの支店DB12′を検索している状態を示している。
【0093】
ここで、本参考例では、本店Hおよび各支店Bn,Bsの間で、DBの一貫性を保つために、本店Hが原本を管理し、各支店Bn,BsがDBの変更を本店Hに依頼する方法を採用する。そのため、本店Hの本店DB(電子電話帳DB)2′は、更新機能を備えている。そして、各支店Bn,Bsからの変更依頼は、随時、本店DB(第1の情報蓄積装置)2′に反映される。一方、各支店Bn,Bsの支店DB(複製)(第2の情報蓄積装置)12′…は簡易型であり、更新機能は備えていない。よって、適宜、支店DB12′…を停止して、本店DB2′の内容を書き写す必要がある。
【0094】
上記複製プロセス21′の概略は、以下のとおりである。まず、本店DB2′の更新を禁止し、全データを読み出し、更新の禁止を解除する。つぎに、読み出した内容を各支店Bn,Bsに配信する。各支店Bn,Bsでは、データ受信が完了すると、DB検索サービスを停止し、受信したデータで支店DB12′…の内容を書換え、完了後検索サービスを再開する。
【0095】
ここで、この複製プロセス(反映手段、反映処理)21′の間隔が短すぎると、本店DB2′から全データを読み出す負荷、各支店Bn,Bsに配信する回線負荷、および支店Bn,Bsを停止するサービス低下などの無駄が生じる。この点、上記電子電話帳システムは、この複製プロセス(処理)21′(後述)のタイミングを自動制御することによって、これらの無駄を防ぎつつ検索の品質を保つことができる。
【0096】
図3に示すDFDを用いて、上記電子電話帳システムの機能を詳細に説明する。
【0097】
上記電子電話帳システムは、アクターである本店端末1′、支店端末11と、データストアである本店DB2′、変更依頼3、更新履歴5、支店DB12′、未反映率の基準26と、プロセスである更新プロセス4′、複製プロセス21′、未反映率の算出プロセス27、未反映率の比較プロセス(反映制御手段、反映制御処理)28とを含んで構成されている。
【0098】
まず、各アクターについて説明する。
【0099】
上記本店端末1′は、本店Hに設置した利用者用の端末装置である。本店端末1′は、本店DB2′の電子電話帳DBを検索するほか、本店DB2′の変更依頼を発行する。そのため、本店端末1′は、キーボード入力装置、画面表示装置、および印字装置(プリンタ)を備えて構成されている。
【0100】
上記支店端末11は、各支店Bn,Bsに設置した利用者用の端末装置であり、電子電話帳DB(本店DB2′)の変更依頼を発行する。なお、図6に示すように、支店端末11は、支店DB12′の停止中には、本店DB2′を遠隔検索することもできる。
【0101】
つぎに、各データストアについて説明する。
【0102】
上記本店DB2′は、本店Hに設置された電子電話帳DBであり、電子電話帳DBの原本を格納する。本店DB2′は、主に本店Hから検索される。なお、図6に示すように、支店DB12′の停止中には、支店端末11から遠隔検索されることもある。また、本店DB2′および支店DB12′は内容を反映する対象である情報蓄積装置である。
【0103】
上記変更依頼3は、本店端末1′と支店端末11とから発行された、本店DB2′(電子電話帳DB)の変更依頼(書換え要求)である。
【0104】
上記更新履歴5は、更新プロセス4′が処理した更新処理の履歴の蓄積である。更新履歴5は、未反映率の算出プロセス27で未反映率を算出するために用いられる。なお、更新履歴5は本店DB2′の障害復旧時にも利用される。
【0105】
上記支店DB12′は、各支店Bn,Bsに設置された電子電話帳DB(複製)である。支店DB12′は、更新機能を備えない簡易型であり、データの検索しかできない。なお、電子電話帳DBのデータの作成、更新は、本店Hで行う。また、図6に示すように、支店DB12′は、他店のDBの停止中には、他店の端末から遠隔検索されることもある。
【0106】
上記未反映率の基準26は、未反映率の比較プロセス28(後述)で複製プロセス21′を起動するための基準値を与える。未反映率の基準26は、本店端末1′より変更することができる。
【0107】
つぎに、各プロセスについて説明する。
【0108】
上記更新プロセス4′は、本店DB2′(原本)を更新する。更新プロセス4′は、本店Hのみで行われ、本店端末1′および支店端末11からの変更依頼3に基づいて、本店DB2′を更新する。
【0109】
上記複製プロセス21′は、本店DB2′の内容を支店DB12′に書き写す。複製プロセス21′は、本店Hに設けられるが、回線を経由して支店DB12′を遠隔制御する機能を含んでいる。そして、上記電子電話帳システムでは、複製プロセス21′を起動する時期を自動制御する。
【0110】
この複製プロセス21′の手順は次のとおりである。まず、本店DB2′を更新禁止し、全データを読み出し、更新禁止を解除する。つぎに、読み出した内容を各支店Bn,Bsに配信する。各支店Bn,Bsでは、データ受信が完了すると、DB検索サービスを停止し、受信したデータで支店DB12′の内容を置き換え、検索サービスを再開する。
【0111】
上記未反映率の算出プロセス27は、定期的に、本店Hおよび各支店Bn,Bs間のDBの誤差を示す未反映率を求めて、フィードバックする。
【0112】
上記未反映率の比較プロセス28は、未反映率を基準と比較して、複製プロセス21′による反映を開始させる。そのために、未反映率の比較プロセス28は、次の二つの内部処理を含んでいる。すなわち、未反映率の比較プロセス28は、未反映率の算出プロセス27で求めた現在の未反映率を、未反映率の基準26の基準値と比較する内部処理と、現在の未反映率が未反映率の基準26の基準値より大きい場合に複製プロセス21′を起動する内部処理とを含んでいる。
【0113】
ここで、更新プロセス4′は、変更依頼3に基づいて、随時実行される。つまり、更新プロセス4′のために、DB検索サービスは停止されない。更新プロセス4′は、本店DB2′が更新中でなくかつ更新禁止状態でないときに、変更依頼3を順次処理する。なお、本店DB(原本)2′は、複製プロセス21′の作業中、および負荷が高いときに、更新禁止状態になる。
【0114】
また、更新プロセス4′は、変更依頼3の1件を処理し終わった時点で、休止するかどうかを判断する。まず、未処理の変更依頼3が残っていない場合には、未反映率の算出プロセス27を起動した後、更新プロセス4′は休止する。また、本店DB2′が更新禁止状態である場合には、単に更新プロセス4′が休止する。そして、未処理の変更依頼3が残っており、本店DB2′が更新禁止状態でない場合には、次の変更依頼3の1件を処理する。
【0115】
更新プロセス4′は、休止状態において、起動するための事象を待ち受けており、本店DB2′が更新可能状態で、かつ、新しい変更依頼3が入ってくると起動する。
【0116】
図4のフローチャートを用いて、上記未反映率の比較プロセス28の手順を説明する。
【0117】
上記未反映率の比較プロセス28は、ステップS11およびステップS13だけからなる。ステップS11では、誤差の過大を検出する。すなわち、未反映率が基準より大きければ(YES)、品質を回復するために、ステップS13へ移行して、直ちに複製プロセス21′(反映処理)を開始する。
【0118】
本参考例に係るデータベースシステムは、一つ以上の情報蓄積装置に蓄えられた、原本となる内容の一部または全部を複製し、他の一つ以上の情報蓄積装置に蓄え、原本になされた書換えを、間欠的に複製へ反映するするとともに、反映処理の時期を自動制御する。
【0119】
また、本参考例に係るデータベースシステムは、反映処理が間欠的であるために情報蓄積装置群の相互間に生ずる誤差の度合いを、計算もしくは推定し、求めた誤差の過去一回以上の値を時期を制御する指標として用いる。
【0120】
また、本参考例に係るデータベースシステムは、ある情報蓄積装置に蓄積された内容のうち書換えがまだ他の情報蓄積装置へ反映されていないものの比率を、計算もしくは推定するとともに、情報蓄積装置群の相互間に生ずる誤差を表す指標として、上記の比率を用いる。
【0121】
さらに、本参考例に係るデータベースシステムは、ある情報蓄積装置に蓄積された内容のうち、書換えがまだ他の情報蓄積装置へ反映されていないものの比率を、計算もしくは推定し、フィードバックする処理について、上記の処理を行う。
【0122】
したがって、本参考例に係る電子電話帳システムは、DBの原本(本店DB2′)を更新する更新プロセス4′が未処理の変更依頼3をすべて処理し終えて休止する際に、未反映率の算出プロセス27および未反映率の比較プロセス28を駆動する。そして、未反映率の比較プロセス28が複製(支店DB12′)に反映する複製プロセス21′を駆動する。
【0123】
さらに、上記電子電話帳システムは、現在の未反映率と基準値とを比較して得られた比較結果に基づいて、反映処理(複製プロセス21′)を開始するか否かを判断する。具体的には、未反映率が基準値を超えた時に、複製プロセス21′を起動して、本店DB2′に対して行われた更新を支店DB12′に反映させる。
【0124】
すなわち、上記電子電話帳システムでは、未反映率を算出する負荷が、反映処理の負荷と比べて、ほとんど無視できることを利用して、上記のような直接的かつ単純な反映時期の自動制御方法を実現している。
【0125】
〔参考例2〕
本発明の他の参考例について図7から図9に基づいて説明すれば、以下のとおりである。なお、説明の便宜上、前記の実施の形態1および参考例1において示した部材と同一の機能を有する部材には、同一の符号を付し、その説明を省略する。
【0126】
本参考例は、本発明に係るデータベースシステムを、本支店間にまたがる電子電話帳システムへ適用した例である。なお、本参考例は、前記従来例4で説明した装置への応用例に相当する。よって、全体の構成は従来例4の装置と同じである。
【0127】
図9は、本参考例に係る電子電話帳システムの全体の構成を示すDFDである。なお、DFDの記法については、前記の従来例1で説明したとおりである。
【0128】
上記電子電話帳システムは、低速回線で結ばれた本店Hおよび各支店Bn,Bsの間で、電子電話帳データを共有するデータベースシステム(設備)である。ここで、上記電子電話帳システムは、回線速度が低速であり、対話型の遠隔検索に不適であるため、各支店Bn,Bsに本店DB2′の複製を置く。そして、平常時の検索は、高速な構内回線だけを経由して、自店のDB2′,12″…のみに対して行う。そして、故障または保守作業で自店構内のDBの停止中に限り、他店のDBを検索する。
【0129】
ここで、本参考例では、本店Hおよび各支店Bn,Bsの間で、DBの一貫性を保つために、各店のDBに自ら更新する権利を与え、各店のDBが適宜内容の同期を取る方法を採用する。すなわち、各店のDBが、相互に情報交換して、個別に更新した内容を互いに反映し合い、すべてのDBの内容を一致させる。上記電子電話帳システムでは、この同期処理を行う時間間隔を自動制御する。なお、本参考例は、支店DB12″が更新機能を備えている点で、参考例1と異なっている。
【0130】
上記同期プロセス21″の概略は、以下のとおりである。まず、全店のDB(本店DB2′,支店DB12″)の更新を禁止する。つぎに、全店の更新履歴から必要な情報を集める。必要な情報とは、前回の同期プロセス21″の開始より後に処理され、かつ同期プロセス21″のためでない、更新処理の更新履歴である。つづいて、集められた情報に基づき、全店のDBに対して必要な挿入、更新、および削除の操作群を特定する。そして、挿入および更新の内容を元のDBから読み込んだ後、各店のDBに対して更新要求を発行する。最後に、全店のDBの更新禁止を解除する。例えば、北支店Bnで挿入したレコードは、北支店Bnの支店DB12″から読み込まれ、本店Hの本店DB2′および南支店Bsの支店DB12″に挿入される。
【0131】
ここで、同期プロセス21″のための更新要求には「同期処理用」のマークが付けられる。そして、その更新要求が処理されたとき、その更新履歴にも「同期処理用」のマークが付けられる。この「同期処理用」のマークが付いた更新履歴は、同期処理の対象にしない。なお、更新要求に付ける「同期処理用」のマークは、当該更新要求を処理した記録である更新履歴に「同期処理用」のマークを付けるために付けられる。
【0132】
ここで、この同期プロセス21″の間隔が短すぎると、全店のDBの更新を禁止することによる更新の遅延、全店より更新履歴を集めるための設備(装置および回線)の負荷、および更新履歴を解析するための装置の負荷などの無駄が生じる。この点、上記電子電話帳システムは、この同期プロセス21″のタイミングを自動制御することによって、これらの無駄を防ぎつつ検索の品質を保つことができる。
【0133】
つづいて、図7に示すDFDを用いて、上記電子電話帳システムの機能を詳細に説明する。
【0134】
上記電子電話帳システムは、アクターである本店端末1′、支店端末11と、データストアである本店DB(第1の情報蓄積装置)2′、更新要求3″、更新履歴5、支店DB(第2の情報蓄積装置)12″、更新要求13、更新履歴15、最終反映時刻22、反映間隔23、未反映率の基準26と、プロセスである更新プロセス4″、更新プロセス14、同期プロセス(反映手段、反映処理)21″、時間の比較プロセス(反映制御手段、反映制御処理)24、反映間隔の調整プロセス(反映間隔設定手段、反映間隔設定処理)25、未反映率の算出プロセス27″とを含んで構成されている。
【0135】
なお、各支店Bn,Bsは、上記の支店端末11と、支店DB12″、更新要求13、更新履歴15と、更新プロセス14とを一組ずつ備えている。それ以外は、本店Hに設けられている。
【0136】
まず、各アクターについて説明する。
【0137】
上記本店端末1′は、本店Hに設置した利用者用の端末装置である。本店端末1′は、本店DB2′の電子電話帳DBを検索するほか、本店DB2′の更新要求3″を発行する。そのため、本店端末1′は、キーボード入力装置、画面表示装置、および印字装置(プリンタ)を備えて構成されている。
【0138】
上記支店端末11は、各支店Bn,Bsに設置した利用者用の端末装置であり、電子電話帳DB(本店DB2′および支店DB12″)の更新要求13を発行する。なお、図示しないが、支店端末11は、支店DB12″の検索が可能であり、支店DB12′の停止中には本店DB2′を遠隔検索することもできる。
【0139】
つぎに、各データストアについて説明する。
【0140】
上記本店DB2′は、本店Hに設置された電子電話帳DBであり、電子電話帳DBを格納する。本店DB2′は、主に本店Hから検索される。なお、参考例1と異なり、原本という位置付けではない。また、図示しないが、本店DB2′は、支店DB12″の停止中に、支店端末11から遠隔検索されることもある。さらに、本店DB2′および支店DB12″は内容を反映する対象である情報蓄積装置である。
【0141】
上記更新要求3″は、本店DB2′に対する更新の要求である。本店端末1′から発行されるほか、同期プロセス21″(後述)からも発行される。
【0142】
上記更新履歴5は、更新プロセス4″が処理した更新処理の履歴の蓄積である。更新履歴5は、未反映率の算出プロセス27″における未反映率の算出、および同期プロセス21″に用いられる。なお、更新履歴5は本店DB2′の障害復旧時にも利用される。
【0143】
上記最終反映時刻22は、同期プロセス21″(後述)による反映を最後に実行した時刻である。最終反映時刻22は、同期プロセス21″に着手する都度更新されて、記憶される。
【0144】
上記反映間隔23は、同期プロセス21″を実行すべき時間の間隔であり、分(minute)単位で表される。反映間隔23は、反映間隔の調整プロセス25(後述)によって設定される都度更新されて、記憶される。
【0145】
上記未反映率の基準26は、反映間隔の調整プロセス25(後述)で反映間隔(頻度)を調整するための基準値、つまり同期プロセス21″を起動するための基準値を与える。未反映率の基準26は、利用者によって本店端末1′介して入力・変更(調整)され、記憶される。
【0146】
上記支店DB12″は、各支店Bn,Bsに設置された電子電話帳DBである。支店DB12″は、参考例1の支店DB12′と異なり、更新機能を備えている。なお、図示しないが、支店DB12″は、他店のDBの停止中には、他店の端末から遠隔検索されることもある。
【0147】
上記変更要求13は、支店DB12″に対する更新の要求である。支店端末11から発行されるほか、同期プロセス21″(後述)からも発行される。
【0148】
上記更新履歴15は、更新プロセス14が処理した更新処理の履歴の蓄積である。更新履歴15は、未反映率の算出プロセス27″における未反映率の算出、および同期プロセス21″に用いられる。なお、更新履歴15は支店DB12″の障害復旧時にも利用される。
【0149】
つぎに、各プロセスについて説明する。
【0150】
上記更新プロセス4″は、更新要求3″に基づいて、本店DB2′を更新する。そして、更新プロセス4″は、更新要求3″に基づいて、随時実行される。
【0151】
上記同期プロセス21″は、各店DB相互間で内容の同期を取る。同期プロセス21″は、本店Hに設けられるが、回線を経由して各支店Bn,Bsの設備を遠隔操作する機能を含んでいる。そして、上記電子電話帳システムでは、同期プロセス21″を起動する時間間隔を自動調整する。
【0152】
この同期プロセス21″の手順は次のとおりである。まず、本店DB2′および各支店DB12″…を更新禁止にする。つぎに、本店Hの更新履歴5および各支店Bn,Bsの更新履歴15…から必要な情報を集める。必要な情報とは、前回の同期プロセス21″の開始より後に処理され、かつ同期プロセス21″のためでない、更新プロセス4″,14の履歴である。つづいて、集められた情報に基づき、本店DB2′および各支店DB12″…に対して、必要な挿入、更新、および削除の操作群を特定する。そして、挿入および更新の内容を元の本店DB2′および各支店DB12″…から読み込んだ後、本店DB2′および各支店DB12″…に対して、更新要求3″,13を発行する。最後に、本店DB2′および各支店DB12″…の更新禁止を解除する。
【0153】
上記時間の比較プロセス24は、最終反映時刻22から現在までに経過した時間と反映間隔23とを比較し、前者が後者より小さくなければ同期プロセス21″を起動する。
【0154】
上記反映間隔の調整プロセス25は、未反映率を基準値と比較して、反映間隔23を調整する。反映間隔の調整プロセス25は、後で図8を用いて詳述するが、次の三つの内部処理を含んでいる。すなわち、反映間隔の調整プロセス25は、未反映率を基準値と比較する内部処理と、未反映率が過小ならば反映間隔23を増やす内部処理と、未反映率が過大ならば反映間隔23を減らす内部処理とを含んでいる。そして、未反映率が過大ならば、直ちに同期プロセス21″を起動する。
【0155】
上記未反映率の算出プロセス27″は、定期的に、各店DB間の誤差を示す未反映率を求め、フィードバックする。具体的には、本店DB2′に対する未反映率を、各支店Bn,Bsの支店DB12″…についてそれぞれ求め、その中で最も高い値を、反映間隔の調整プロセス25へ送る。なお、上記電子電話帳システムでは、支店相互間の未反映率は計算しない。
【0156】
上記更新プロセス14は、更新要求13に基づいて、支店DB12″を更新する。ここで、更新プロセス14は、更新要求13に基づいて、随時実行される。つまり、更新プロセス14のために、DB検索サービスは停止されない。更新プロセス14は、支店DB12″が更新中でなくかつ更新禁止状態でないときに、変更依頼13を順次処理する。なお、支店DB12″は、同期プロセス21″の作業中、および負荷が高いときに、更新禁止状態になる。また、更新プロセス14の休止と起動については、本店Hの更新プロセス4″と同様である。
【0157】
ここで、更新プロセス4″は、更新要求3″に基づいて、随時実行される。つまり、更新プロセス4″のために、DB検索サービスは停止されない。更新プロセス4″は、本店DB2′が更新中でなくかつ更新禁止状態でないときに、更新要求3″を順次処理する。なお、本店DB2′は、同期プロセス21″の作業中、および負荷が高いときに、更新禁止状態になる。
【0158】
また、更新プロセス4″は、更新要求3″の1件を処理し終わった時点で、休止するかどうかを判断する。まず、未処理の更新要求3″が残っていない場合、または本店DB2′が更新禁止状態の場合であれば、休止する。そうでなければ、次の更新要求3″の1件を処理する。なお、参考例1では更新プロセス4′が休止する際に未反映率の算出プロセス27を起動したが、本参考例では更新プロセス4″が休止する際には未反映率の算出プロセス27″を起動しない。
【0159】
更新プロセス4″は、休止状態において、起動するための事象を待ち受けており、本店DB2′が更新状態状態で、かつ、新しい更新要求3″が入ってくると起動する。
【0160】
図8のフローチャートを用いて、上記反映間隔の調整プロセス25の手順を示す。なお、図8は、実施の形態1で説明した図2のフローチャートに、ステップS12,S13を追加したものである。この追加部分は、図7における反映間隔の調整プロセス25から同期プロセス21″へ向かう制御フロー(誤差警報)を発生させるものである。
【0161】
ステップS12では、未反映率をその時点の警戒基準と比較して、未反映率が基準(未反映率の基準26)を超過する危険を判定する。そして、未反映率が警戒基準を超過していれば、基準を超過したのと同じ扱いをする。
【0162】
上記警戒基準は、以下の式により、監視した時点の現在時刻、最終反映時刻22、および反映間隔23の3つの値から計算した係数を、未反映率の基準26に乗じて算出する。
【0163】
警戒基準=未反映率の基準26
×(現在時刻−最終反映時刻22+反映間隔23)
÷(2×反映間隔23)
ここで、反映処理が終了した瞬間には、未反映率はゼロに下がっている。その後、更新要求が処理されるにつれて、未反映率が上昇する。よって、反映処理の各回の間、未反映率は時間とともに上昇する。そのため、未反映率を監視していれば、所定の反映間隔が経過しないうちに未反映率が基準を超過する危険を予測できる。よって、監視した時点で未反映率が警戒基準を超過していれば、所定の反映間隔が経過しないうちに未反映率が基準を超過する危険性が高いと判断できる。
【0164】
ステップS13では、未反映率が基準(S11)あるいは警戒基準(S12)を超えているため、直ちに誤差警報を発行して同期プロセス21″(反映処理)を開始する。そして、ステップS16′へ移行して、反映間隔23を縮める。具体的には、未反映率(誤差)が反映間隔23に比例するものと考え、未反映率とその基準との比率によって調整する。すなわち、未反映率が基準のF倍であれば、反映間隔23をF分の1にする。ただし、ステップS16′中のTは以下の式で与えられるものとする。
【0165】
T=min(反映間隔23,最終反映時刻22−現在時刻)
なお、ステップS12,S13,S16′以外のステップは、図2と同じであるので説明を省略する。また、フローチャート中の各ステップにおける演算式は一例であり、これに限定されない。
【0166】
ここで、本参考例は、ある時期に更新要求が到着するペースがある程度一定していることを前提としている。仮に、更新要求が完全に一定のペースで到着するならば、警戒基準は以下の簡略化された式で求めることができる。
【0167】
警戒基準=未反映率の基準26
×(現在時刻−最終反映時刻22)÷反映間隔23
しかし、実際の更新要求はランダムに到着するものであり、この点を考慮した予測を行うために警戒基準を利用している。そのため、予測に用いるサンプル数を考慮する必要がある。前回の反映処理から現在までの時間が短ければ短い程、サンプル数は少なくなる。そして、この状況で上記の簡略化された式により警戒基準を求めると、誤差警報が誤報となる危険性が高くなる。また、前回の反映処理から現在までの時間が短ければ短い程、基準までには余裕があるはずであり、警戒基準を緩くすることができる。これによって、誤報を避けることができる。上記ステップS12における警戒基準の式は、この考え方に基づいて決められている。
【0168】
また、実施の形態1では、反映処理(インデックス化プロセス21)が未反映率の算出プロセス27を駆動するが、これらは原本(文書ファイル群2)の書換えとは独立であった。また、参考例1では、本店DB2′(原本)の更新が、未反映率の算出プロセス27および未反映率の比較プロセス28を駆動する。そして、未反映率の比較プロセス28が反映処理(複製プロセス21′)を駆動していた。
【0169】
これに対して、本参考例では、未反映率の算出プロセス27″を起動するタイミングが2通り可能であり、どちらもDBの更新とは独立である。一つは、実施の形態1と同様、反映処理(同期プロセス21″)のタイミングである。もう一つは、時間の比較プロセス24による所定の時間間隔(以下、「監視間隔」と記す。)である。本参考例では、反映間隔23の8分の1の間隔で未反映率の算出プロセス27″を起動する。
【0170】
ここで、上記監視間隔は反映間隔23より短い任意の時間間隔である。実験によれば、監視間隔が長い程、欠陥(未反映率が基準を超過する現象)が多発するが、監視間隔を反映間隔の8分の1以下に設定しても欠陥を減らす効果は上がらなかった。そこで、本参考例では、この実験結果に基づいて、監視間隔を反映間隔の8分の1に設定している。
【0171】
なお、本参考例では、反映間隔23の自動調整を行っているが、上記監視間隔の自動調整を行うことも可能である。すなわち、未反映率によって反映間隔23を制御するのと同様に、欠陥発生率によって監視間隔を制御することが可能である。
【0172】
また、実施の形態1および参考例1、2とも、反映時期の自動制御方法は、現在の未反映率を基準値と比較することだが、比較結果の扱い方が異なる。実施の形態1では、比較結果によって反映間隔を加減するという、間接的な方法である。参考例1では、比較結果によって反映処理を開始するかどうか判断するという、直接的な方法である。そして、本参考例では、両者を併用している。
【0173】
本参考例に係るデータベースシステムは、複数の情報蓄積装置の相互間で、内容の一部又は全部を同一に保ち、一部の情報蓄積装置になされた書換えを、間欠的に他へ反映するとともに、反映処理の時期を自動制御する。
【0174】
また、本参考例に係るデータベースシステムは、反映処理が間欠的であるために情報蓄積装置群の相互間に生ずる誤差の度合いを、計算もしくは推定し、求めた誤差の過去一回以上の値を時期を制御する指標として用いる。
【0175】
さらに、本参考例に係るデータベースシステムは、ある情報蓄積装置に蓄積された内容のうち、書換えがまだ他の情報蓄積装置へ反映されていないものの比率を計算もしくは推定し情報蓄積装置群の相互間に生ずる誤差を表す指標として、上記の比率を用いる。
【0176】
加えて、本参考例に係るデータベースシステムは、ある情報蓄積装置に蓄積された内容のうち、書換えがまだ他の情報蓄積装置へ反映されていないものの比率を計算もしくは推定しフィードバックする処理について、上記の処理を行う。
【0177】
以上のように、本発明に係るデータベースシステムは、同期処理(反映処理)の時期を、利用者の手動操作あるいは単純な一定時間間隔とせず、状況に応じて動的に制御することによって、情報の同一性と装置の負荷という相反する二つの要素のバランスを最適に維持できる。
【0178】
すなわち、本発明に係るデータベースシステムの制御方法は、情報蓄積装置間の反映処理の時期を、利用者の手動操作あるいは単純な一定時間間隔とせず、状況に応じて時期を動的に制御する。具体的には、上記データベースシステムの制御方法は、所定の条件または計算によって反映の時間間隔を加減し、あるいは、所定の条件を満たしたときに反映を開始し、あるいは、所定の条件を満たさないときには反映を開始しないように、反映処理の時期を自動制御する。しがたって、情報の精度と装置の負荷という相反する二つの要素のバランスを最適に維持できる。
【0179】
また、本発明に係るデータベースシステムの制御方法は、情報蓄積装置群の相互間に生ずる誤差の度合いによって、反映の時期を制御する。そのために、上記データベースシステムは、読み出しまたは検索の結果/現状で実行した結果/書換えた結果をすべて反映したうえで実行した結果と比べたときに、どれぐらい誤りが生ずるかを、計算もしくは推定する。このとき、実際に実行して比較するかもしくは実際に実行するより負荷の軽い方法で誤差の度合いを求める。そして、その計算値もしくは推定値に基づいて、反映の時期を制御する。
【0180】
そして、具体的な反映時期の制御方法としては、例えば、インデックスの誤差が所定の範囲内に収まるように反映の時間間隔を加減する方法、誤差が所定の基準を超えたときに反映を開始する方法、誤差が所定の基準に収まるときには反映を開始しない方法等がある。
【0181】
本発明に係るデータベースシステムの制御方法は、ある情報蓄積装置に蓄積された内容のうち、書換えがまだ他の情報蓄積装置へ反映されていないものの比率を、計算もしくは推定する方法を含んでいてもよい。そして、この比率を、上記の「情報蓄積装置群の相互間に生ずる誤差の度合い」を表す指標として用いることができる。
【0182】
これにより、上記データベースシステムは、複数の情報蓄積装置群において、ある情報蓄積装置になされた書換えを、繰り返し他へ反映するとともに、反映処理を実行する時期を自動制御することができる。
【0183】
本発明に係るデータベースシステムは、複数の情報蓄積装置群において、ある情報蓄積装置になされた書換えを、繰り返し他へ反映する手段と、その手段を用いて反映処理を実行する時期を自動制御する手段とを備えている。あるいは、上記データベースシステムは、反映処理の時期を自動制御する手段を備えている。あるいは、上記データベースシステムは、反映処理が間欠的であるために情報蓄積装置群の相互間に生ずる誤差の度合いを計算もしくは推定する手段と、それを自動制御のためにフィードバックする手段を備えている。あるいは、上記データベースシステムは、ある情報蓄積装置に蓄積された内容のうち、書換えがまだ他の情報蓄積装置へ反映されていないものの比率を計算もしくは推定する手段と、それを自動制御のためにフィードバックする手段とを備えている。なお、これらの手段は、前記の対応する制御方法を実行するものである。
【0184】
本発明に係るデータベースシステムの制御方法を記録した記録媒体は、前記の方法を実行するプログラムをコンピュータにより実行可能に記憶している。そして、このプログラムを読み取ることによって記憶を再現し、再現したプログラムを一台あるいはそれ以上の情報処理装置によって実行することが可能である。このようにして実行することによって、本発明の目的を達成することができる。
【0185】
また、上記記録媒体は、データベースシステムにおいて、反映を行う時期を自動制御する方法を実行するプログラムを記憶している。そして、このプログラムを読み取ることによって記憶を再現し、再現したプログラムを一台あるいはそれ以上の情報処理装置によって、つぎに述べる手段と組み合わせて実行することが可能である。その手段とは、その装置に固有の手段(プログラムを含む)または何らかの媒体から読み取ったプログラムを実行することによって実現されるものであり、両手段を組み合わせて実行することによって、本発明の目的を達成することができる。
【0186】
また、上記記録媒体は、データベースシステムにおいて、反映処理が間欠的であるために情報蓄積装置群の相互間に生ずる誤差の度合いを計算もしくは推定し、フィードバックする方法を実行するプログラムを記憶している。そして、このプログラムを読み取ることによって記憶を再現し、再現したプログラムを一台あるいはそれ以上の情報処理装置によって、つぎに述べる手段と組み合わせて実行することが可能である。その手段とは、その装置に固有の手段(プログラムを含む)または何らかの媒体から読み取ったプログラムを実行することによって実現されるものであり、両手段を組み合わせて実行することによって、本発明の目的を達成することができる。
【0187】
また、上記記録媒体は、データベースシステムにおいて、ある情報蓄積装置に蓄積された内容のうち、書換えがまだ他の情報蓄積装置へ反映されていないものの比率を計算または推定し、フィードバックする方法を実行するプログラムを記憶している。そして、このプログラムを読み取ることによって記憶を再現し、再現したプログラムを一台あるいはそれ以上の情報処理装置によって、つぎに述べる手段と組み合わせて実行することが可能である。その手段とは、その装置に固有の手段(プログラムを含む)または何らかの媒体から読み取ったプログラムを実行することによって実現されるものであり、両手段を組み合わせて実行することによって、本発明の目的を達成することができる。
【0188】
なお、本参考例は本発明の範囲を限定するものではなく、本発明の範囲内で種々の変更が可能であり、例えば、以下のように構成することができる。
【0189】
本発明に係るデータベースシステムの制御方法は、複数の情報蓄積装置群において、一部の情報蓄積装置になされた書換えを、間欠的に他へ反映する方法であって、反映処理の時期を自動制御する方法であってもよい。
【0190】
これにより、上記データベースシステムは、情報蓄積装置間の反映処理の時期を、利用者の手動操作あるいは単純な一定時間間隔とせず、状況に応じて動的に制御することによって、情報の精度と装置の負荷という相反する二つの要素のバランスを最適に維持できる。
【0191】
本発明に係るデータベースシステムの制御方法は、一つ以上の情報蓄積装置を対象とする検索の便宜を図るために、検索補助用の情報を生成し、別の一つ以上の情報蓄積装置に蓄える方法であって、検索対象の情報蓄積装置になされた書換えを、間欠的に検索補助用の情報へ反映する方法であって、反映処理の時期を自動制御する方法であってもよい。
【0192】
これにより、上記データベースシステムは、検索対象から検索補助情報への反映処理の時期を、利用者の手動操作あるいは単純な一定時間間隔とせず、状況に応じて動的に制御することによって、検索の品質と装置の負荷という相反する二つの要素のバランスを最適に維持できる。
【0193】
本発明に係るデータベースシステムの制御方法は、一つ以上の情報蓄積装置に蓄えられた、原本となる内容の一部または全部を複製し、他の一つ以上の情報蓄積装置に蓄える方法であり、原本になされた書換えを、間欠的に複製へ反映する方法であって、複製処理(反映処理)の時期を自動制御する方法であってもよい。
【0194】
これにより、上記データベースシステムは、複製処理(反映処理)の時期を、利用者の手動操作あるいは単純な一定時間間隔とせず、状況に応じて動的に制御することによって、情報の同一性と装置の負荷という相反する二つの要素のバランスを最適に維持できる。
【0195】
本発明に係るデータベースシステムの制御方法は、複数の情報蓄積装置の相互間で、内容の一部または全部を同一に保つ方法であり、一部の情報蓄積装置になされた書換えを、間欠的に他へ反映する方法であって、同期処理(反映処理)の時期を自動制御する方法であってもよい。
【0196】
これにより、上記データベースシステムは、同期処理(反映処理)の時期を、利用者の手動操作あるいは単純な一定時間間隔とせず、状況に応じて動的に制御することによって、情報の同一性と装置の負荷という相反する二つの要素のバランスを最適に維持できる。
【0197】
本発明に係るデータベースシステムの制御方法は、上記反映処理が間欠的であるために情報蓄積装置群の相互間に生ずる誤差の度合いを、計算もしくは推定によって求めるとともに、求めた誤差の過去一回以上の値を時期を制御する指標として用いる方法であってもよい。
【0198】
これにより、上記データベースシステムは、上記反映処理の時期を制御する指標として、反映処理が間欠的であるために情報蓄積手段群の相互間に生ずる誤差の度合いを用いることによって、情報の精度を適切に評価し、装置の負荷とのバランスを最適に維持できる。
【0199】
本発明に係るデータベースシステムの制御方法は、ある情報蓄積装置に蓄積された内容のうち、書換えがまだ他の情報蓄積装置へ反映されていないものの比率を、計算もしくは推定するとともに、情報蓄積装置群の相互間に生ずる誤差を表す指標として、上記の比率を用いる方法であってもよい。
【0200】
これにより、上記データベースシステムは、反映処理の時期を制御する指標として、未反映率を用いることによって、反映処理が間欠的であるために情報蓄積装置群の相互間に生ずる誤差の度合いを比較的低コストで適切に評価することができる。
【0201】
本発明に係るデータベースシステムの制御方法を記憶した記録媒体は、前記の制御方法を実行するプログラムを記憶していてもよい。これにより、前記の制御方法を、特定の一台の情報処理装置に内蔵した形態のみならず、特定の一台の情報処理装置から前記制御方法を実行するプログラムを切り離して独立した記録媒体の形態にすることによって、保存、運搬、配布、および流通させることが可能になる。
【0202】
すなわち、上記記録媒体は、反映処理の時期の自動制御について、前記の自動制御方法を実行するプログラムを記憶していてもよい。そして、上記データベースシステムは、上記記録媒体に記憶された前記の自動制御方法のプログラムを実行することによって、前記の自動制御方法を実現するものであってもよい。
【0203】
上記記録媒体によれば、前記自動制御の方法を、特定の一台の情報処理装置に内蔵した形態のみならず、特定の一台の情報処理装置から前記自動制御の方法を実行するプログラムを切り離して独立した記録媒体の形態にすることによって、保存、運搬、配布、販売等が可能になる。また、前記自動制御の方法を、反映方法の一部という形態のみならず、特定の反映方法から前記自動制御の方法を実行するプログラムを切り離して独立した記録媒体の形態での保存、運搬、配布、販売等が可能になる。また、特定の反映方法から前記自動制御の方法を行う装置を切り離した設計、製造等が可能になる。また、切り離すことによって、複数の反映方法と複数の自動制御の方法を任意に組み合わせることが可能になる。
【0204】
同様に、上記記録媒体は、反映処理が間欠的であるために情報蓄積装置群の相互間に生ずる誤差の度合いを、計算もしくは推定し、フィードバックする処理について、前記の誤差取扱いの方法を実行するプログラムを記憶していてもよい。そして、上記データベースシステムは、上記記録媒体に記憶された前記の誤差取扱い方法のプログラムを実行することによって、前記の誤差取扱い方法を実現するものであってもよい。なお、上記記録媒体による効果は、前記の自動制御の方法に準じ、自動制御の方法を誤差取扱いの方法と読みかえたものとなる。
【0205】
同様に、上記記録媒体は、ある情報蓄積装置に蓄積された内容のうち、書換えがまだ他の情報蓄積装置へ反映されていないものの比率を、計算もしくは推定し、フィードバックする処理について、前記の未反映率取扱いの方法を実行するプログラムを記憶していてもよい。そして、上記データベースシステムは、上記記録媒体に記憶された前記の未反映率取扱いの方法のプログラムを実行することによって、前記の未反映率取扱いの方法を実現するものであってもよい。なお、上記記録媒体による効果は、前記の自動制御の方法に準じ、自動制御の方法を未反映率取扱いの方法と読みかえたものとなる。
【0206】
最後に、上記の各実施の形態で説明したデータベースシステムは、複数の機器(例えば、ホストコンピュータ、端末コンピュータ、インタフェース機器、ネットワーク機器、プリンタなど)から構成されるシステムに適用しても、一つの機器からなる装置(例えば、携帯型コンピュータ、ワープロ装置など)に適用してもよい。
【0207】
また、本発明の目的は、上述した機能を実現するソフトウェアであるプログラムコード(実行形式プログラム、中間コードプログラム、ソースプログラム)をコンピュータで読み取り可能に記録した記録媒体を、システムあるいは装置に供給し、そのシステムあるいは装置のコンピュータ(またはCPUやMPU)が記録媒体に記録されているプログラムコードを読み出し実行することによっても、達成可能である。この場合、記録媒体から読み出されたプログラムコード自体が上述した機能を実現することになり、そのプログラムコードを記録した記録媒体は本発明を構成することになる。
【0208】
上記プログラムコードを供給するための記録媒体は、システムあるいは装置と分離可能に構成することができる。また、上記記録媒体は、プログラムコードを供給可能であるように固定的に担持する媒体であってもよい。そして、上記記録媒体は、記録したプログラムコードをコンピュータが直接読み取ることができるようにシステムあるいは装置に装着されるものであっても、外部記憶装置としてシステムあるいは装置に接続されたプログラム読み取り装置を介して読み取ることができるように装着されるものであってもよい。
【0209】
例えば、上記記録媒体としては、磁気テープやカセットテープ等のテープ系、フロッピーディスク/ハードディスク等の磁気ディスクやCD−ROM/MO/MD/DVD/CD−R等の光ディスクを含むディスク系、ICカード(メモリカードを含む)/光カード等のカード系、あるいはマスクROM/EPROM/EEPROM/フラッシュROM等の半導体メモリ系などを用いることができる。
【0210】
また、上記プログラムコードは、コンピュータが記録媒体から読み出して直接実行できるように記録されていてもよいし、記録媒体から主記憶のプログラム記憶領域へ転送された後コンピュータが主記憶から読み出して実行できるように記録されていてもよい。
【0211】
さらに、上記記録媒体は、通信ネットワーク等を介してプログラムコードを供給可能であるように流動的に担持する媒体であってもよい。この場合、システムあるいは装置を通信ネットワーク(インターネット等を含む)と接続可能に構成し、上記プログラムコードを通信ネットワークからダウンロードすることにより供給することができる。
【0212】
なお、プログラムコードを記録媒体から読み出して主記憶に格納するためのプログラム、および、通信ネットワークからプログラムコードをダウンロードするためのプログラムは、コンピュータによって実行可能にあらかじめシステムあるいは装置に格納されているものとする。
【0213】
上述した機能は、コンピュータが読み出した上記プログラムコードを実行することによって実現されるだけでなく、そのプログラムコードの指示に基づき、コンピュータ上で稼働しているOSなどが実際の処理の一部または全部を行うことによっても実現される。
【0214】
さらに、上述した機能は、上記記録媒体から読み出された上記プログラムコードが、コンピュータに装着された機能拡張ボードやコンピュータに接続された機能拡張ユニットに備わるメモリに書込まれた後、そのプログラムコードの指示に基づき、その機能拡張ボードや機能拡張ユニットに備わるCPUなどが実際の処理の一部または全部を行うことによっても実現される。
【0215】
【発明の効果】
本発明のデータベースシステムは、以上のように、第1の情報蓄積装置と、第2の情報蓄積装置と、第1の情報蓄積装置に対して行われた変更を、間欠的に第2の情報蓄積装置へ反映する反映手段と、第1の情報蓄積装置の内容と第2の情報蓄積装置の内容との誤差の程度に応じて、上記反映手段の起動を制御する反映制御手段とを備えている構成である。
【0216】
また、本発明のデータベースシステムの制御方法は、以上のように、第1の情報蓄積装置と第2の情報蓄積装置とを備えたデータベースシステムの制御方法であって、第1の情報蓄積装置に対して行われた変更を、間欠的に第2の情報蓄積装置へ反映する反映処理と、第1の情報蓄積装置の内容と第2の情報蓄積装置の内容との誤差の程度に応じて、上記反映処理の起動を制御する反映制御処理とを含んでいる方法である。
【0217】
また、本発明のコンピュータ読み取り可能な記録媒体は、以上のように、第1の情報蓄積装置と第2の情報蓄積装置とを備えたデータベースシステムを制御するための制御プログラムを記録したコンピュータ読み取り可能な記録媒体であって、第1の情報蓄積装置に対して行われた変更を、間欠的に第2の情報蓄積装置へ反映する反映処理と、第1の情報蓄積装置の内容と第2の情報蓄積装置の内容との誤差の程度に応じて、上記反映処理の起動を制御する反映制御処理とを、コンピュータに実行させるためのプログラムを記録している構成である。
【0218】
それゆえ、上記データベースシステムでは、反映制御処理によって、第1の情報蓄積装置の内容と第2の情報蓄積装置の内容との誤差の程度(未反映率)に応じて、反映処理の起動が制御される。
【0219】
よって、上記データベースシステムでは、未反映率を算出する負荷が、反映処理の負荷と比べて、ほとんど無視できる場合に、反映処理の起動を直接的かつ単純に自動制御することができる。
【0220】
したがって、複数の情報蓄積装置(データベース等)群の間で、一定の誤差を許容しつつ、内容を同一化するデータベースシステムにおいて、反映処理の時期を、利用者の手動操作あるいは単純な一定時間間隔とせず、状況に応じて動的に制御することによって、情報の同一性と装置の負荷という相反する二つの要素のバランスを最適に維持できるという効果を奏する。
【0221】
本発明のデータベースシステムは、以上のように、さらに、上記反映制御手段は、第1の情報蓄積装置の内容と第2の情報蓄積装置の内容との誤差の程度に基づいて、上記反映手段を間欠的に起動する反映間隔を設定する反映間隔設定手段を備えている構成である。
【0222】
また、本発明のデータベースシステムの制御方法は、以上のように、さらに、上記反映制御処理は、第1の情報蓄積装置の内容と第2の情報蓄積装置の内容との誤差の程度に基づいて、上記反映処理を間欠的に起動する反映間隔を設定する反映間隔設定処理を含んでいる方法である。
【0223】
また、本発明のコンピュータ読み取り可能な記録媒体は、以上のように、さらに、上記プログラムは、上記反映制御処理が、第1の情報蓄積装置の内容と第2の情報蓄積装置の内容との誤差の程度に基づいて、上記反映処理を間欠的に起動する反映間隔を設定する反映間隔設定処理を含んでいる構成である。
【0224】
それゆえ、さらに、上記データベースシステムでは、反映間隔設定処理によって、第1の情報蓄積装置の内容と第2の情報蓄積装置の内容との誤差の程度(未反映率)に応じて、反映間隔を設定して、反映間隔ごとに反映処理が起動するように制御することが可能になる。
【0225】
よって、上記データベースシステムでは、未反映率を算出する負荷が反映処理の負荷と比べて無視できない場合に、反映間隔を加減するという間接的な方法によって、反映時期を自動制御することができる。
【0226】
したがって、複数の情報蓄積装置(データベース等)群の間で、一定の誤差を許容しつつ、内容を同一化するデータベースシステムにおいて、反映処理の時期を、利用者の手動操作あるいは単純な一定時間間隔とせず、状況に応じて動的に制御することによって、過剰頻度による設備への過負荷や、過少頻度による情報精度の低下を防ぎながら、情報の同一性と装置の負荷という相反する二つの要素のバランスを最適に維持できるという効果を奏する。
【図面の簡単な説明】
【図1】 本発明の一実施の形態に係るデータベースシステムを適用した文書編集装置の機能の概略を示すデータフロー図である。
【図2】 図1に示した文書編集装置の反映間隔の調整プロセスの手順を示すフローチャートである。
【図3】 本発明の参考例に係るデータベースシステムを適用した電子電話帳システムの機能の概略を示すデータフロー図である。
【図4】 図3に示した電子電話帳システムの未反映率の比較プロセスの手順を示すフローチャートである。
【図5】 図3に示した電子電話帳システムの全体の構成の平常時の機能の概略を示すデータフロー図である。
【図6】 図3に示した電子電話帳システムの全体の構成の故障時または保守作業時の機能の概略を示すデータフロー図である。
【図7】 本発明の他の参考例に係るデータベースシステムを適用した電子電話帳システムの機能の概略を示すデータフロー図である。
【図8】 図7に示した電子電話帳システムの反映間隔の調整プロセスの手順を示すフローチャートである。
【図9】 図7に示した電子電話帳システムの全体の構成の機能の概略を示すデータフロー図である。
【図10】 本発明の一従来例に係る文書編集装置の機能の概略を示すデータフロー図である。
【図11】 本発明の他の従来例に係る仕入先データベースシステムの機能の概略を示すデータフロー図である。
【図12】 図11に示した仕入先データベースシステムの全体の構成の機能の概略を示すデータフロー図である。
【図13】 本発明のさらに他の従来例に係る電子電話帳システムの平常時の機能の概略を示すデータフロー図である。
【図14】 図13および図15に示した電子電話帳システムの全体の構成の故障時または保守作業時の機能の概略を示すデータフロー図である。
【図15】 本発明のさらに他の従来例に係る電子電話帳システムの平常時の機能の概略を示すデータフロー図である。
【符号の説明】
2 文書ファイル群(第1の情報蓄積装置)
2′ 本店DB(第1の情報蓄積装置)
12 インデックス(第2の情報蓄積装置)
12′ 支店DB(複製)(第2の情報蓄積装置)
12″ 支店DB(第2の情報蓄積装置)
21 インデックス化プロセス(反映手段、反映処理)
21′ 複製プロセス(反映手段、反映処理)
21″ 同期プロセス(反映手段、反映処理)
23 反映間隔
24 時間の比較プロセス(反映制御手段、反映制御処理)
25 反映間隔の調整プロセス(反映間隔設定手段、反映間隔設定処理)
28 未反映率の比較プロセス(反映制御手段、反映制御処理)
Claims (5)
- 複数のデータを蓄積する第1の情報蓄積装置と、
第1の情報蓄積装置に蓄積された上記データを検索するためのデータ検索用インデックスを蓄積する第2の情報蓄積装置と、
第1の情報蓄積装置に蓄積された上記データに対して行われたデータ変更を、予め定めた反映間隔で第2の情報蓄積装置へ反映させるように、上記データ検索用インデックスを作り直す反映手段と、
上記反映手段による反映処理の際に、第1の情報蓄積装置に蓄積された上記データに対して行われたデータ変更が第2の情報蓄積装置に蓄積された上記データ検索用インデックスに反映されていない誤差の程度を求めるとともに、上記反映手段を間欠的に起動する上記反映間隔を、上記誤差の程度が基準値と比較して大きければ短くするように設定する反映間隔設定手段とを備えていることを特徴とするデータベースシステム。 - 上記反映間隔設定手段は、第1の情報蓄積装置に蓄積された上記データに対して行われたデータ変更が第2の情報蓄積装置に蓄積された上記データ検索用インデックスに反映されていない未反映データの数から上記誤差の程度を求めることを特徴とする請求項1に記載のデータベースシステム。
- 複数のデータを蓄積する第1の情報蓄積装置と、第1の情報蓄積装置に蓄積された上記データを検索するためのデータ検索用インデックスを蓄積する第2の情報蓄積装置とを備えたデータベースシステムの制御方法であって、
上記データベースシステムが備える反映手段が、第1の情報蓄積装置に蓄積された上記データに対して行われたデータ変更を、予め定めた反映間隔で第2の情報蓄積装置へ反映させるように、上記データ検索用インデックスを作り直す反映処理と、
上記データベースシステムが備える反映間隔設定手段が、上記反映処理の際に、第1の情報蓄積装置に蓄積された上記データに対して行われたデータ変更が第2の情報蓄積装置に蓄積された上記データ検索用インデックスに反映されていない誤差の程度を求めるとともに、上記反映処理を間欠的に起動する上記反映間隔を上記誤差の程度が基準値と比較して大きければ短くするように、上記反映間隔を更新して記憶する反映間隔設定処理とを含んでいることを特徴とするデータベースシステムの制御方法。 - 上記反映間隔設定処理は、上記データベースシステムが備える反映間隔設定手段が、第1の情報蓄積装置に蓄積された上記データに対して行われたデータ変更が第2の情報蓄積装置に蓄積された上記データ検索用インデックスに反映されていない未反映データの数から上記誤差の程度を求めることを特徴とする請求項3に記載のデータベースシステムの制御方法。
- 請求項1または2に記載のデータベースシステムを制御するための制御プログラムを記録したコンピュータ読み取り可能な記録媒体であって、コンピュータを上記の各手段として機能させるためのプログラムを記録したコンピュータ読み取り可能な記録媒体。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
JP18627999A JP3751476B2 (ja) | 1999-06-30 | 1999-06-30 | データベースシステム、およびその制御方法、ならびにその制御プログラムを記録したコンピュータ読み取り可能な記録媒体 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
JP18627999A JP3751476B2 (ja) | 1999-06-30 | 1999-06-30 | データベースシステム、およびその制御方法、ならびにその制御プログラムを記録したコンピュータ読み取り可能な記録媒体 |
Publications (2)
Publication Number | Publication Date |
---|---|
JP2001014336A JP2001014336A (ja) | 2001-01-19 |
JP3751476B2 true JP3751476B2 (ja) | 2006-03-01 |
Family
ID=16185531
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
JP18627999A Expired - Fee Related JP3751476B2 (ja) | 1999-06-30 | 1999-06-30 | データベースシステム、およびその制御方法、ならびにその制御プログラムを記録したコンピュータ読み取り可能な記録媒体 |
Country Status (1)
Country | Link |
---|---|
JP (1) | JP3751476B2 (ja) |
Families Citing this family (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JP3860098B2 (ja) * | 2002-08-30 | 2006-12-20 | 株式会社東芝 | 情報端末装置 |
JP4787560B2 (ja) * | 2005-07-27 | 2011-10-05 | 日本電気株式会社 | ファイルローテーションシステムおよびそのローテーション方法ならびにプログラム |
JP4992242B2 (ja) * | 2006-01-30 | 2012-08-08 | 株式会社セガ | ゲームシステム及びゲームシステム制御方法 |
JP5049618B2 (ja) * | 2007-03-15 | 2012-10-17 | 株式会社日立製作所 | ディザスタリカバリシステムおよび方法 |
Family Cites Families (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JPH07141241A (ja) * | 1993-11-17 | 1995-06-02 | Hitachi Ltd | 分散データベースシステム管理装置 |
US5918013A (en) * | 1996-06-03 | 1999-06-29 | Webtv Networks, Inc. | Method of transcoding documents in a network environment using a proxy server |
JPH1011344A (ja) * | 1996-06-24 | 1998-01-16 | Mitsubishi Electric Corp | データ・バックアップ方法 |
-
1999
- 1999-06-30 JP JP18627999A patent/JP3751476B2/ja not_active Expired - Fee Related
Also Published As
Publication number | Publication date |
---|---|
JP2001014336A (ja) | 2001-01-19 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US11245758B2 (en) | System and method for automatic cloud-based full-data restore to mobile devices | |
US6360330B1 (en) | System and method for backing up data stored in multiple mirrors on a mass storage subsystem under control of a backup server | |
US20080256137A1 (en) | Method and system for data processing with data replication for the same | |
US7904425B2 (en) | Generating backup sets to a specific point in time | |
US5842222A (en) | Production information system enhanced for availability | |
US8578203B2 (en) | Providing a backup service from a remote backup data center to a computer through a network | |
US8527464B2 (en) | Self-contained partial database backups | |
JP3050510B2 (ja) | イメージデータ管理装置 | |
JP2007500890A (ja) | モバイル装置のユーザ設定を保存するための方法、システム、およびコンピュータ・プログラム | |
US10191906B1 (en) | Creation and implementation of designated time points in a version expiration environment | |
JP3751476B2 (ja) | データベースシステム、およびその制御方法、ならびにその制御プログラムを記録したコンピュータ読み取り可能な記録媒体 | |
JP2004139217A (ja) | データベースの移行方法 | |
US7194486B2 (en) | Method and system for data processing with data replication for the same | |
JP4907059B2 (ja) | コンピュータシステムおよびそのデータの自動バックアップ方法 | |
JP4998010B2 (ja) | データベースシステム管理、データベースシステム、プログラム及び処理装置 | |
US7120822B2 (en) | Computer executable digital video rendering restoration method | |
JP3859445B2 (ja) | ファイルバックアップシステム及び記録媒体 | |
EP4172776A1 (en) | Device and method for merging backup policies | |
JP2002116938A (ja) | 世代管理機能を備えたファイルバックアップ方法 | |
JP2004318810A (ja) | データ管理方法およびシステム | |
JP2004295363A (ja) | バックアップ方法 | |
JPH04250539A (ja) | ジャーナル取得方式 | |
JP3309198B2 (ja) | データベース多重化方法 | |
JPH04342041A (ja) | コンピュ−タシステムのバックアップ保守方法 | |
JP2004021914A (ja) | コンピュータシステム及びバックアップ取得方法 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
A131 | Notification of reasons for refusal |
Free format text: JAPANESE INTERMEDIATE CODE: A131 Effective date: 20041012 |
|
A521 | Written amendment |
Free format text: JAPANESE INTERMEDIATE CODE: A523 Effective date: 20041209 |
|
A131 | Notification of reasons for refusal |
Free format text: JAPANESE INTERMEDIATE CODE: A131 Effective date: 20050301 |
|
A521 | Written amendment |
Free format text: JAPANESE INTERMEDIATE CODE: A523 Effective date: 20050422 |
|
RD02 | Notification of acceptance of power of attorney |
Free format text: JAPANESE INTERMEDIATE CODE: A7422 Effective date: 20050422 |
|
A131 | Notification of reasons for refusal |
Free format text: JAPANESE INTERMEDIATE CODE: A131 Effective date: 20050816 |
|
A521 | Written amendment |
Free format text: JAPANESE INTERMEDIATE CODE: A523 Effective date: 20051013 |
|
TRDD | Decision of grant or rejection written | ||
A01 | Written decision to grant a patent or to grant a registration (utility model) |
Free format text: JAPANESE INTERMEDIATE CODE: A01 Effective date: 20051206 |
|
A61 | First payment of annual fees (during grant procedure) |
Free format text: JAPANESE INTERMEDIATE CODE: A61 Effective date: 20051207 |
|
R150 | Certificate of patent or registration of utility model |
Free format text: JAPANESE INTERMEDIATE CODE: R150 |
|
FPAY | Renewal fee payment (event date is renewal date of database) |
Free format text: PAYMENT UNTIL: 20091216 Year of fee payment: 4 |
|
FPAY | Renewal fee payment (event date is renewal date of database) |
Free format text: PAYMENT UNTIL: 20091216 Year of fee payment: 4 |
|
FPAY | Renewal fee payment (event date is renewal date of database) |
Free format text: PAYMENT UNTIL: 20101216 Year of fee payment: 5 |
|
FPAY | Renewal fee payment (event date is renewal date of database) |
Free format text: PAYMENT UNTIL: 20101216 Year of fee payment: 5 |
|
FPAY | Renewal fee payment (event date is renewal date of database) |
Free format text: PAYMENT UNTIL: 20111216 Year of fee payment: 6 |
|
LAPS | Cancellation because of no payment of annual fees |