No.3ベストアンサー
- 回答日時:
こんにちは。
お力になれなかったようで、すみません。
今回例をあげていただいた場合を考えると、リレーションシップの設定は必ずしも必要ではないように思います。
リレーションシップは、親レコードを削除したら、同時に子レコードも削除することを可能とする場合などに有効ですよね。
でもこの場合は、「車種」を簡単に選ぶために車種をテーブル化しコードとして利用するのでリレーションの必要があるのかな・・・とも思います。
私が今まで作成してきたシステムではリレーションシップは利用しなかったので詳しくはわからないのですが・・・。リレーションシップをとりあえず外してみてはどうでしょうか。(根本的な解決にはなってないですよねぇ・・・逃げてますぅ)
出力画面ではメインテーブルとサブテーブルとをリンクしたクエリーを用いて車種名を出力するなどで対応できます。
混乱させるだけで、お力になれているとは思えませんね。スミマセン。
他の方からの回答があればそちらを信用なさってくださいね。
自宅にはACCESSがないので、土日は試してみることもできなくって・・・。
最後まで付き合いますので、頑張りましょう!
この回答への補足
温かいお言葉ありがとうございます。
一度リレーションが必要でなさそうなところは、削除してみます。
そうした場合、出力のときクエリーを利用してリンクしたときは、リンク先の車種の抽出条件にメインフォームの車種を見に行くように設定すればいいのですか?たとえば、抽出条件にforms!メインフォーム名!コントロール名なんかのように!
私の中ではテーブル同士で関連するようなものはすべてリレーションが必要だと考えていました。
もし差し支えなければ私が作成したDBを一度確認していただいてアドバイスしていただければありがたいのですが。
私の周りには経験者がいなく、私自身も作成するのがはじめてなもので、本当にゴールに向かって進んでいるのかと、かなり無駄な作業をしすぎているのではと心配になります。もしだめな場合は、今の私を助けていただけるような人(あくまで個人で費用負担ができないのを承知の方)はいらっしゃらないでしょうか?
修正していただくと言うものではなく、欠点、修正点のコメント、アドバイスがほしいのですが。ご連絡お待ちしております。
No.4
- 回答日時:
こんにちは。
出力の際は、書いてらっしゃるような対応で可能だと思います。
作成中のものを私が見て差し支えないのであれば、見てみますので送っていただけますか?見てみるのは、月曜日になってしまいますが・・・
gooのフリーメールに添付できる容量であれば(制限はどれくらいなのかなぁ・・・)送ってください。不可能であれば、その旨を連絡ください。メールアドレスを返信いたします。
gooのフリーメールは、ニックネーム@mail.goo.ne.jpでいいんですよね。
お待ちしています。
No.2
- 回答日時:
こんにちは。
やりたいことがよくわかりました。おっしゃるとおりですね。
この場合最後にチェックすることが望ましいと思います。
リレーションシップでメインテーブルとサブテーブルのリンクを1対多(無限マーク)になっているかと思います。そのリレーションを選択し、右クリックして「リレーションの編集」を選択するか、リレーションをダブルクリックするとリレーションの編集ができます。その画面の「結合の種類」ボタンを押してください。
そこで「Aテーブルの全レコードとBテーブルの同じ結合のフィールドだけを含める。」を選択してみてください。
こうすれば、Aテーブルの全てとBテーブルはリンクが可能なもののみ・・・というふうな設定になります。
これで対処できるといいのですが・・・
これでもダメならまた知らせてください。
この回答への補足
せっかくアドバイスいただいたのですが、やっぱりうまくいきません。
さっき気が付いたのですが、たとえば、メインフォーム内のあるフィールドにある
コンボボックスで、ただ選択するだけのものでも同じような現象になります。
EX. サブテーブルに車の車種を登録しておきます。
メインフォームからコンボボックスでこのサブテーブル内のレコードを表示する。
このとき出力するために、メインテーブルとサブテーブルを多対1のリレーションを組んでいます。
こうしたばあい、車の仕様を登録するようなメインフォーム内で、この車種を入力するコンボボックスを入力しないでレコードの移動あるいは終了をすると同様なエラー表示がでます。
このようなばあい、根本的な考え方が間違っているのでしょうか。リレーションの設定をこのような場合に行うこと自体が間違っているのでしょうか?
なにせ、ビギナーのため怖いもの知らずのため、よろしくご教示ください。
No.1
- 回答日時:
おはようございます。
前の質問も参照させていただきました。
どのようなシステムを作っているのかわからないのですが、以下の例をあげて説明をさせてください。
請求書 (請求番号をキーとし顧客コードや請求番号・請求日を含む)
請求明細(請求番号と枝番をキーとし、商品コード、数量等を含む)
顧客情報(顧客コードをキーとする顧客情報)
商品 (商品コードをキーとし、単価を含む)
この場合以下の関係が生まれます。
1請求書に対しては、顧客は1
1顧客に対しては、請求書はn
1請求書に対しては、請求明細はn
1請求明細に対しては、商品は1
質問の内容を読むと、以下のように思われます。
・請求書作成画面に顧客情報が表示される顧客コードコンボボックスを作成している。
・顧客コードを選択(入力)せず請求書を作成しようとしている
(私の挙げた例が悪いかも知れないのですが・・・。)
リレーションをどのように設定しているかにもよりますが、例では顧客のいない請求書は作成されるべきではないはずです。
リレーション・テーブルのキーの状態から上記のような現象が起こっているのではないかと思われます。
他の方からの回答を優先してくださって結構ですが、私の例での勘違い等あれば、補足してくだされば嬉しいです。前のご質問を読んでもイメージがわかないので、どのようなシステムを作成されているのか明かすことはできないとは思いますが、具体的に例を挙げてくだされば、お力になれると思います。
この回答への補足
ご回答ありがとうございます。
わかりやすい例を挙げていただいてすいません。
おおむね、例でいわれているとおり、本来顧客コード(私の場合は施設コード)を全ての入力者がいれるべきものなのですが、ネットワークで使用したいと思っているため、どのような入力をされるかわかりません。そこで、シュミレーションをして、このコードを入力せずに終了しようとしたときにこのエラー表示が出たわけです。よって、入力必須項目を入力せずに終了した場合、このエラー表示が出る前に入力を促すメッセージが出せればと思っています。エラー表示がいきなりでると、壊れていると思われるみたいで。。。
このフォームには、終了、メインへ、他のフォームへなどのコマンドボタンを作成していますので、各イベント時に入力を確認し、入力されていない場合は入力を促すようにしたいと思います。
ビギナーのため、具体的にどうしたいと書くことが難しいのですが、よろしくご教示のほどお願いいたします。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・街中で見かけて「グッときた人」の思い出
- ・「一気に最後まで読んだ」本、教えて下さい!
- ・幼稚園時代「何組」でしたか?
- ・激凹みから立ち直る方法
- ・1つだけ過去を変えられるとしたら?
- ・【あるあるbot連動企画】あるあるbotに投稿したけど採用されなかったあるある募集
- ・【あるあるbot連動企画】フォロワー20万人のアカウントであなたのあるあるを披露してみませんか?
- ・映画のエンドロール観る派?観ない派?
- ・海外旅行から帰ってきたら、まず何を食べる?
- ・誕生日にもらった意外なもの
- ・天使と悪魔選手権
- ・ちょっと先の未来クイズ第2問
- ・【大喜利】【投稿~9/7】 ロボットの住む世界で流行ってる罰ゲームとは?
- ・推しミネラルウォーターはありますか?
- ・都道府県穴埋めゲーム
- ・この人頭いいなと思ったエピソード
- ・準・究極の選択
- ・ゆるやかでぃべーと タイムマシンを破壊すべきか。
- ・歩いた自慢大会
- ・許せない心理テスト
- ・字面がカッコいい英単語
- ・これ何て呼びますか Part2
- ・人生で一番思い出に残ってる靴
- ・ゆるやかでぃべーと すべての高校生はアルバイトをするべきだ。
- ・初めて自分の家と他人の家が違う、と意識した時
- ・単二電池
- ・チョコミントアイス
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
2つのテーブルAとBをマージ...
-
access テーブル内のレコード...
-
ACCESSで指定されたテーブルか...
-
ACCESSに同時アクセス(編集)を...
-
Accessレコードの追加や変更が...
-
テーブル作成クエリで主キーを設定
-
Accessでテーブル名やクエリ名...
-
SQL ServerとACCESSの関係
-
時間の足し算
-
Accessのクエリで半角円マーク...
-
SQLで 全項目を追加したい
-
テーブルの結合プロパティについて
-
フォームの計算がテーブルに反...
-
Accessでvlookupみたいなことは...
-
Accessでテーブルをデータシー...
-
アクセスでのswitch又はiif関数...
-
クエリでグループ毎に連番を振...
-
ACCESS DB起動時パスワードを...
-
2つのテーブルを比較して一致し...
-
AccessでのNULLのレコードの表...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
Accessでテーブル名やクエリ名...
-
access テーブル内のレコード...
-
Accessレコードの追加や変更が...
-
Accessクエリでの、LIKE条件
-
Accessの追加クエリで既存のテ...
-
Accessでvlookupみたいなことは...
-
3つの表を1つに縦に連結する
-
ACCESSに同時アクセス(編集)を...
-
デザインビューで、連結式 を...
-
ACCESSで指定されたテーブルか...
-
Accessでテーブルからテーブル...
-
2つのテーブルを比較して一致し...
-
ツリー構造をRDBで表現するには?
-
SQLで条件指定結合をしたいがNU...
-
リンクテーブルを CopyObject ...
-
パススルークエリをテーブル作...
-
Accessでテーブルにパスワード...
-
SQL: SELECT UNIONすると文字数...
-
時間の足し算
-
INSERT時にデータ登録とmaxの発...
おすすめ情報