Recordset2.AddNew メソッド (DAO)
適用先: Access 2013、Office 2013
更新可能な Recordset2 オブジェクトの新しいレコードを作成します。
構文
式 .AddNew
式Recordset2 オブジェクトを表す変数。
注釈
AddNew メソッドは、レコードセット名で指定された Recordset2 オブジェクトに新しいレコードを作成および追加するために使用します。 このメソッドでは、フィールドが既定値に設定されますが、既定値が指定されていない場合、フィールドは Null (テーブル タイプの Recordset2 に指定されている既定値) に設定されます。
新しいレコードを追加した後は、 Update メソッドを使用して、変更を保存し、レコードを Recordset2 に追加します。 Update メソッドを使用しない限り、変更はデータベースに反映されません。
注:
[!メモ] AddNew の実行後、 Update を使用せずに他のレコードへ移動する操作を行った場合、変更は警告なしに取り消されます。 さらに、 Recordset2 を終了した場合や、 Recordset2 またはその Database オブジェクトが宣言されているプロシージャを終了した場合、新しいレコードは警告なしに破棄されます。
注:
[!メモ] Microsoft Access ワークスペースで AddNew を使用する場合に、データベース エンジンでカレント レコードを保持するために新しいページを作成する必要がある場合は、ページのロック状態は排他的となります。 一方、新しいレコードが既存のページに収まる場合は、ページのロック状態は共有的となります。
Recordset2 の最後のレコードに移動していない場合、他のプロセスによってベース テーブルに追加されたレコードがカレント レコードよりも後ろにある場合は、それらのレコードが含まれる場合があります。 しかし、独自の Recordset2 オブジェクトにレコードを追加する場合は、レコードはその Recordset2 の他に基になるテーブルにも追加されるため、新しく作成される Recordset2 オブジェクトにも含まれます。
新しいレコードの位置は、 Recordset2 の種類によって異なります。
ダイナセット タイプの Recordset2 オブジェクトでは、 Recordset を開いたときに有効になっている並べ替え規則や順序規則にかかわらず、 Recordset の末尾に挿入されます。
Index プロパティが設定されているテーブル タイプの Recordset2 オブジェクトでは、レコードは並べ替え順序の適切な位置に挿入されて返されます。 Index プロパティが設定されていない場合、新しいレコードは Recordset の末尾に挿入されて返されます。
AddNew を使用する前にカレント レコードであったレコードは、そのままカレント レコードとなります。 新しいレコードをカレント レコードにするには、 Bookmark プロパティを LastModified プロパティの設定で指定されたブックマークに設定します。
注:
[!メモ] レコードを追加、編集、削除するには、基になるデータ ソースのレコードに一意のインデックスが存在している必要があります。 一意のインデックスが存在しない場合、Microsoft Access ワークスペースでは AddNew、Delete、または Editメソッドを呼び出したときに「アクセスが拒否されました」のエラーが発生します。
例
この例では、 AddNew メソッドを使用して、指定した名前を持つ新しいレコードを作成します。 このプロシージャを実行するには、AddName 関数が必要です。
Sub AddNewX()
Dim dbsNorthwind As Database
Dim rstEmployees As Recordset2
Dim strFirstName As String
Dim strLastName As String
Set dbsNorthwind = OpenDatabase("Northwind.mdb")
Set rstEmployees = _
dbsNorthwind.OpenRecordset("Employees", dbOpenDynaset)
' Get data from the user.
strFirstName = Trim(InputBox( _
"Enter first name:"))
strLastName = Trim(InputBox( _
"Enter last name:"))
' Proceed only if the user actually entered something
' for both the first and last names.
If strFirstName <> "" and strLastName <> "" Then
' Call the function that adds the record.
AddName rstEmployees, strFirstName, strLastName
' Show the newly added data.
With rstEmployees
Debug.Print "New record: " & !FirstName & _
" " & !LastName
' Delete new record because this is a demonstration.
.Delete
End With
Else
Debug.Print _
"You must input a string for first and last name!"
End If
rstEmployees.Close
dbsNorthwind.Close
End Sub
Function AddName(rstTemp As Recordset2, _
strFirst As String, strLast As String)
' Adds a new record to a recordset using the data passed
' by the calling procedure. The new record is then made
' the current record.
With rstTemp
.AddNew
!FirstName = strFirst
!LastName = strLast
.Update
.Bookmark = .LastModified
End With
End Function