
いつもお世話になっています。
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で質問しましょう!
似たような質問が見つかりました
- 経営情報システム accessでの請求管理について 12 2022/06/11 16:20
- Excel(エクセル) Powershell エクセル検索 完全一致の方法 1 2022/06/05 20:19
- Visual Basic(VBA) エクセルVBAで教えて頂きたいのですが? 2 2022/12/31 20:28
- プリンタ・スキャナー コンビニのマルチコピーの性能について教えて下さい。 5 2023/05/10 03:05
- その他(データベース) 更新クエリをリンクデータベーステーブルに実行し実行時エラー3362固有インデックスに重複する値が含ま 1 2022/09/21 11:44
- Java Java 南京錠 2 2023/02/04 11:46
- iPhone(アイフォーン) iPhone/iPadの標準メールアプリでのアカウント新規登録について pop/imap選択 1 2023/06/22 08:00
- その他(プログラミング・Web制作) ちょっとだけ勉強したいのですが何がよろしいですか 11 2022/04/27 10:09
- 物理学 物理の問題が分かりません。 解説よろしくお願い致します。 ピストンのついた容器に一定量の気体を入れ、 2 2023/06/20 19:46
- Access(アクセス) Access DLookup vbaで条件を2件設定したい場合どうすればよいでですか? 現在 If( 1 2023/06/28 14:28
このQ&Aを見た人はこんなQ&Aも見ています
-
<ACCESS>別テーブルのレコードのテキストデータが中に含まれるレコードを抽出する方法を教えてください
Access(アクセス)
-
ACCESS クエリの抽出条件に他のテーブルの値を参照する方法
Access(アクセス)
-
アルファベットの入った文字列の抽出の仕方について。
Excel(エクセル)
-
-
4
accessテーブル作成クエリを実行したときにオートNo(のような)振る方法
その他(データベース)
-
5
Access サブフォームでの選択行の取得
その他(データベース)
-
6
Accessクエリでの、LIKE条件
その他(データベース)
-
7
アクセスの初心者の質問です(空白の場合に他のフィールドを表示させたい。)
Access(アクセス)
-
8
Access]2つのテーブルを比較してフィールドの一部が一致したデータを抽出
Access(アクセス)
-
9
アクセス 部分一致の抽出
その他(Microsoft Office)
-
10
Accessで、1つの項目に複数の置換えを1度でするには?
Access(アクセス)
-
11
データベースの最適化をマクロでしたい
その他(データベース)
-
12
ACCESS IIF関数 複数条件の設定について
Excel(エクセル)
-
13
Access レポートでiif関数で文字列検索
その他(Microsoft Office)
-
14
access別のテーブルを参照してテキストボックスに値を表示、編集したい
Access(アクセス)
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
クエリのキャンセルがいつにな...
-
accessテーブル作成クエリを実...
-
SQLサーバーのテーブルの値...
-
ユニオンクエリの結果をテーブ...
-
重複するレコードに対しフラグ...
-
SI Object Browserのテーブルス...
-
テーブル作成クエリで新テーブ...
-
あるテーブルのデータを追加、...
-
レプリケーションしているテー...
-
SQL Serverのテーブル追加を、A...
-
AccessVBAで降順にするテーブル...
-
excel テーブル
-
「マスタ」と「テーブル」の違...
-
Accessにインポートしたら並び...
-
列名XXXXが無効です
-
SELECT文でのデッドロックに対...
-
accessのエクスポートエラーに...
-
3つ以上のテーブルをUNIONする...
-
SQL Server のデータをCSVファ...
-
ACCESSのSQLで、NULLかNULLでな...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
SI Object Browserのテーブルス...
-
クエリのキャンセルがいつにな...
-
ユニオンクエリの結果をテーブ...
-
accessテーブル作成クエリを実...
-
AccessでOracleのテーブルをリ...
-
コンボボックスで入力したもの...
-
エクセルでテーブルの最終行が...
-
UNIONなどで複数のテーブルから...
-
あるテーブルのデータを追加、...
-
アクセスのテーブル作成クエリ...
-
VIEWしか読み取れないユーザの...
-
PL/SQLでFROM句に変数を使いたい
-
Access のリレーションシップで...
-
ADOでSeekメッソッドが使えませ...
-
ストアドをまたがるローカル一...
-
レプリケーションしているテー...
-
SQLサーバーのテーブルの値...
-
リンクサーバー接続先の参照エ...
-
ACCESS-リンクテーブルの設定で...
-
重複するレコードに対しフラグ...
おすすめ情報