
いつもお世話になっています。
Accessでクエリを作成するにあたり、リレーションシップを設定したいのですが、
一致させるフィールドが「123456/S1234とS1234」,「S001234とS1501234E」,「5678と5678」など、
完全一致するものと一部一致するものが混在しています。
一部一致のものでも、どれと一致させるかを判断することはできるのですが、
この状態では通常のリレーションシップは設定できませんか?
設定できないならば、一度加工して完全一致したテーブルを作成し、
それとリレーションシップをVBAで設定するしかないでしょうか?
No.2ベストアンサー
- 回答日時:
一致条件を判断する関数をVBAで作成すれば可能ですが、
「S001234とS1501234E」が一致するということは、1234 が一致しているということですが、前者の一部と後者の一部の一致も許可するということですよね。
だとすると、「S001234」は一つ前のデータ例「S1234」とも一致するし、「S1501234E」は同じく「123456/S1234」とも一致するということになりますね。
これでは、一致する条件が緩すぎて、複数の組み合わせが多数できてしまい使い物にならないと思いますが。
もう少し厳密な条件定義が必要ですね。
また、関数で一致条件を定義するとインデックスの機能が使えませんので、レコード件数が多いと処理が重くなります。
加工して完全一致になるフィールドを作成する方法をとることをお勧めましす。
どちらにしても現状の条件ではどうにもなりません。
回答ありがとうございます。
比較条件が緩いのは、相談するにあたりちょっとデータを単純化しているのでどうにかなりそうです。(紛らわしくてすみません)
が、VBAで関数を使うつもりが、処理がおそくなるとは知りませんでした。
やはり完全一致フィールドを比較用キーとして作成するのがよさそうですね。
No.4
- 回答日時:
補足:選択クエリはちょっと複雑になるかも・・・。
改定後の構造で選択クエリを作成してみました。その場合、普通に作成すると、参照が倍になりました。(添付図参照のこと)
こういう状況が出現することも想定して作業を進められたがいいかもです。

No.3
- 回答日時:
>一致させるフィールドに一部一致するものが混在しています。
>一度加工して完全一致したテーブルを作成し・・・
それが妥当かどうかは、全体のデータ構造だと思いますよ。
[テーブル1]
ID=1
列1=12345
・・・・・
ID=7
列1=12345
[テーブル2]
ID=1
列1=12345
列2=S1234
ID=2
列1=12345
列2=12345
[テーブル2.列1]を新たに追加。そして、[テーブル1.列1]-[テーブル2.列1]でリレーションシップを設定。実際には、[テーブル2.1列2]のみを参照する。こういう設計変更が考えられますが、それが妥当かどうか・・・。全体のデータ構造だと思いますよ。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
このQ&Aを見た人はこんなQ&Aも見ています
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
SI Object Browserのテーブルス...
-
クエリのキャンセルがいつにな...
-
SQLサーバーのテーブルの値...
-
PL/SQLでFROM句に変数を使いたい
-
トリガの使い方
-
#ワークテーブルにinsert時 変...
-
アクセスのテーブル作成クエリ...
-
ユニオンクエリの結果をテーブ...
-
「マスタ」と「テーブル」の違...
-
オラクルではできるのにSQLSERV...
-
accessで移動平均する方法
-
数百万件レコードのdelete
-
ACCESS2000のテーブル構造
-
請求と入金のテーブルの作成の...
-
VBAの実行時エラー'2522'について
-
SQLで○○の値以外を持っているレ...
-
更新クエリでキー違反
-
Access VBA [リモートサーバー...
-
SELECT時の行ロックの必要性に...
-
AccessShareLock はどの程度気...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
SI Object Browserのテーブルス...
-
accessテーブル作成クエリを実...
-
クエリのキャンセルがいつにな...
-
ストアドをまたがるローカル一...
-
エクセルでテーブルの最終行が...
-
ユニオンクエリの結果をテーブ...
-
アクセスのテーブル作成クエリ...
-
UNIONなどで複数のテーブルから...
-
ADOでSeekメッソッドが使えませ...
-
あるテーブルのデータを追加、...
-
コンボボックスで入力したもの...
-
VIEWしか読み取れないユーザの...
-
列サイズ変更時、DB停止は必要?
-
テーブル作成クエリで新テーブ...
-
#ワークテーブルにinsert時 変...
-
エクセルの数式で添付写真のも...
-
excel テーブル
-
SQL Serverのテーブル追加を、A...
-
Accessでバージョン違いのファ...
-
エクセル
おすすめ情報