AccessのVBAを教えてください。
「名簿1」というテーブルがあり、そのテーブルの1つのレコードを「名簿2」という別テーブルに移動させたいです。
「名簿検索」フォームがあり、「名簿1」のデータを検索して表示させることができます。
その表示させたある特定のレコードを、「移動」というボタンを押すと「名簿2」へ移動させるような作りにしたいです。
「名簿1」と「名簿2」は全く同じ構造のテーブルです。
初心者のため、一番簡単な方法でやりたいです。
レコードを「名簿2」へコピーし、その後「名簿1」のレコードを削除しようと思ったのですが、なかなかうまくできません。
insert into を使ってみたのですが、テーブルのデータ全てがコピーされてしまいます。
Access2010を使用しています。
よろしくお願いいたします。
No.2ベストアンサー
- 回答日時:
No.1です
以下を追加してみてください(変数名は任意です)
Dim RSF As Recordset ← フォームに表示されているレコード用
DIM I As Integer ← カウンター用の変数
Set RSF = Me.Recordset でRSFにフォームに表示されているレコードセット
RS.AddNew から RS.Update の部分を以下に変更します
RS.AddNew
For I = 0 To フィールドの数-1 ← フィールド数が20ならば19
RS.Fields(I) = RSF.Fields(I)
Next I
RS.Update
これでコピーできます。
No.1
- 回答日時:
名簿1と名簿2のフィールドが 氏名、住所、TEL だったとします。
名簿検索フォームに配置したテキストボックスが、Tx_氏名、Tx_住所、Tx_TELだとして、
Dim DB As Database
Dim RS As Recordset
Set DB = CurrentDb
Set RS = DB.OpenRecordset("名簿2", dbOpenDynaset)
RS.AddNew
RS!氏名 = Me.Tx_氏名 ←名簿2へコピー
RS!住所 = Me.Tx_住所
RS!TEL = Me.Tx_TEL
RS.Update
DoCmd.SetWarnings False ← システムメッセージを非表示
DoCmd.RunCommand acCmdDeleteRecord ←名簿1(名簿検索フォーム)のレコード削除
DoCmd.SetWarnings True ← システムメッセージを表示
RS.Close: Set RS = Nothing
DB.Close: Set DB = Nothing
とても分かりやすくありがとうございます。
ちなみに、フィールドがかなり多数あるのですが、
ひとつひとつ指定ではなく、まとめてすべてを指定する方法はありますでしょうか。
2つのテーブルはフィールド名も、テーブル上のフィールドの位置もすべて同じです。
手動でいうと、名簿1で行選択してコピーして、名簿2へ貼付け という感じです。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
このQ&Aを見た人はこんなQ&Aも見ています
-
誕生日にもらった意外なもの
みなさんがもらった誕生日プレゼントで面白いものがあったらぜひ教えてください!
-
フォロワー20万人のアカウントであなたのあるあるを披露してみませんか?
あなたが普段思っている「これまだ誰も言ってなかったけど共感されるだろうな」というあるあるを教えてください
-
映画のエンドロール観る派?観ない派?
映画が終わった後、すぐに席を立って帰る方もちらほら見かけます。皆さんはエンドロールの最後まで観ていきますか?
-
海外旅行から帰ってきたら、まず何を食べる?
帰国して1番食べたくなるもの、食べたくなるだろうなと思うもの、皆さんはありますか?
-
天使と悪魔選手権
悪魔がこんなささやきをしていたら、天使のあなたはなんと言って止めますか?
-
Accessでテーブルからテーブルにデータをコピーしたい
その他(データベース)
-
Accessのテーブルデータを一気にVBAで追加したい・・
その他(データベース)
-
Accessで別mdbのテーブルをコピー
その他(プログラミング・Web制作)
-
-
4
Access サブフォームでの選択行の取得
その他(データベース)
-
5
アクセスVBAで既に開いているエクセルを閉じたい
Yahoo!ショッピング
-
6
SQL文で パラメータが少なすぎます エラー
Access(アクセス)
-
7
Accessで別テーブルの値をフォームに表示したい
その他(データベース)
-
8
Accessでレコードの複製
Access(アクセス)
-
9
accessで選択クエリで得た全レコードをテーブルに取り込む方法
その他(データベース)
-
10
日付型のフィールドに空白を入れる方法を教えてください
その他(データベース)
-
11
Access 最後のレコードに到達するまでループ処理を行う方法
Access(アクセス)
-
12
ACCESSでVBAから選択クエリの抽出条件を指定したい
Access(アクセス)
-
13
Accessで、フォームからフォームへ値を引き継ぐやり方
Access(アクセス)
-
14
アクセスで数値型のフィールドにNullをいれたい
その他(データベース)
-
15
レコードを保存するコード アクセスvba
その他(Microsoft Office)
-
16
ACCESSで空白のデーターをクエリで判定/識別する方法を教えてくださ
Access(アクセス)
-
17
Accessでテーブルの値をテキストボックスに代入するには?
Access(アクセス)
-
18
リンクテーブルを CopyObject するとリンク情報がコピーされる
その他(データベース)
-
19
アクセスVBAのMe!と[ ]
Access(アクセス)
-
20
クエリのデータをテーブルに入れたい
Access(アクセス)
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・人生のプチ美学を教えてください!!
- ・10秒目をつむったら…
- ・あなたの習慣について教えてください!!
- ・牛、豚、鶏、どれか一つ食べられなくなるとしたら?
- ・【大喜利】【投稿~9/18】 おとぎ話『桃太郎』の知られざるエピソード
- ・街中で見かけて「グッときた人」の思い出
- ・「一気に最後まで読んだ」本、教えて下さい!
- ・幼稚園時代「何組」でしたか?
- ・激凹みから立ち直る方法
- ・1つだけ過去を変えられるとしたら?
- ・【あるあるbot連動企画】あるあるbotに投稿したけど採用されなかったあるある募集
- ・【あるあるbot連動企画】フォロワー20万人のアカウントであなたのあるあるを披露してみませんか?
- ・映画のエンドロール観る派?観ない派?
- ・海外旅行から帰ってきたら、まず何を食べる?
- ・誕生日にもらった意外なもの
- ・天使と悪魔選手権
- ・ちょっと先の未来クイズ第2問
- ・【大喜利】【投稿~9/7】 ロボットの住む世界で流行ってる罰ゲームとは?
- ・推しミネラルウォーターはありますか?
- ・都道府県穴埋めゲーム
- ・この人頭いいなと思ったエピソード
- ・準・究極の選択
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
同窓会名簿で、亡くなった方の記載
-
亡くなられた方の表現
-
差し込み印刷 1ページに複数の...
-
物故者名の一覧表を作成すると...
-
携帯のアドレス帳に「山田さん...
-
オンラインでの名簿管理ソフト...
-
同窓会の名簿に欠席者・物故者...
-
Accessでレコードを別テーブル...
-
「○日までに」の意味、その日は...
-
同期と給料に差がありました。 ...
-
派遣社員です。私語がおおいと...
-
社会人で坊主はやめてね
-
不動産業者から個人情報をLINE...
-
派遣社員です。仕事がこなせず...
-
ガソリンスタンドって何業界?
-
沖電気工業って一流企業ですか...
-
会社は仲良しを作る所ではない...
-
県庁と一流企業って一般的にど...
-
関わりたくないのに関わってく...
-
入社5ヶ月目になる者です。 も...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
同窓会名簿で、亡くなった方の記載
-
Accessでレコードを別テーブル...
-
差し込み印刷 1ページに複数の...
-
亡くなられた方の表現
-
同窓会の名簿に欠席者・物故者...
-
Access]2つのテーブルを比較し...
-
名簿図書館って
-
教員採用の名簿登載について
-
新橋の名簿図書館について
-
携帯のアドレス帳に「山田さん...
-
国立病院機構の採用者名簿に、...
-
同窓会名簿作成のための、個人...
-
こんな時の言い回し
-
大学の同窓会名簿に載らないと...
-
名簿に載る個人情報について
-
エクセルで学年クラスが変わっ...
-
幼稚園で園児の住所、電話番号...
-
保護者名簿を作成したいが、依...
-
チーム分けのフリーソフト
-
公立小中学校の生徒の住所録を...
おすすめ情報