2つのクエリーで抽出したレコードを結合し、そのレコードにID番号をつけて別のテーブルに追加することはできないでしょうか?
1枚のガラスの値段表を作りたいと考えています。
使用するテーブルは、1つ目がサイズ表でサイズ番号と2つの辺の長さの3つのフィールドからできています。2つ目はガラスの種類表で種類番号と種類名の2つのフィールドでできています。3つ目は値段表で上の2つの表の5つのフィールドにID番号と値段の2つのフィールドがあり全部で7つのフィールドです。
いま、フォームにサイズ表と種類表のサブフォームをつくり、それぞれ結合したいレコードを表示させています。そこからフォームに値段を入力し登録ボタンをクリックすると値段表に新しいレコードを追加するような登録ボタンを作りたいです。
簡単な例でも構いません。
VBAがわかる方、教えてください。
No.1ベストアンサー
- 回答日時:
ウーン!チクッと無駄で複雑な仕組みを作り上げようとしています。
例えば、
<Table1>
ID Data1
1 A
2 B
<table2>
ID Table1_ID Table3_ID Data1
1 1 1 XX
2 1 1 YY
<Table3>
ID Price
1 \1,000
2 \2,000
という設計であれば、ノープログラミングで目的を達成できます。
<クエリ1>
ID Table1.Data1 Table2.Data1 Price
1 A XX \1,000
2 A YY \1,000
SELECT Table2.ID, Table1.Data1, Table2.Data1, Table3.Price
FROM Table1 RIGHT JOIN (Table2 LEFT JOIN Table3 ON Table2.Table3_ID = Table3.ID)
ON Table1.ID = Table2.Table1_ID;
正に、この<クエリ1>が「1枚のガラスの値段表」です。
****************************************************************
なお、質問に即答すれば、
Private Sub コマンド0_Click()
Dim strInsertSQL As String
strInsertSQL = "INSERT INTO Table3 (ID,Price) Values (3,3000)"
CnnExecute(strInsertSQL)
End Sub
と、SQLのINSERT文を作成し実行すれば可能です。
CnnExecute()については、要求があれば示します。
大変ありがとうございました。
回答を読んでコードの全体像がとてもシンプルになりました。
SQL文の結合は情報処理の勉強で、SELECT・・・From・・・Where A = B AND ・・・のようなものしかやりませんでしたが、これも勉強になりました。
CnnExecute()は某Webサイトで調べました。オートナンバーは自動的にふってくれるし、あとは何とかできそうです。
No.2
- 回答日時:
> 3つ目は値段表で上の2つの表の5つのフィールドにID番号と値段の2つのフィールドがあり全部で7つのフィールドです。
この値段表テーブルの作り方がマズイです。
Accessに限らずリレーショナルデータベースでは、他のテーブルにあるデータを重複して持つことを極力避けます。
ご質問の例の値段表テーブルは、
1.商品ID(型番など、商品を一意に特定できる番号)
2.価格
3.サイズID(サイズ表テーブルのサイズ番号)
4.種類ID(種類表テーブルの種類番号)
この4フィールドにすべきです。
値段表テーブルに他のテーブルのデータを書き込むテーブル構成にしてしまうと、種類やサイズに変更があったとき、種類テーブルやサイズテーブルだけでなく、値段表テーブル上にあるデータも訂正しなければならなくなります。
他のテーブルのデータを参照したいときは、これら別テーブルのIDでリンクさせたクエリーを使うのがセオリーです。
従って、ご質問のフォームでは、ザブフォームからは2つのサブフォームからそれぞれのIDだけを取り出し、値段表テーブルに追加すれば良いのです。
ただ、サブフォーム方式を採用することが良いかどうかは別の話です。
サイズテーブルや種類テーブルのレコード数が多い場合、絞り込みを行える様にするなど、エンドユーザーの負担を軽減させる工夫も必要です
ありがとうございました。
4つの主キーにしぼる話はNo1さんの回答を理解する助けにもなりました。番号の組合せと値段だけでは何のガラスかわからなくなってしまわないか不安はありましたが、必要に応じてリレーションシップからクエリなどで参照すればいいですよね。
値段表はフィールドを2つにするか4つするかまだ決めてませんが、フォームは新規のガラスを登録するときに既存のサイズと種類があるか確認しやすいものをつくりたいと考えています。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Access(アクセス) アクセスの更新クエリでカレントレコードのみ更新したい 1 2022/06/02 23:32
- Access(アクセス) Accessテーブルの結合で別々のテーブルのフィールドを組み合わせて値を出す方法について 2 2022/07/20 19:43
- その他(データベース) 更新クエリをリンクデータベーステーブルに実行し実行時エラー3362固有インデックスに重複する値が含ま 1 2022/09/21 11:44
- Access(アクセス) Accessフォーム 一部のレコードだけを抽出する方法について 1 2022/06/28 18:45
- その他(データベース) Accessフォームからパラメーターで表示したレコードを指定のExcelのセルへ転送する方法について 2 2022/08/22 18:04
- Access(アクセス) Accessのクエリの結果を、既存のエクセルに追加したい 2 2022/07/31 22:44
- SQL Server ACCESSで表が作りたく、そのためのSQL文や設定方法を教えてください。 1 2022/08/15 12:28
- Access(アクセス) access,vbaでフォルダ内のファイルをテーブルにインポート、ファイル名もフィールドに追加したい 1 2022/08/31 11:11
- Access(アクセス) Accessテキストボックス内に2つのフィールドの値を比較して大きい方の値を表示させる方法 1 2022/09/09 10:50
- Access(アクセス) Accessフォームで複数条件でフィールドの値を表示する方法 4 2022/07/21 10:47
関連するカテゴリからQ&Aを探す
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
ACCESSで和暦を西暦に・・・
-
Accessでテーブルの値をテキス...
-
アクセスで複数行の一括入力す...
-
ODBC--リンクテーブル'XXXX'で...
-
通貨型で\\0の時、何も表示しな...
-
アクセス VBAで列の入れ替...
-
Access クエリの累計
-
Accessで、固定アルファベット+...
-
ACCESSで400以上のフィールドが...
-
accessで重複を防ぎたい
-
アクセスでの時間の並びかえに...
-
アクセスのテーブルデータをCSV...
-
アクセス エラーを数値「0」に...
-
Access 昇順・降順で並び替え...
-
INSERT INTO ステートメントに...
-
ACCESS検索★ある文字を複数のフ...
-
主キーはオートナンバー型のID...
-
3つの表を1つに縦に連結する
-
ODBCで接続するとDBに変更/追加...
-
Accessでテーブル名やクエリ名...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
Accessでテーブルの値をテキス...
-
Accessのフィールド数が255しか...
-
ACCESSで400以上のフィールドが...
-
INSERT INTO ステートメントに...
-
【Access】フォームで自動計算...
-
IT用語について質問です。 以前...
-
アクセス エラーを数値「0」に...
-
SQLServer2005のSQL文での別名...
-
ACCESSでの改行コード
-
accessで重複を防ぎたい
-
ExcelのデータをコピーでACCESS...
-
accessのレポートで元になるテ...
-
ACCESSで和暦を西暦に・・・
-
Accessで、固定アルファベット+...
-
アクセス VBAで列の入れ替...
-
アクセス メモ型 255文字...
-
ACCESSでテーブルのフィールド...
-
Access 昇順・降順で並び替え...
-
ACCESS検索★ある文字を複数のフ...
-
アクセスでオートナンバーをリ...
おすすめ情報