いつもお世話になっています。
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も見ています
-
新NISA制度は今までと何が変わる?非課税枠の拡大や投資対象の変更などを解説!
少額から投資を行う人のための非課税制度であるNISAが、2024年に改正される。おすすめの銘柄や投資額の目安について教えてもらった。
-
<ACCESS>別テーブルのレコードのテキストデータが中に含まれるレコードを抽出する方法を教えてください
Access(アクセス)
-
Access]2つのテーブルを比較してフィールドの一部が一致したデータを抽出
Access(アクセス)
-
アクセス 部分一致の抽出
その他(Microsoft Office)
-
-
4
Access 同じデータをたくさんのレコード(同一列)に一度に入力するには
Access(アクセス)
-
5
Accessクエリでの、LIKE条件
その他(データベース)
-
6
ACCESSのSQLで、NULLかNULLでないかの判定
その他(データベース)
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
accessテーブル作成クエリを実...
-
クエリのキャンセルがいつにな...
-
エクセルでテーブルの最終行が...
-
Accessにインポートした複数の...
-
SQLサーバーのテーブルの値...
-
VIEWしか読み取れないユーザの...
-
AccessVBAで降順にするテーブル...
-
列サイズ変更時、DB停止は必要?
-
ストアドをまたがるローカル一...
-
ユニオンクエリの結果をテーブ...
-
SI Object Browserのテーブルス...
-
レプリケーションしているテー...
-
SQL Serverのテーブル追加を、A...
-
SQLスクリプトを自動生成する方法
-
ACCESS-リンクテーブルの設定で...
-
あるテーブルのデータを追加、...
-
コンボボックスで入力したもの...
-
位置を指定してフィールドを追...
-
Access2000でテーブルが見れない
-
リンクサーバー接続先の参照エ...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
accessテーブル作成クエリを実...
-
クエリのキャンセルがいつにな...
-
SI Object Browserのテーブルス...
-
エクセルでテーブルの最終行が...
-
UNIONなどで複数のテーブルから...
-
Accessにインポートした複数の...
-
ストアドをまたがるローカル一...
-
SQLについて質問です。 テーブ...
-
ユニオンクエリの結果をテーブ...
-
あるテーブルのデータを追加、...
-
SQLサーバーのテーブルの値...
-
位置を指定してフィールドを追...
-
レプリケーションしているテー...
-
コンボボックスで入力したもの...
-
AccessVBAで降順にするテーブル...
-
重複するレコードに対しフラグ...
-
列サイズ変更時、DB停止は必要?
-
SQLスクリプトを自動生成する方法
-
Access のリレーションシップで...
-
VIEWしか読み取れないユーザの...
おすすめ情報