現在、趣味でデータベース開発をしており
ACCESS単体で作成する場合は連結←非連結での作り方が分からない為(苦笑)
VB+ACCESSで作成する場合は非連結
という方法で作成しています。
一般的な業界のデータベースの開発現場では、非連結によりデータベース作成が基本なのでしょうか??
開発に取り掛かるに当たって、連結or非連結はどの様な観点で選ばれるのでしょうか?
また、初心者の理解として、
連結→直テーブル更新される
非連結→画面上のデータを『登録』等のボタン押下後に登録と認識しておりますが、
この点につきましても間違いがございましたら、ご教授下さいませ。
No.1ベストアンサー
- 回答日時:
基本的にはデータベースは連結・非連結ではなくデータの重複をなくすことによってデータの管理を容易にしたりデータを多様な目的に用いるのに有効な方法でデータベースの構築の基本になる正規化を基に作成します。
これがデータベースの開発の基になります。
連結・非連結はコントロールのあり方でデータベースのテーブル自体はキーによって各テーブルは結合されて構成されます。
連結・非連結とのことなのでフォーム等のコントロールのことでの質問と理解して・・。
テーブルのレコードに対してそのコントロールがテーブルのフィールドに連結されているかいないかでデータを操作する際の対応が変わります。(連結→直テーブル更新される非連結→画面上のデータを『登録』等のボタン押下後に登録 のように)
例えばフォームでレコードを追加・修正・削除等の処理をする際に適切な方法で行うのが良いのでそこで連結にするか非連結にした方が良いのかが変わると思います。
連結にしてレコード単位でフォームに読み込み時にレコードロックを行えば他者が修正・削除は出来ないのでレコードのデータを修正・変更する際に有効。
極端な例ですが非連結でフォーム上にレコードを表示し修正し更新しようとしたら他者がそのレコードに更新かける前に削除しまっていた。という事が起こりかねない。それを防御する為に連結コントロールでレコードをロックさせていれば他者か削除してしまうことがない。 など
小規模のクライアントでのデータベース開発ならこの辺を考慮して決めれば良いのではないでしょうか。
大規模だともっと厳密になりますが。
連結→直テーブル更新される
Accessでは連結ではUpdate(新規ならInsert)するかレコードを移動した時に更新されます。
非連結→画面上のデータを『登録』等のボタン押下後に登録
(ボタン等のイベントで)Update(新規はInsert)しないと更新されない。
で良いと思います。
No.2
- 回答日時:
>ACCESS単体で作成する場合は連結---(A)
>VB+ACCESSで作成する場合は非連結---(B)
では正確な表現ではないと思いますが、大体そんなものです。
正確な表現ではどうなるかを私が理解できる範囲で回答させていただきます。
■データベースとインターフェースの接続が
保持している間にデータの更新を行う=連結
切れている間にデータの更新を行う=非連結
ですので実装によってはVB+ACCESSでも連結は可能です。
結果として
>連結→直テーブル更新される
>非連結→画面上のデータを『登録』等のボタン押下後に登録
に見えることが多いとなります。
しかしそれはそのように見えるだけで更新時のみDBへ自動的に接続していれば非連結であるが直テーブルが更新されているように見える状況があります。
>一般的な業界のデータベースの開発現場では、非連結によりデータベース作成が基本なのでしょうか??
「一般的な」では残念ながら開発規模もわからず状況を全く伝えられていません。
ただ業界のデータベースの内もっともシェアがあるのはリレーショナルDBである事とAccessをあげていることから非連結が主流であることは確かです。
では連結データベースがメインになる現場は何になるかと申しますとワークグループ(会社でたとえるとスタンドアローンから部署単位まで)の開発がそれに当たります。
趣味でのデータベース開発がWindowsアプリであれば連結系がまだまだ使われていると思いますが、Web系であれば非連結でないと実装できなくなります。
以上、初心者の理解から一歩構造を理解しようとすると、こんな感じになります。
少し説明が長くなってしまったので、さらにそれぞれの利点について回答させてください。#1の方とかぶってしまいますけど
No.3
- 回答日時:
#2の続きです
■非連結であることの最大利点
多人数の同時データ更新が可能
■連結であることの最大利点
開発効率が良いこと
でしょう。
>連結or非連結はどの様な観点で選ばれるのでしょうか?
もしデータベースの利用目的をきちんと設計できているなら、開発する上でどちらを選択すればよいかを判断することが容易になります。
一人しかそのデータベースを利用しないのに非連結でのデットロックを回避するようなコードを実装した重厚なアプリケーションを作ることは、全くの無意味です。それより市販のファイルメーカーなどで作成したほうが開発時間は10分の1で済むはずです。
逆に多人数での使用が目的なのに連結で実装すると、誰かが更新を完了させるまで他の人が作業を進めることが出来ない。となるでしょう。
では良き趣味ライフを!
分かり易いご回答ありがとうございます。
私は、データベースはファイルメーカーから入りました。
ACCESSにおいても、ファイルメーカーにしても連結ですと、何か誤ってキーに触れて、
そのフィールドのデータが消えてしまうと、一度であればctrl+zで何とか戻せますが・・・・
最悪、自分が知らない間にデータが変わる可能性が怖いなぁと思い、業務では非連結と思い込みがありました。
実はこの点が一番ネックな部分でした。
しかし使う規模とユーザーの要求によっては、非連結でも全然OKで、ましてやファイルメーカでもOKなんですね。
瞬間にデータが書き換わってしまう注意点等はユーザーにきちんと伝えて・・・
O_cyan様がおっしゃった極端な例の、非連結で更新しようとしている時に他の人が削除・・・
という事も確かに非連結ですと考えられますね。奥が深いです。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Access(アクセス) Accessテーブルの結合で別々のテーブルのフィールドを組み合わせて値を出す方法について 2 2022/07/20 19:43
- MySQL 「utf8mb4_general_ci」はMAMPでは何に当たりますか? 1 2022/06/02 07:45
- ソフトウェア データベースのウェブでの自作 2 2023/08/01 10:06
- PHP htmlspecialcharsが機能していないです。 バグですか? 1 2022/04/05 01:22
- CAD・DTP JWW-CADでDXF変換後の線が連動して消える 2 2023/01/13 11:09
- X(旧Twitter) Twitterの連鎖凍結について 2 2023/01/25 03:16
- その他(データベース) pythonでsqlight勉強中、クエリー結果の利用法教えて下さい 1 2022/04/28 20:38
- Excel(エクセル) EXCELの外部データ取得ができない 1 2023/03/23 09:03
- MySQL PHPとMySQLを使った掲示板の作り方 1 2022/06/02 13:00
- Access(アクセス) Access 登録ボタンからサブフォームの更新 1 2022/07/22 10:23
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
型 varchar から型 numeric へ...
-
コンピュータ用語、データベー...
-
データベースソフトのTCARDにつ...
-
リスト形式の表とデータベース...
-
ODBCを使わないでExcelへ連携
-
SQL Server 縦方向のデータを列...
-
SQLを使いこなしている人が ETL...
-
オラクルのLONG RAW型のテーブ...
-
ACCESSで条件付き書式の設定方法
-
OpenOfficeのBaseでExcelのデー...
-
Access or SQLServer どちらを...
-
カンマ区切りで格納するカラム...
-
Accessで連番の付け方
-
オラクルなどのデータベースの...
-
オラクルを使っての仕事内容
-
【ACCESS】複数のパソコンから...
-
エクセルの重複データの曖昧検索
-
エクセルの裏でACCESSを動かす...
-
【パフォーマンス】ファイル読...
-
EXCEL2000のVBAで*.dbf形式デー...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
型 varchar から型 numeric へ...
-
リスト形式の表とデータベース...
-
エクセルの重複データの曖昧検索
-
エクセルのフォームについて(...
-
ACCESSで条件付き書式の設定方法
-
ハイフン無しの電話番号データ...
-
カンマ区切りで格納するカラム...
-
OpenOfficeのBaseでExcelのデー...
-
オラクルのLONG RAW型のテーブ...
-
ODBCを使わないでExcelへ連携
-
データのインポートに失敗します。
-
【パフォーマンス】ファイル読...
-
データベースソフトのTCARDにつ...
-
Accessで入力したデータ...
-
SQLを使いこなしている人が ETL...
-
SQL Server 縦方向のデータを列...
-
【ACCESS】複数のパソコンから...
-
アクセスがエクセルより優れて...
-
DBとテキストファイルの比較
-
CSVでDLしたデータにダブルクォ...
おすすめ情報