ACCESS2000で更新クエリの質問です。
先日同様の質問をさせていただきましたが、その後うまくできないところがあったので再度質問させていただきました。
内容は、フィールドの値のカウントを集計し、更新クエリを使用してデータを更新するという内容です。
前回の質問でDCount関数を用いて下記のとおり実行するとできるとのことでしたが、条件が複数ある場合どのように記述すれば
いいのかを教えて下さい。
条件は、
(1)年月 =Aテーブル.年月
(2)コード=Aテーブル.コード
(3)区分 =Aテーブル.区分
<こんな感じで実行しようとしたのですがうまく動きません>
UPDATE Bテーブル SET"
カウント数1
= DCount('区分','Aテーブル','[A年月]=[B年月] And [Aコード]=[Bコード] And [A区分]='001'')
カウント数2
= DCount('区分','Aテーブル','[A年月]=[B年月] And [Aコード]=[Bコード] And [A区分]='002'')
やりたいことは下記のとおりです。Aテーブルを集計しBテーブルの個数にAテーブルの個数の合計値を更新する。
<Aテーブル>
A年月 Aコード A区分
200807 9991 001
200807 9991 001
200807 9991 001
200807 9991 002
200807 9991 002
<Bテーブル>
B年月 Bコード Bカウント数1 Bカウント数2
200807 9991 0 0
↓↓↓更新後
<結果:Bテーブル>
B年月 Bコード Bカウント数1 Bカウント数2
200807 9991 3 2
↑ ↑
(Aテーブルの区分='001' (Aテーブルの区分='002'
を集計した結果) を集計した結果)
No.2ベストアンサー
- 回答日時:
> ちなみに条件の年月、コード、区分全てテキスト型です。
多分、そう思って・・・「数値の前提」って、注意書きしたのよ^^;;;
UPDATE Bテーブル SET
Bカウント数1 = DCount('*','Aテーブル','[A年月] = ''' & [B年月] & ''' And [Aコード] = ''' & [Bコード] & ''' And [A区分]=''001'''),
Bカウント数2 = DCount('*','Aテーブル','[A年月] = ''' & [B年月] & ''' And [Aコード] = ''' & [Bコード] & ''' And [A区分]=''002''');
と、言う話・・・
''で、文字列の中に'を1つ挿入可能
だから、'''とシングルクオートが3つのところが、かなり増えた状況ね
No.1
- 回答日時:
とりあえず、B年月、Bコードが数値の前提で、SQL文
UPDATE Bテーブル SET
Bカウント数1 = DCount('*','Aテーブル','[A年月] = ' & [B年月] & ' And [Aコード] = ' & [Bコード] & ' And [A区分]=''001'''),
Bカウント数2 = DCount('*','Aテーブル','[A年月] = ' & [B年月] & ' And [Aコード] = ' & [Bコード] & ' And [A区分]=''002''');
と、言う感じ
'の関係がおかしいのと、SQL上のWhere条件を入れられないから、DCountに更新条件を追加
この回答への補足
やってみたのですが、「更新クエリですべてのレコードを更新できません。」1個のフィールドで型変換エラー、0件のレコードでキー違反、0件のレコードでロック違反、0件のレコードで入力規則違反が発生したため、レコードを更新できませんでした。とエラーがでました。
SELECT文にしても#エラーと表示されます。
もう少し教えてください。ちなみに条件の年月、コード、区分全てテキスト型です。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Access(アクセス) Access クエリ 同一テーブル内 複数フィールドの同時集計のやり方について 1 2022/05/18 19:01
- その他(データベース) 更新クエリをリンクデータベーステーブルに実行し実行時エラー3362固有インデックスに重複する値が含ま 1 2022/09/21 11:44
- Oracle update文で質問です。 下記の条件でupdateをしたいですが、どのようにしたら良いでしょうか。 2 2022/06/23 10:51
- Access(アクセス) Accessテーブルの結合で別々のテーブルのフィールドを組み合わせて値を出す方法について 2 2022/07/20 19:43
- Access(アクセス) AccessVBAで降順にするテーブル作成クエリを使用して作成したテーブルを削除し同一のテーブル作成 1 2023/01/06 11:17
- MySQL うまくいきません教えてくださいお願いしますSQLです。クエリ構文です。 1 2023/07/07 12:39
- MySQL SQLです。こんな感じですか?あってますか? うまくいきません教えてくださいお願いします 1 2023/07/08 15:27
- Access(アクセス) アクセスの更新クエリでカレントレコードのみ更新したい 1 2022/06/02 23:32
- Oracle SQL update方法 2 2022/06/22 14:07
- Oracle sqlのupdate文で質問です。 テーブルBの番号をキーにテーブルAの身長をテーブルBの身長に更新 2 2022/11/02 15:15
このQ&Aを見た人はこんなQ&Aも見ています
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
「マスタ」と「テーブル」の違...
-
重複するキーから一番古い年月...
-
行方向のデータを横に並べる
-
accessで移動平均する方法
-
Accessユニオンクエリーで2つ...
-
sqlのupdate文で質問です。 テ...
-
主キーの変更
-
2つのテーブルから条件に一致...
-
下記のsqlで取得されるレコード...
-
select文の書き方
-
SQLの書き方(UPDATE文)
-
連番のMin, Maxを取得したい
-
Accessでフィールドを比較した...
-
SQL 2つのテーブルとSUBSTRING...
-
Inner join と Left joinの明...
-
自分自身への矢印
-
SELECT時にカウントアップ
-
[Oracle] UPDATE分の副問い合わ...
-
ACCESSのコンパイルエラーについて
-
access初心者です。 アパレル...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
「マスタ」と「テーブル」の違...
-
2つのテーブルから条件に一致...
-
重複するキーから一番古い年月...
-
ACCESS 一つのフィールドに複...
-
PLSQLの識別子エラー
-
主キーの変更
-
Accessでフィールドを比較した...
-
SQL 2つのテーブルとSUBSTRING...
-
続.ORACLEのSELECTのソートに...
-
行方向のデータを横に並べる
-
下記のsqlで取得されるレコード...
-
VIEWでテーブルの集計結果...
-
update文で質問です。 下記の条...
-
[Oracle] UPDATE分の副問い合わ...
-
自分自身への矢印
-
片方だけ抽出する方法(SQL)
-
Accessユニオンクエリーで2つ...
-
連番のMin, Maxを取得したい
-
Inner join と Left joinの明...
-
日付の最大値を検索条件にする方法
おすすめ情報