
No.6ベストアンサー
- 回答日時:
こんにちは
>dim rst as new adodb.recordset
>set rst = new adodb.recordset って記述は
本来は必要です
行数を減らすため、省略していました
あえて書かなくても、あなたがNo1の回答に対する補足に
記述されているので、すでに理解されているものと思っていました。
失礼しました。
長々とアドバイスいただき大変感謝しております。
これからももっと勉強してアドバイスできる立場になれるよう精進します。
本当にありがとうございました。
No.5
- 回答日時:
こんにちは
sqlstring = sqlstring & "where 座席コード ='" & 座席コード & "'"
sqlstring = sqlstring & "返却 = '1';"
のsqlstring & "返却 = '1';"のところでスペースが抜けてますね
"返却 →" 返却
としてください。
ここからは、忠告です。
ぼちぼち、ご自身でデバッグする知識を身につけた方がよろしいかと
存じます(^^;;)
人から教えてもらったソースを理解しないで動かすと
後から変更が発生したとき、大変ですよ
ヘルプを調べたり、SQL文をイミディエイトに貼りつけてデバッグ
それをクエリのSQLに貼り付けて、試してみたりと
なかなか、しんどいですが、頑張ってください。
では
この回答への補足
おっしゃるとおりです。
あせってしまっていてつい、、
ところで最後にひとつだけおしえてください。
rst.open sqlstring, _ -----
とありますが、sqlのばあいは
最初に
dim rst as new adodb.recordset
set rst = new adodb.recordset って記述は
必要ないですか?
No.4
- 回答日時:
こんにちは
失礼しました。ご指摘の通り & が抜けております
SQLSTRING = SQLSTRING & " where 座席コード ='" & Me.座席コード & "'"
SQLSTRING = SQLSTRING & " Set 終了時間 ='" & rst![終了時間] & "',"
SQLSTRING = SQLSTRING & " Where 座席コード ='" & Me.座席コード & "'"
全て、行後部の "'" または"',"で囲んだ文字列の前の & が抜けてます
失礼しました
この回答への補足
すいません
今度はオブジェクトがありませんのエラーが出でしまいました場所は下記の
rst.open sqlstring,_
currentproject.connecction,adopenstatic,adlockreadonly
のところです。
何でしょう????
Dim sqlstring As String
sqlstring = "select * from sogo "
sqlstring = sqlstring & "where 座席コード ='" & 座席コード & "'"
sqlstring = sqlstring & "返却 = '1';"
rst.Open sqlstring, _
CurrentProject.Connection, adOpenStatic, adLockReadOnly
If rst.EOF = True Or rst.BOF = True Then
'エラー処理
Beep
MsgBox ("まだ返却されていません")
End If
No.3
- 回答日時:
こんにちは
手順としては
1.キー入力
2.合致したレコードを読んで
3.画面に表示
4.終了時間入力
5.更新=UPDATE
ですよね
レコード読みこみの条件は
キーが[座席コード]
条件は[返却]が1のものでよろしいかと思います
sub データリード画面表示()
dim SQLSTRING as string
SQLSTRING = "select * form 総合 "
'座席コード・返却は文字型とみなしています
SQLSTRING = SQLSTRING & " where 座席コード ='" & Me.座席コード "'"
SQLSTRING = SQLSTRING & " and 返却 ='1';"
'注ただこれだと入力もれの場合複数レコードが合致するので
'日付と受付時間の最大という条件もあったほうがいいかも?
rst.Open SQLSTRING, _
CurrentProject.Connection, adOpenStatic, adLockReadOnly
If rst.eof = true or rst.bof = true then
'エラー処理
endif
'画面表示
Me.Date= rst![日付]
Me.学生番号 = rst![学生番号]
Me.氏名=rst![氏名]
・
・
・
rst.Close
Set rst = Nothing
End Sub
これで画面表示ができたので終了時間を入力します
更新ボタンを設け、ボタンが押された処理で
sub 更新()
dim SQLSTRING as string
SQLSTRING = "UPDATE 総合 "
SQLSTRING = SQLSTRING & " Set 終了時間 ='" & rst![終了時間] "',"
SQLSTRING = SQLSTRING & " Set 返却 ='2'"
SQLSTRING = SQLSTRING & " Where 座席コード ='" & Me.座席コード "'"
SQLSTRING = SQLSTRING & " and 返却 ='1';"
rst.Open SQLSTRING, _
CurrentProject.Connection, adOpenKeyset, adLockOptimistic
rst.Close
Set rst = Nothing
End Sub
では
この回答への補足
早速ありがとうございました
しかし下記の構文がエラーになってしまいます
なぜでしょう?
& のあとは " っていらないんですか?
たとえば
sqlstring =sqlstring & "where 座席コード ='" & me.座席コード"'"
のところとかですが、、、
sub データリード画面表示()
SQLSTRING = SQLSTRING & " where 座席コード ='" & Me.座席コード "'"
sub 更新()
SQLSTRING = SQLSTRING & " Set 終了時間 ='" & rst![終了時間] "',"
SQLSTRING = SQLSTRING & " Where 座席コード ='" & Me.座席コード "'"
No.2
- 回答日時:
こんにちは
一般的なテーブルメンテナンスの処理には
1.新規登録
2.更新登録
3.削除
があります。
これを一つのフォームで行う場合
今からどれをするよと初めに確定させてから処理するか
キー項目を入力させ、データがあれば更新・削除モード
なければ新規登録モードとさせる、2通りがあります。
まずは、最初に確定させる方法がわかりやすいかと思います。
フォームの上にコマンドボタンを新規と更新・削除の二つ用意して
処理を分岐させれば、いかがでしょうか
では
No.1
- 回答日時:
フォームの開く時のイベントで表示させたいレコードをクエリやSQLで抽出し、各項目をコントロールにセットします。
保存時は更新処理となります。
新規に追加する処理がVBAを使用していてSQLを使用していて、SQLでinsertステートメントで行っているのでしたら同じようにupdateステートメントにwhere句でレコードを指定し更新処理が掛けられます。
もし、addnewメソッド等でそのレコードに対して追加しているようでしたら、更新したいレコードに対するレコードセットを作成しそのレコードに対してeditメソッドを使用し、updateメソッドで更新を掛けられます。
また元々追加クエリで追加しているようでしたら、更新クエリを作成しクエリの抽出条件をフォーム上に有るキー項目として、値をビルドで各フォームの値にしてあげれば出来ると思います。
ざっと考えてこの3種類が有ります。
この回答への補足
アドバイスありがとうございました。
保存用の総合テーブルがあり、最初に保存した時に返却フィールドに”1”を入力して保存しています。
2度目に座席コードを入力用テキストボックスに入力した時に返却フィールドの”1”の場合の座席コードが一致したレコードの終了時間フィールドに時間をいれて2回目の保存の時に返却フィールドを”2”に書き換えて保存したいのですが、どのようなコードになるかサンプルだけでも教えていただけないでしょうか?今のコードは下記のとおりです。
Public Sub 保存処理2()
Dim rst As New ADODB.Recordset
Set rst = New ADODB.Recordset
rst.Open "総合", _
CurrentProject.Connection, adOpenKeyset, adLockOptimistic
rst.AddNew
rst![日付] = Date
rst![学生番号] = Me.学生番号
rst![氏名] = Me.氏名
rst![受付時間] = Me.受付時間
rst![終了時間] = Me.終了時間
rst![座席コード] = Me.座席コード
rst![座席番号] = Me.座席番号
rst![性別] = Me.性別
rst![履修] = Me.r.Value
rst![ホームページ] = Me.h.Value
rst![電子メール] = Me.m.Value
rst![レポート作成] = Me.re.Value
rst![就職利用] = Me.j.Value
rst![その他] = Me.o.Value
rst![mo] = Me.mo.Value
rst![プリンター] = Me.pri.Value
rst![スキャナ] = Me.scan.Value
rst![zip] = Me.zip.Value
rst![返却] = "1"
rst.Update
rst.Close
Set rst = Nothing
Me.入力用テキストボックス = ""
Me.学生番号 = ""
Me.受付時間 = ""
Me.氏名 = ""
Me.座席コード = ""
Me.座席番号 = ""
Me.性別 = ""
Me.終了時間 = ""
Me.r.Value = False
Me.h.Value = False
Me.m.Value = False
Me.re.Value = False
Me.j.Value = False
Me.o.Value = False
Me.mo.Value = False
Me.scan.Value = False
Me.pri.Value = False
Me.zip.Value = False
入力用テキストボックス.SetFocus
End Sub
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Access(アクセス) Access 登録ボタンからサブフォームの更新 1 2022/07/22 10:23
- Access(アクセス) accessについて(超初心者です) 1 2023/02/11 11:18
- Access(アクセス) AccessVBAで降順にするテーブル作成クエリを使用して作成したテーブルを削除し同一のテーブル作成 1 2023/01/06 11:17
- Access(アクセス) アクセスの更新クエリでカレントレコードのみ更新したい 1 2022/06/02 23:32
- Access(アクセス) Access2016でフォーム内にExcelの複数シートを 表示させるイメージで複数テーブルの デー 1 2022/11/25 15:30
- JavaScript javascriptでテーブルに追加した項目のid追加してローカルストレージを操作したい 5 2023/01/01 15:52
- Access(アクセス) Accessテーブルの結合で別々のテーブルのフィールドを組み合わせて値を出す方法について 2 2022/07/20 19:43
- PHP PHPで入力フォームでデータを確認表示画面まで送る流れを日本語で理解したいのです。 1 2023/05/29 19:12
- Access(アクセス) Access VBA 1 2023/03/04 15:03
- PHP php 確認表示画面で値をSESSIONから取り出す理由の解釈は正しいでしょうか? 1 2023/06/09 17:39
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
レコードを保存するコード ア...
-
新規レコード行を非表示にしたい
-
アクセスでフォームビューがみ...
-
レコード削除時に(サブ)フォー...
-
Access2010、値を入力したら自...
-
アクセスの自動保存解除はでき...
-
ACCESSでフォームを使って、テ...
-
フィルタ後のフォームの件数の...
-
ACCESSフォームのリストボック...
-
アクセス:フォーム入力で、最...
-
レコードの移動
-
Accessでフォーム上に 直前の...
-
Access 更新キャンセルするには?
-
Access2000 フォームビューの表...
-
accessのフォームのレコードの移動
-
ACCESSのクエリで抽出したデー...
-
Accessで上の行を自動でコピー...
-
AccessVBA RecordSourceのリセ...
-
データベースのINT型項目にNULL...
-
Access レポート印刷するときに...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
レコードを保存するコード ア...
-
新規レコード行を非表示にしたい
-
アクセスでフォームビューがみ...
-
レコード削除時に(サブ)フォー...
-
Accessで上の行を自動でコピー...
-
AccessVBA RecordSourceのリセ...
-
アクセスのフォームで立ち上げ...
-
ACCESSフォームのリストボック...
-
アクセスの自動保存解除はでき...
-
アクセス:フォーム入力で、最...
-
Accessで一件の新規レコードの...
-
フィルタ後のフォームの件数の...
-
アクセス データの競合を非表...
-
Access:フォームプロパティ「...
-
Access2010、値を入力したら自...
-
レコードをダブルクリックする...
-
Accessでのデータ消滅に...
-
ACCESSでフォームを使って、テ...
-
Accessでフォーム上に 直前の...
-
アクセスでの警告について教え...
おすすめ情報