JP5190241B2 - 情報処理装置、情報処理方法及びプログラム - Google Patents
情報処理装置、情報処理方法及びプログラム Download PDFInfo
- Publication number
- JP5190241B2 JP5190241B2 JP2007255529A JP2007255529A JP5190241B2 JP 5190241 B2 JP5190241 B2 JP 5190241B2 JP 2007255529 A JP2007255529 A JP 2007255529A JP 2007255529 A JP2007255529 A JP 2007255529A JP 5190241 B2 JP5190241 B2 JP 5190241B2
- Authority
- JP
- Japan
- Prior art keywords
- information
- source code
- program
- definition file
- access
- 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.)
- Active
Links
- 230000010365 information processing Effects 0.000 title claims description 30
- 238000003672 processing method Methods 0.000 title claims description 5
- 238000013507 mapping Methods 0.000 claims description 22
- 238000012795 verification Methods 0.000 claims description 7
- 238000012360 testing method Methods 0.000 claims description 4
- 238000000034 method Methods 0.000 description 37
- 238000010586 diagram Methods 0.000 description 17
- 230000008569 process Effects 0.000 description 16
- 238000012545 processing Methods 0.000 description 12
- 230000006870 function Effects 0.000 description 8
- 230000033772 system development Effects 0.000 description 8
- 238000011161 development Methods 0.000 description 7
- 230000018109 developmental process Effects 0.000 description 7
- 230000008859 change Effects 0.000 description 6
- 208000037805 labour Diseases 0.000 description 6
- 238000013461 design Methods 0.000 description 3
- 230000004044 response Effects 0.000 description 3
- 238000005516 engineering process Methods 0.000 description 2
- 238000012937 correction Methods 0.000 description 1
- 230000003111 delayed effect Effects 0.000 description 1
- 230000006872 improvement Effects 0.000 description 1
- 238000012986 modification Methods 0.000 description 1
- 230000004048 modification Effects 0.000 description 1
Images
Landscapes
- Information Retrieval, Db Structures And Fs Structures Therefor (AREA)
Description
また、システム開発者が前記単純な仕様のDBアクセスプログラムのソースコードを改変して複雑な操作を行うDBアクセスプログラムに修正することは不可能ではないが、開発に携わる不特定多数の開発者が、DBアクセスプログラムのソースコードに手を加えることは、ソースコードの品質を落とすことに繋がる場合が多かった。
同様に、DBアクセスプログラムの実行により得られたテーブルのレコードを格納するレコード格納プログラムの型マッピングが静的に決まっていない場合、実行時にマッピングを行う必要があり、型マッピングの失敗が発生する可能性があった。
また、システム開発過程や運用過程において、DB設計に変更が発生することは多く、その変更がソースコードに反映されていなくても、それを気付かせる技術がなかった。
図1は、情報処理装置(コンピュータ)のハードウェア構成の一例を示す図である。図1に示されるように、情報処理装置1は、ハードウェア構成として、入力装置11と、表示装置12と、記録媒体ドライブ装置13と、ROM(Read Only Memory)15と、RAM(Random Access Memory)16と、CPU(Central Processing Unit)17と、インターフェース装置18と、HD(Hard Disk)19と、を含む。
DBアクセサ定義出力部21は、図4に示す情報入力画面を介して入力された、DB操作情報31と、DBアクセスプログラムジェネレート情報32と、に基づいて、図5に示すようなDBアクセサ定義ファイル33を生成する。ここで、DB操作情報31とは、DB23のテーブル名や、SQL文に関する情報である。また、DBアクセスプログラムジェネレート情報32とは、データベースのテーブルに対する操作に係るDBアクセスプログラムに関する情報であって、より具体的には、このプログラム(本実施形態の例では、DBアクセスプログラム36、レコード格納プログラム37)の名称、コメント、メソッド名、である。なお、図4に示す情報入力画面は、DBアクセサ定義出力部21が、表示装置12に表示させ、入力された情報の取得やその表示制御等を行う。
ソースコード生成部22は、DBアクセサ定義ファイル33(より具体的にはDBアクセサ定義ファイル33に含まれるDB操作情報と、DBアクセスプログラムジェネレート情報と、)に基づいて、DBアクセスプログラム36、レコード格納プログラム37内で発行予定(つまり、DBアクセスプログラム36のソースコード、レコード格納プログラム37のソースコードに含まれる予定)の図7に示されるような発行予定SQL文38をメソッド単位で組み立てる。
シーケンスSQ1において、ソースコード生成部22は、DBアクセサ定義ファイル33に基づいて、DB23へ、前記発行予定のSQL文をDB23へ発行し、その発行結果であるテーブルの各カラムのデータの型を問い合わせる。例えば、ソースコード生成部22は、DBアクセサ定義ファイル33に基づいて、図7に記載された発行予定SQL文をDB23へ発行し、EMPテーブルのEMPNOのデータの型についての問い合わせをDB23に対して行う。
シーケンスSQ11において、ソースコード生成部22は、型マッピング情報34よりテストデータ(例えば、0)を取得する。
続いて、シーケンスSQ12において、ソースコード生成部22は、取得したテストデータを用いて、発行予定SQL文38をDB23に対して発行する。
ソースコード生成部22が、発行予定SQL文38の動作検証をDBアクセスプログラム36、レコード格納プログラム37の作成前に行っておくことによって、これらのプログラムの質を高めることができる。
ソースコード生成部22は、発行予定SQL文38の動作検証の結果、発行予定SQL文38が正常に動作すると判断した場合、発行予定SQL文38と、前記決定した型と、図12及び図13に示されるコードテンプレート351と、コードテンプレート352と、に基づいて、図14に示されるようなDBアクセスプログラム36、図15に示されるようなレコード格納プログラム37のソースコードを生成する。ここで、コードテンプレート35は、テーブルの操作に係るプログラムのソースコードのテンプレートである。
上述した実施形態では、DB23のテーブルに紐付けて、DBにアクセスするプログラムを生成する例を示した。しかしながら、本実施形態では、例えばレコード格納プログラム(レコード格納クラス)に格納できる対象が必ずDB23に存在するテーブルのカラムと対応付かなくてもよい例を示す。つまり、本実施形態によれば、関数や演算の結果の様なものもレコード格納クラスの一属性として扱うことができるようになる。
なお、以下では、上述した実施形態とは異なる点を主に説明する。
シーケンスSQ21において、ソースコード生成部22は、発行予定SQL文38に含まれるSQL文を、DB23に対して発行する。より具体的に説明すると、ソースコード生成部22は、発行予定SQL文38に含まれるSQL文
「
SELECT ENAME,
EMPNO+100 AS EMPNO_NEW
FROM EMP
」
等をDB23に対して発行する。
11 入力装置
12 表示装置
13 記録媒体ドライブ装置
14 記録媒体
15 ROM
16 RAM
17 CPU
18 インターフェース装置
19 HD
Claims (6)
- 情報入力画面を介して入力された、データベースのテーブルの操作に係る操作情報と、データベースのテーブルに対する操作に係るDBアクセスプログラムの関連情報と、に基づいて、アクセス定義ファイルを出力するアクセス定義ファイル出力手段と、
前記アクセス定義ファイルに基づいて、発行予定のSQL文を組み立てるソースコード生成手段と、
を有し、
前記ソースコード生成手段は、前記アクセス定義ファイルに基づいて、前記テーブルの各カラムのデータの型を前記データベースに問い合わせ、問い合わせの結果得られた前記型に基づいて、型マッピング情報を参照し、前記プログラムのソースコードで使用する型を決定することを特徴とする情報処理装置。 - 前記アクセス定義ファイル出力手段は、前記操作情報と、前記DBアクセスプログラムの関連情報と、を読み込み、読み込んだ、前記操作情報と、前記DBアクセスプログラムの関連情報と、をタグで収納した記載に変換したアクセス定義ファイルを出力し、
前記ソースコード生成手段は、前記アクセス定義ファイルを読み込み、前記タグが示す属性情報に基づいて、前記発行予定のSQL文を組み立てることを特徴とする請求項1に記載の情報処理装置。 - 前記ソースコード生成手段は、前記型マッピング情報から取得したテストデータを用いて、前記発行予定のSQL文を、前記データベースに対して発行し、前記発行予定のSQL文に係る動作検証を行うことを特徴とする請求項1又は2に記載の情報処理装置。
- 前記ソースコード生成手段は、前記動作検証の結果、正常に動作すると判断した場合、前記発行予定のSQL文と、前記決定した型と、前記プログラムのソースコードのテンプレートと、に基づいて、前記プログラムのソースコードを生成することを特徴とする請求項3に記載の情報処理装置。
- 情報処理装置における情報処理方法であって、
情報入力画面を介して入力された、データベースのテーブルの操作に係る操作情報と、データベースのテーブルに対する操作に係るDBアクセスプログラムの関連情報と、に基づいて、アクセス定義ファイルを出力するアクセス定義ファイル出力ステップと、
前記アクセス定義ファイルに基づいて、発行予定のSQL文を組み立てるソースコード生成ステップと、
を含み、
前記ソースコード生成ステップでは、前記アクセス定義ファイルに基づいて、前記テーブルの各カラムのデータの型を前記データベースに問い合わせ、問い合わせの結果得られた前記型に基づいて、型マッピング情報を参照し、前記プログラムのソースコードで使用する型を決定することを特徴とする情報処理方法。 - コンピュータを、
情報入力画面を介して入力された、データベースのテーブルの操作に係る操作情報と、データベースのテーブルに対するアクセスに係るプログラムの関連情報と、に基づいて、アクセス定義ファイルを出力するアクセス定義ファイル出力手段と、
前記アクセス定義ファイルに基づいて、発行予定のSQL文を組み立てるソースコード生成手段と、
して機能させるためのプログラムであって、
前記ソースコード生成手段は、前記アクセス定義ファイルに基づいて、前記テーブルの各カラムのデータの型を前記データベースに問い合わせ、問い合わせの結果得られた前記型に基づいて、型マッピング情報を参照し、前記プログラムのソースコードで使用する型を決定することを特徴とするプログラム。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
JP2007255529A JP5190241B2 (ja) | 2007-09-28 | 2007-09-28 | 情報処理装置、情報処理方法及びプログラム |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
JP2007255529A JP5190241B2 (ja) | 2007-09-28 | 2007-09-28 | 情報処理装置、情報処理方法及びプログラム |
Publications (2)
Publication Number | Publication Date |
---|---|
JP2009086992A JP2009086992A (ja) | 2009-04-23 |
JP5190241B2 true JP5190241B2 (ja) | 2013-04-24 |
Family
ID=40660340
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
JP2007255529A Active JP5190241B2 (ja) | 2007-09-28 | 2007-09-28 | 情報処理装置、情報処理方法及びプログラム |
Country Status (1)
Country | Link |
---|---|
JP (1) | JP5190241B2 (ja) |
Family Cites Families (7)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JPH01232428A (ja) * | 1988-03-14 | 1989-09-18 | Oki Electric Ind Co Ltd | データベース問い合わせ処理装置 |
JPH08263277A (ja) * | 1995-03-22 | 1996-10-11 | Fujitsu Ltd | データ操作プログラムの自動生成装置 |
JPH11232090A (ja) * | 1998-02-16 | 1999-08-27 | Mitsubishi Electric Corp | データベースシステムの自動生成システム |
JP2001256076A (ja) * | 2000-03-08 | 2001-09-21 | Ricoh Co Ltd | テストデータ生成装置、テストデータ生成方法及び記録媒体 |
JP2003006217A (ja) * | 2001-06-26 | 2003-01-10 | Technical Syndicate Co Ltd | データベース構築支援プログラム及びデータベースを利用したWebアプリケーション構築プログラム |
JP2006209655A (ja) * | 2005-01-31 | 2006-08-10 | Niit Technologies Kk | システム開発支援方法及びシステム開発支援プログラム |
JP4939007B2 (ja) * | 2005-08-01 | 2012-05-23 | ケン・システムコンサルティング株式会社 | システム設計支援プログラム |
-
2007
- 2007-09-28 JP JP2007255529A patent/JP5190241B2/ja active Active
Also Published As
Publication number | Publication date |
---|---|
JP2009086992A (ja) | 2009-04-23 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US10162611B2 (en) | Method and apparatus for business rule extraction | |
US8739116B2 (en) | Development environment configured to generate application source code from database objects | |
US20170228426A1 (en) | Managing data queries | |
CN101727320B (zh) | 用于识别数据库更改对应用的影响的方法和系统 | |
US20160170719A1 (en) | Software database system and process of building and operating the same | |
KR101213798B1 (ko) | 복합 데이터 액세스 | |
KR102330547B1 (ko) | 보고 생성 방법 | |
CN108762743B (zh) | 一种数据表操作代码生成方法及装置 | |
US7792851B2 (en) | Mechanism for defining queries in terms of data objects | |
JP2002508561A (ja) | 自動コンフィギュレーション発生 | |
IL143823A (en) | Method and facility to execute code of PL / SQL objects stored in a database | |
US20120266131A1 (en) | Automatic program generation device, method, and computer program | |
US11611627B2 (en) | Action flow fragment management | |
EP3314409B1 (en) | Tracing dependencies between development artifacts in a software development project | |
Mueller | Microsoft ADO. NET Entity Framework Step by Step | |
EP1909170B1 (en) | Method and system for automatically generating a communication interface | |
Jovanovic et al. | Aggregate data modeling style | |
JP5190241B2 (ja) | 情報処理装置、情報処理方法及びプログラム | |
US20080022258A1 (en) | Custom database system and method of building and operating the same | |
US8631393B2 (en) | Custom database system and method of building and operating the same | |
US11805181B2 (en) | Migration of software extensions | |
US20230128661A1 (en) | Information retrieval framework | |
Tummala | Data warehouse modeler (A CASE Tool): redesign and implementation of framework | |
JP2009217635A (ja) | 検索条件作成方法、検索条件作成装置及びプログラム | |
Concepcion | VirHoLex 2.0 (Virus-Host Interaction Lexicon) |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
A621 | Written request for application examination |
Free format text: JAPANESE INTERMEDIATE CODE: A621 Effective date: 20100922 |
|
A977 | Report on retrieval |
Free format text: JAPANESE INTERMEDIATE CODE: A971007 Effective date: 20120914 |
|
A131 | Notification of reasons for refusal |
Free format text: JAPANESE INTERMEDIATE CODE: A131 Effective date: 20121016 |
|
A521 | Request for written amendment filed |
Free format text: JAPANESE INTERMEDIATE CODE: A523 Effective date: 20121217 |
|
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: 20130115 |
|
A61 | First payment of annual fees (during grant procedure) |
Free format text: JAPANESE INTERMEDIATE CODE: A61 Effective date: 20130128 |
|
FPAY | Renewal fee payment (event date is renewal date of database) |
Free format text: PAYMENT UNTIL: 20160201 Year of fee payment: 3 |
|
R150 | Certificate of patent or registration of utility model |
Ref document number: 5190241 Country of ref document: JP Free format text: JAPANESE INTERMEDIATE CODE: R150 |
|
R250 | Receipt of annual fees |
Free format text: JAPANESE INTERMEDIATE CODE: R250 |
|
R250 | Receipt of annual fees |
Free format text: JAPANESE INTERMEDIATE CODE: R250 |
|
R250 | Receipt of annual fees |
Free format text: JAPANESE INTERMEDIATE CODE: R250 |
|
R250 | Receipt of annual fees |
Free format text: JAPANESE INTERMEDIATE CODE: R250 |
|
R250 | Receipt of annual fees |
Free format text: JAPANESE INTERMEDIATE CODE: R250 |
|
R250 | Receipt of annual fees |
Free format text: JAPANESE INTERMEDIATE CODE: R250 |
|
R250 | Receipt of annual fees |
Free format text: JAPANESE INTERMEDIATE CODE: R250 |
|
R250 | Receipt of annual fees |
Free format text: JAPANESE INTERMEDIATE CODE: R250 |
|
R250 | Receipt of annual fees |
Free format text: JAPANESE INTERMEDIATE CODE: R250 |