
A 回答 (2件)
- 最新から表示
- 回答順に表示
No.2
- 回答日時:
エラー3662は、IDENTITY列(主キーがオートナンバー型)を持つSQL Serverテーブルにアクセスする際に、OpenRecordsetでdbSeeChangesを使用する必要があることを示しています。
このエラーを解決するために以下の方法を試してみてください:レコードセットを更新可能なものに変更:IDENTITY列を持つテーブルにアクセスする場合、dbOpenDynasetではなくdbOpenDynaset | dbSeeChangesを使用する必要があります。以下のように修正してみてください:
Set rs = db.OpenRecordset("SELECT * FROM 見積 WHERE 得意先コード = '" & Me.得意先コード & "'", dbOpenDynaset | dbSeeChanges)
レコードセットの型を変更:オートナンバー型の主キーを持つテーブルにアクセスする場合、レコードセットの型を適切に設定することが重要です。dbOpenDynasetではなく、dbOpenTableを使用する方法もあります。以下のように修正してみてください:
Set rs = db.OpenRecordset("見積", dbOpenTable)
これらの修正を試してみてください。エラーが解消されると、SQL Serverテーブル「見積」にアクセスしやすくなるはずです。
No.1
- 回答日時:
エラーの原因は、「得意先コード」オブジェクトに対して.Refreshメソッドを使用しているためです。
Accessのフォームやレポートでは、フィールドの値を更新するために.Refreshメソッドを使うことはできません。代わりに、特定のレコードを更新する場合は、次の手順を試してみてください:
フォームのデータソースを特定のレコードに設定します。
更新したいフィールドに新しい値を代入します。
フォームのレコードを更新します(レコードセットの更新)。
例えば、得意先コードが特定のレコードを識別するキーである場合、以下のようなVBAコードを使用できます:
Private Sub 得意先コード_Enter()
Dim db As DAO.Database
Dim rs As DAO.Recordset
Set db = CurrentDb
Set rs = db.OpenRecordset("SELECT * FROM YourTableName WHERE 得意先コード = '" & Me.得意先コード & "'", dbOpenDynaset)
If Not rs.EOF Then
rs.Edit
' 更新したいフィールドに新しい値を設定
rs!フィールド名 = 新しい値
rs.Update
End If
rs.Close
Set rs = Nothing
Set db = Nothing
End Sub
上記のコードは、特定の得意先コードに関連するレコードを探し、そのレコードを編集して新しい値を設定し、最後に更新します。お使いのAccessデータベースの構造や具体的な要件に合わせてコードを調整してください。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Excel(エクセル) EXCELの外部データ取得ができない 1 2023/03/23 09:03
- Visual Basic(VBA) xmlドキュメントから別拡張子で保存したい 4 2023/09/12 11:08
- Visual Basic(VBA) エクセルVBA 3 2022/06/23 20:00
- Visual Basic(VBA) Excel マクロについての相談 5 2024/03/20 15:02
- Visual Basic(VBA) ACCESS DAO で不要なテーブルのフィールド(列)の削除 4 2022/06/23 12:13
- Visual Basic(VBA) Accessフォームで全レコードを指定のExcelのセルへ転送し印刷する方法について 2 2022/09/08 18:23
- Access(アクセス) Access DAOのExecuteメソッドのオプション(RecordsetOptionEnum)に 1 2022/09/19 07:34
- Visual Basic(VBA) VBAでのMATCH関数 3 2022/10/17 19:06
- Excel(エクセル) 【マクロ】1つのセルから結合されているセルへのコピー貼り付けについて 4 2024/01/28 21:30
- その他(データベース) 更新クエリをリンクデータベーステーブルに実行し実行時エラー3362固有インデックスに重複する値が含ま 1 2022/09/21 11:44
このQ&Aを見た人はこんなQ&Aも見ています
-
性格悪い人が優勝
できるだけ性格悪い人になって回答をお願いします。
-
字面がカッコいい英単語
あなたが思う「字面がカッコいい英単語」を教えてください。
-
人生で一番思い出に残ってる靴
皆さんの人生で一番思い入れのある靴の話を伺ってみたいです。
-
チョコミントアイス
得意ですか?不得意ですか?できれば理由も教えてください。
-
あなたが好きな本屋さんを教えてください
どのくらいの規模間で、どのような本が並んでいるか、どのような雰囲気なのかなどなど...
-
「メソッドまたはデータメンバが見つかりません。」というエラーが出ます。
その他(データベース)
-
Access2003 メソッドまたはデータメンバが見つかりません
Visual Basic(VBA)
-
SQL文で パラメータが少なすぎます エラー
Access(アクセス)
-
-
4
ACCSESS2013VBA フォームのレコードソースを変更する
その他(データベース)
-
5
MS Accessでフォームの「開く時」と「読込み時」のイベントの違い
Access(アクセス)
-
6
実行時エラー 3265「要求された名前、または序数
Visual Basic(VBA)
-
7
レコードを保存するコード アクセスvba
その他(Microsoft Office)
-
8
実行時エラー 438になった時の対処法を教えて下さい。
Visual Basic(VBA)
-
9
Access 最後のレコードに到達するまでループ処理を行う方法
Access(アクセス)
-
10
Access サブフォームでの選択行の取得
その他(データベース)
-
11
フォームを開くときに、コンボボックスの値を選択(アクセスVBA)
Visual Basic(VBA)
-
12
テキストボックスにクエリ結果を表示させたい
その他(データベース)
-
13
アクセスで#エラーを表示させない方法は?
Access(アクセス)
-
14
AccessVBA RecordSourceのリセットについて
Access(アクセス)
-
15
エラー「メソッドまたはデータメンバが見つかりません」
Access(アクセス)
-
16
Accessで別テーブルの値をフォームに表示したい
その他(データベース)
-
17
Accessレポートのチェックボックスを大きくする方法
Access(アクセス)
-
18
access2021 強制終了してしまう
Access(アクセス)
-
19
ACCESS VBA でのエラー解決の根拠がわかりません エラー「イベントプロパティに指定した式・・
Access(アクセス)
-
20
アクセスVBAのMe!と[ ]
Access(アクセス)
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・昔のあなたへのアドバイス
- ・字面がカッコいい英単語
- ・許せない心理テスト
- ・歩いた自慢大会
- ・「I love you」 をかっこよく翻訳してみてください
- ・ゆるやかでぃべーと タイムマシンを破壊すべきか。
- ・はじめての旅行はどこに行きましたか?
- ・準・究極の選択
- ・この人頭いいなと思ったエピソード
- ・「それ、メッセージ花火でわざわざ伝えること?」
- ・ゆるやかでぃべーと すべての高校生はアルバイトをするべきだ。
- ・【お題】甲子園での思い出の残し方
- ・【お題】動物のキャッチフレーズ
- ・人生で一番思い出に残ってる靴
- ・これ何て呼びますか Part2
- ・スタッフと宿泊客が全員斜め上を行くホテルのレビュー
- ・あなたが好きな本屋さんを教えてください
- ・かっこよく答えてください!!
- ・一回も披露したことのない豆知識
- ・ショボ短歌会
- ・いちばん失敗した人決定戦
- ・性格悪い人が優勝
- ・最速怪談選手権
- ・限定しりとり
- ・性格いい人が優勝
- ・これ何て呼びますか
- ・チョコミントアイス
- ・単二電池
- ・初めて自分の家と他人の家が違う、と意識した時
- ・「これはヤバかったな」という遅刻エピソード
- ・ゴリラ向け動画サイト「ウホウホ動画」にありがちなこと
- ・泣きながら食べたご飯の思い出
- ・一番好きなみそ汁の具材は?
- ・人生で一番お金がなかったとき
- ・カラオケの鉄板ソング
- ・自分用のお土産
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
videopadについて
-
コンパイルエラー 変数が定義...
-
フィルターかけた後、重複を除...
-
wechatアプリについての質問で...
-
こんばんは。COBOLを初めて学ん...
-
多数のExcelファイルからVBAの...
-
access でエラーを回避するには?
-
Javaの問題で質問あります。 コ...
-
2つの住所録の照合
-
SQL
-
JANコードとPOSコードは同じ?
-
VSコードでHTMLに(リンク)フ...
-
スキャンコード取得は MapVirtu...
-
VBSでメール内容を指定のエクセ...
-
ゲームのアルゴリズム
-
VBAでファイルオープン後にコー...
-
VBA リストボックス(複数条件...
-
マザーボードの名前を知る方法
-
Gitのクローンについて
-
access2021 VBA メソッドまたは...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
フィルターかけた後、重複を除...
-
1日に1人がこなせるプログラム...
-
JANコードとPOSコードは同じ?
-
access2021 VBA メソッドまたは...
-
Excel VBA素人です。VBAで図形...
-
Exel VBA 別ブックから該当デ...
-
access2003 クエリSQL文に...
-
エクセルに見えない文字(JISX0...
-
Nullの使い方が不正です。
-
【VB6】実行ファイルとした後、...
-
VBAでファイルオープン後にコー...
-
オートフィルタで抽出結果に 罫...
-
PreviewKeyDownイベントが2回...
-
JavaScriptの定数名が取り消し...
-
Excel VBAでOpenTextのFieldInf...
-
COBOLの文法
-
ACCESSユニオンクエリでORDER B...
-
Access DCountでの連番について
-
VBA リストボックス(複数条件...
-
C# コードビハインドについて
おすすめ情報
hectopascal 様
丁寧なご回答ありがとうございます。
いただいたレコードにコードを入力した際エラーが発生してしまいました。
実行エラー3662:
IDENTITY列を持つSQLServerテーブルにアクセスする場合
OpenRecordsetでdbSeeChangesを使用する必要があります。
エラーがついた場所
Set rs = db.OpenRecordset("SELECT * FROM 見積 WHERE 得意先コード = '" & Me.得意先コード & "'", dbOpenDynaset)
今回テーブルとして使う「見積」の主キーが「オートナンバー型」であることが原因だと思いますがどのように変更すればよいでしょうか?
hectopascal 様
丁寧なご回答ありがとうございます。
型によってコードを変えるのはとても大切ですね..........。
いただいたレコードにコードを入力した際再びエラーが発生してしまいました。
Set rs = db.OpenRecordset("SELECT * FROM 見積 WHERE 得意先コード = '" & Me.得意先コード & "'", dbOpenDynaset | dbSeeChanges)
→コンパイルエラー:
構文エラー:
Set rs = db.OpenRecordset("見積", dbOpenTable)
→実行エラー 3219
無効な処理です。
どちらも変更したレコードにエラー線がありました。
エラーが発生せず実行するのは厳しいでしょうか?