Database クラス
データベースメソッド
Database のメソッドは次のとおりです。すべてのメソッドが静的です。
convertLead(leadToConvert, allOrNone)
署名
public static Database.LeadConvertResult convertLead(Database.LeadConvert leadToConvert, Boolean allOrNone)
パラメータ
- leadToConvert
- 型: Database.LeadConvert
- allOrNone
- 型: Boolean
- (省略可能) allOrNone パラメータは、操作で部分的な完了を許可するかどうかを指定します。このパラメータを false に設定した場合、レコードが失敗しても、残りの DML 操作を正常に完了できます。このメソッドは、どのレコードが成功または失敗したか、およびその理由の確認に使用できる結果オブジェクトを返します。パラメータが設定されていないか true に設定されている場合、メソッドが失敗すると例外が発生します。
戻り値
convertLead(leadsToConvert, allOrNone)
署名
public static Database.LeadConvertResult[] convertLead(Database.LeadConvert[] leadsToConvert, Boolean allOrNone)
パラメータ
- leadsToConvert
- 型: Database.LeadConvert[]
- allOrNone
- 型: Boolean
- (省略可能) allOrNone パラメータは、操作で部分的な完了を許可するかどうかを指定します。このパラメータを false に設定した場合、レコードが失敗しても、残りの DML 操作を正常に完了できます。このメソッドは、どのレコードが成功または失敗したか、およびその理由の確認に使用できる結果オブジェクトを返します。パラメータが設定されていないか true に設定されている場合、メソッドが失敗すると例外が発生します。
戻り値
使用方法
convertLead メソッドは、最大 100 の LeadConvert オブジェクトを受け入れます。
実行された各 convertLead メソッドは、DML ステートメントのガバナ制限に含まれます。
delete(recordToDelete, allOrNone)
署名
public static Database.DeleteResult delete(SObject recordToDelete, Boolean allOrNone)
パラメータ
戻り値
delete(recordsToDelete, allOrNone)
署名
public static Database.DeleteResult[] delete(SObject[] recordsToDelete, Boolean allOrNone)
パラメータ
戻り値
使用方法
delete は、SOAP API の delete() ステートメントに類似しています。
実行された各 delete メソッドは、DML ステートメントのガバナ制限に含まれます。
例
1Account[] doomedAccts = [SELECT Id, Name FROM Account WHERE Name = 'DotCom'];
2Database.DeleteResult[] DR_Dels = Database.delete(doomedAccts);delete(recordID, allOrNone)
署名
public static Database.DeleteResult delete(ID recordID, Boolean allOrNone)
パラメータ
戻り値
使用方法
delete は、SOAP API の delete() ステートメントに類似しています。
実行された各 delete メソッドは、DML ステートメントのガバナ制限に含まれます。
delete(recordIDs, allOrNone)
署名
public static Database.DeleteResult[] delete(ID[] recordIDs, Boolean allOrNone)
パラメータ
戻り値
使用方法
delete は、SOAP API の delete() ステートメントに類似しています。
実行された各 delete メソッドは、DML ステートメントのガバナ制限に含まれます。
deleteAsync(sobjects, callback)
署名
public static List<Database.DeleteResult> deleteAsync(List<SObject> sobjects, DataSource.AsyncDeleteCallback callback)
パラメータ
- sobjects
- 型: List<SObject>
- 削除する外部オブジェクトレコードのリスト。
- callback
- 型: DataSource.AsyncDeleteCallback
- 元のコンテキストの状態と挿入操作の完了後に実行されるアクション (processDelete メソッド) を含むコールバック。このアクションのコールバックを使用して、操作の結果を基に組織のデータを更新します。コールバックオブジェクトは DataSource.AsyncDeleteCallback を拡張する必要があります。
戻り値
型: List<Database.DeleteResult>
削除操作の状況の結果。各結果は、この非同期操作で処理されたレコードに対応し、一意の識別子 (asyncLocator) に関連付けられます。asyncLocator 値は、結果のエラー配列に含まれます。この識別子は Database.getAsyncLocator() で取得できます。Database.getAsyncDeleteResult() を使用して最終結果を取得します。
deleteAsync(sobject, callback)
署名
public static Database.DeleteResult deleteAsync(SObject sobject, DataSource.AsyncDeleteCallback callback)
パラメータ
- sobject
- 型: SObject
- 削除する外部オブジェクトレコード。
- callback
- 型: DataSource.AsyncDeleteCallback
- 元のコンテキストの状態と挿入操作の完了後に実行されるアクション (processDelete メソッド) を含むコールバック。このアクションのコールバックを使用して、操作の結果を基に組織のデータを更新します。コールバックオブジェクトは DataSource.AsyncDeleteCallback を拡張する必要があります。
deleteAsync(sobjects)
署名
public static List<Database.DeleteResult> deleteAsync(List<SObject> sobjects)
パラメータ
- sobjects
- 型: List<SObject>
- 削除する外部オブジェクトレコードのリスト。
戻り値
型: List<Database.DeleteResult>
削除操作の状況の結果。各結果は、この非同期操作で処理されたレコードに対応し、一意の識別子 (asyncLocator) に関連付けられます。asyncLocator 値は、結果のエラー配列に含まれます。この識別子は Database.getAsyncLocator() で取得できます。Database.getAsyncDeleteResult() を使用して最終結果を取得します。
deleteAsync(sobject)
署名
public static Database.DeleteResult deleteAsync(SObject sobject)
パラメータ
- sobject
- 型: SObject
- 削除する外部オブジェクトレコード。
戻り値
削除操作の状況の結果。結果は、この非同期操作で処理されたレコードに対応し、一意の識別子 (asyncLocator) に関連付けられます。asyncLocator 値は、結果のエラー配列に含まれます。この識別子は Database.getAsyncLocator() で取得できます。Database.getAsyncDeleteResult() を使用して最終結果を取得します。
deleteImmediate(sobjects)
署名
public static List<Database.DeleteResult> deleteImmediate(List<SObject> sobjects)
パラメータ
- sobjects
- 型: List<SObject>
- 削除する外部オブジェクトレコードのリスト。
使用方法
deleteImmediate() を使用する Big Object のバッチ制限は、一度に 50,000 レコードです。
deleteImmediate(sobject)
署名
public static Database.DeleteResult deleteImmediate(SObject sobject)
パラメータ
- sobject
- 型: SObject
- 削除する外部オブジェクトレコード。
emptyRecycleBin(recordIds)
署名
public static Database.EmptyRecycleBinResult[] emptyRecycleBin(ID [] recordIds)
パラメータ
- recordIds
- 型: ID[]
戻り値
使用方法
次の点に注意してください。
- このメソッドを使用してレコードが削除されると、復元することはできません。
- 削除対象として指定できるのは 10,000 件のレコードのみです。
- ログインユーザは、自身のごみ箱にあるレコード、または、下位のごみ箱にあるレコードの中でクエリ可能なものはすべて削除できます。ログインユーザが「すべてのデータの編集」権限を持っている場合、組織内のすべてのごみ箱のレコードに対するクエリと削除を実行できます。
- カスケード削除レコード ID は ID のリストに含めないでください。リストに含めるとエラーが発生します。たとえば、取引先レコードが削除されると、関連するすべての取引先責任者、商談、契約なども削除されます。最上位の取引先の ID のみを含めるようにしてください。関連するレコードはすべて自動的に削除されます。
- DML ステートメントによって処理された項目の数に、削除された項目が追加され、発行された DML ステートメントの合計数にメソッドコールが追加されます。実行された各 emptyRecycleBin メソッドは、DML ステートメントのガバナ制限に含まれます。
emptyRecycleBin(obj)
署名
public static Database.EmptyRecycleBinResult emptyRecycleBin(sObject obj)
パラメータ
- obj
- 型: sObject
使用方法
次の点に注意してください。
- このメソッドを使用して sObject が削除されると、復元することはできません。
- 削除対象として指定できるのは 10,000 件の sObject のみです。
- ログインユーザは、自身のごみ箱または下位ユーザのごみ箱にある (クエリ可能な) すべての sObject を削除できます。ログインユーザが「すべてのデータの編集」権限を持っている場合、組織内のすべてのごみ箱の sObject に対するクエリと削除を実行できます。
- カスケード削除によって削除された sObject は含めないでください。含めるとエラーが発生します。たとえば、取引先が削除されると、関連するすべての取引先責任者、商談、契約なども��除されます。最上位の取引先の sObject のみを含めるようにしてください。関連する sObject はすべて自動的に削除されます。
emptyRecycleBin(listOfSObjects)
署名
public static Database.EmptyRecycleBinResult[] emptyRecycleBin(sObject[] listOfSObjects)
パラメータ
- listOfSObjects
- 型: sObject[]
戻り値
使用方法
次の点に注意してください。
- このメソッドを使用して sObject が削除されると、復元することはできません。
- 削除対象として指定できるのは 10,000 件の sObject のみです。
- ログインユーザは、自身のごみ箱または下位ユーザのごみ箱にある (クエリ可能な) すべての sObject を削除できます。ログインユーザが「すべてのデータの編集」権限を持っている場合、組織内のすべてのごみ箱の sObject に対するクエリと削除を実行できます。
- カスケード削除によって削除された sObject は含めないでください。含めるとエラーが発生します。たとえば、取引先が削除されると、関連するすべての取引先責任者、商談、契約なども削除されます。最上位の取引先の sObject のみを含めるようにしてください。関連する sObject はすべて自動的に削除されます。
executeBatch(batchClassObject)
署名
public static ID executeBatch(Object batchClassObject)
パラメータ
- batchClassObject
- 型: Object
- Database.Batchable インターフェースを実装するクラスのインスタンス。
使用方法
このメソッドをコールすると、Salesforce では、一括処理クラスの start メソッドが返すレコードを 200 個のバッチに分割し、各バッチを execute メソッドに渡します。Apex ガバナ制限は、execute の各実行でリセットされます。
詳細は、「Apex の一括処理の使用」を参照してください。
バージョン管理動作の変更
executeBatch コールで Apex Flex キューロックを取得できなかった場合は、次のようになります。
- API バージョン 52.0 以降の場合は、System.AsyncException が発生します。
- API バージョン 51.0 以前の場合は、例外が発生するのではなく、空の ID 「000000000000000」が返されます。
executeBatch(batchClassObject, scope)
署名
public static ID executeBatch(Object batchClassObject, Integer scope)
パラメータ
- batchClassObject
- 型: Object
- Database.Batchable インターフェースを実装するクラスのインスタンス。
- scope
- 型: Integer
- 一括処理の execute メソッドに渡すレコードの数。
使用方法
scope の値は 0 より大きくします。
一括処理クラスの start メソッドが Database.QueryLocator を返す場合、Database.executeBatch の scope パラメータには最大値 2,000 を指定できます。これより大きい値に設定すると、Salesforce では、QueryLocator が返すレコードを、最大 200 レコードまでの、より小さいバッチに分割します。一括処理クラスの start メソッドが Iterable を返す場合、scope パラメータ値に上限はありませんが、非常に大きい値を使用すると、他の制限が発生する場合があります。
Apex ガバナ制限は、execute の各実行でリセットされます。
詳細は、「Apex の一括処理の使用」を参照してください。
バージョン管理動作の変更
executeBatch コールで Apex Flex キューロックを取得できなかった場合は、次のようになります。
- API バージョン 52.0 以降の場合は、System.AsyncException が発生します。
- API バージョン 51.0 以前の場合は、例外が発生するのではなく、空の ID 「000000000000000」が返されます。
getAsyncDeleteResult(deleteResult)
署名
public static Database.DeleteResult getAsyncDeleteResult(Database.DeleteResult deleteResult)
パラメータ
- deleteResult
- 型: Database.DeleteResult
- 取得する削除操作の結果レコード。
getAsyncDeleteResult(asyncLocator)
署名
public static Database.DeleteResult getAsyncDeleteResult(String asyncLocator)
パラメータ
- asyncLocator
- 型: String
- 非同期操作の結果に関連付けられる一意の識別子。
getAsyncSaveResult(saveResult)
署名
public static Database.SaveResult getAsyncSaveResult(Database.SaveResult saveResult)
パラメータ
- saveResult
- 型: Database.SaveResult
- 取得する挿入または更新操作の結果レコード。
getAsyncSaveResult(asyncLocator)
署名
public static Database.SaveResult getAsyncSaveResult(String asyncLocator)
パラメータ
- asyncLocator
- 型: String
- 非同期操作の結果に関連付けられる一意の識別子。
getDeleted(sObjectType, startDate, endDate)
署名
public static Database.GetDeletedResult getDeleted(String sObjectType, Datetime startDate, Datetime endDate)
パラメータ
戻り値
使用方法
ごみ箱ではレコードを最長 15 日間保持するため、コールが実行された日から 15 日以内の結果が返されます (システム管理者がごみ箱の中身を消去した場合、期間が短くなる場合があります)。
例
1Database.GetDeletedResult r =
2 Database.getDeleted(
3 'Merchandise__c',
4 Datetime.now().addHours(-1),
5 Datetime.now());getQueryLocator(listofQueries)
署名
public static Database. QueryLocator getQueryLocator(sObject [] listOfQueries)
パラメータ
- listOfQueries
- 型: sObject[]
戻り値
使用方法
集計関数が含まれるクエリで getQueryLocator を使用することはできません。
実行された各 getQueryLocator メソッドは、取得されるレコードの合計数と発行される SOQL クエリの合計数である 10,000 のガバナ制限に含まれます。
詳細は、「Apex による共有管理について」および「IdeaStandardSetController クラス」を参照してください。
getQueryLocator(query)
署名
public static Database.QueryLocator getQueryLocator(String query)
パラメータ
- query
- 型: String
戻り値
使用方法
集計関数が含まれるクエリで getQueryLocator を使用することはできません。
実行された各 getQueryLocator メソッドは、取得されるレコードの合計数と発行される SOQL クエリの合計数である 10,000 のガバナ制限に含まれます。
詳細は、「Apex による共有管理について」および「StandardSetController クラス」を参照してください。
getUpdated(sobjectType, startDate, endDate)
署名
public static Database.GetUpdatedResult getUpdated(String sobjectType, Datetime startDate, Datetime endDate)
パラメータ
戻り値
使用方法
返される結果の日付の範囲は、コールが実行された日から 30 日以内です。
例
1Database.GetUpdatedResult r =
2 Database.getUpdated(
3 'Merchandise__c',
4 Datetime.now().addHours(-1),
5 Datetime.now());insert(recordToInsert, allOrNone)
署名
public static Database.SaveResult insert(sObject recordToInsert, Boolean allOrNone)
パラメータ
戻り値
使用方法
insert は SQL の INSERT ステートメントに類似しています。
項目に割り当てた文字列値が長すぎる場合、API バージョン 15.0 以降を使用して保存 (コンパイル) した Apex クラスとトリガにはランタイムエラーが発生します。
実行された各 insert メソッドは、DML ステートメントのガバナ制限に含まれます。
insert(recordsToInsert, allOrNone)
署名
public static Database.SaveResult[] insert(sObject[] recordsToInsert, Boolean allOrNone)
パラメータ
戻り値
型: Database.SaveResult[]
使用方法
insert は SQL の INSERT ステートメントに類似しています。
項目に割り当てた文字列値が長すぎる場合、API バージョン 15.0 以降を使用して保存 (コンパイル) した Apex クラスとトリガにはランタイムエラーが発生します。
実行された各 insert メソッドは、DML ステートメントのガバナ制限に含まれます。
例
例:
1Account a = new Account(name = 'Acme1');
2Database.SaveResult[] lsr = Database.insert(
3 new Account[]{a, new Account(Name = 'Acme2')},
4 false);insert(recordToInsert, dmlOptions)
署名
public static Database.SaveResult insert(sObject recordToInsert, Database.DMLOptions dmlOptions)
パラメータ
- recordToInsert
- 型: sObject
- dmlOptions
- 型: Database.DMLOptions
- (省略可能) dmlOptions パラメータは、レコード挿入時にエラーが発生した場合の割り当てルールの情報やロールバック動作など、トランザクションの追加データを指定します。
戻り値
使用方法
insert は SQL の INSERT ステートメントに類似しています。
項目に割り当てた文字列値が長すぎる場合、API バージョン 15.0 以降を使用して保存 (コンパイル) した Apex クラスとトリガにはランタイムエラーが発生します。
実行された各 insert メソッドは、DML ステートメントのガバナ制限に含まれます。
insert(recordsToInsert, dmlOptions)
署名
public static Database.SaveResult insert(sObject[] recordsToInsert, Database.DMLOptions dmlOptions)
パラメータ
- recordsToInsert
- 型: sObject[]
- dmlOptions
- 型: Database.DMLOptions
- (省略可能) dmlOptions パラメータは、レコード挿入時にエラーが発生した場合の割り当てルールの情報やロールバック動作など、トランザクションの追加データを指定します。
戻り値
型: Database.SaveResult[]
insertAsync(sobjects, callback)
署名
public static List<Database.SaveResult> insertAsync(List<SObject> sobjects, DataSource.AsyncSaveCallback callback)
パラメータ
- sobjects
- 型: List<SObject>
- 挿入する外部オブジェクトレコードのリスト。
- callback
- 型: DataSource.AsyncSaveCallback
- 元のコンテキストの状態と挿入操作の完了後に実行するアクション (processSave メソッド) を含むコールバックオブジェクト。このアクションのコールバックを使用して、操作の結果を基に組織のデータを更新します。コールバックオブジェクトは DataSource.AsyncSaveCallback を拡張する必要があります。
戻り値
型: List<Database.SaveResult>
挿入操作の状況の結果。各結果は、この非同期操作で処理されたレコードに対応し、一意の識別子 (asyncLocator) に関連付けられます。asyncLocator 値は、結果のエラー配列に含まれます。この識別子は Database.getAsyncLocator() で取得できます。Database.getAsyncSaveResult() を使用して最終結果を取得します。
使用方法
ポータルユーザがコミュニティメンバーの場合でも、Database.insertAsync() メソッドをポータルユーザのコンテキストで実行することはできません。Apex で外部オブジェクトレコードを追加するには、Database.insertImmediate() メソッドを使用します。
insertAsync(sobject, callback)
署名
public static Database.SaveResult insertAsync(SObject sobject, DataSource.AsyncSaveCallback callback)
パラメータ
- sobject
- 型: SObject
- 挿入する外部オブジェクトレコード。
- callback
- 型: DataSource.AsyncSaveCallback
- 元のコンテキストの状態と挿入操作の完了後に実行するアクション (processSave メソッド) を含むコールバックオブジェクト。このアクションのコールバックを使用して、操作の結果を基に組織のデータを更新します。コールバックオブジェクトは DataSource.AsyncSaveCallback を拡張する必要があります。
戻り値
挿入操作の状況の結果。結果は、この非同期操作で処理されたレコードに対応し、一意の識別子 (asyncLocator) に関連付けられます。asyncLocator 値は、結果のエラー配列に含まれます。この識別子は Database.getAsyncLocator() で取得できます。Database.getAsyncSaveResult() を使用して最終結果を取得します。
使用方法
ポータルユーザがコミュニティメンバーの場合でも、Database.insertAsync() メソッドをポータルユーザのコンテキストで実行することはできません。Apex で外部オブジェクトレコードを追加するには、Database.insertImmediate() メソッドを使用します。
insertAsync(sobjects)
署名
public static List<Database.SaveResult> insertAsync(List<SObject> sobjects)
パラメータ
- sobjects
- 型: List<SObject>
- 挿入する外部オブジェクトレコードのリスト。
戻り値
型: List<Database.SaveResult>
挿入操作の状況の結果。各結果は、この非同期操作で処理されたレコードに対応し、一意の識別子 (asyncLocator) に関連付けられます。asyncLocator 値は、結果のエラー配列に含まれます。この識別子は Database.getAsyncLocator() で取得できます。Database.getAsyncSaveResult() を使用して最終結果を取得します。
使用方法
ポータルユーザがコミュニティメンバーの場合でも、Database.insertAsync() メソッドをポータルユーザのコンテキストで実行することはできません。Apex で外部オブジェクトレコードを追加するには、Database.insertImmediate() メソッドを使用します。
insertAsync(sobject)
署名
public static Database.SaveResult insertAsync(SObject sobject)
パラメータ
- sobject
- 型: SObject
- 挿入する外部オブジェクトレコード。
戻り値
挿入操作の状況の結果。結果は、この非同期操作で処理されたレコードに対応し、一意の識別子 (asyncLocator) に関連付けられます。asyncLocator 値は、結果のエラー配列に含まれます。この識別子は Database.getAsyncLocator() で取得できます。Database.getAsyncSaveResult() を使用して最終結果を取得します。
使用方法
ポータルユーザがコミュニティメンバーの場合でも、Database.insertAsync() メソッドをポータルユーザのコンテキストで実行することはできません。Apex で外部オブジェクトレコードを追加するには、Database.insertImmediate() メソッドを使用します。
insertImmediate(sobjects)
署名
public static List<Database.SaveResult> insertImmediate(List<SObject> sobjects)
パラメータ
- sobjects
- 型: List<SObject>
- 挿入する外部オブジェクトレコードのリスト。
使用方法
部分的な完了が操作で許可されます。1 つ以上のレコード挿入が失敗した場合でも、例外は発生せず、残りの DML 操作を完了することができます。返された SaveResult オブジェクトは、操作が完了したかどうかを示します。完了しなかった場合、オブジェクトはエラーコードと説明も返します。
insertImmediate(sobject)
署名
public static Database.SaveResult insertImmediate(SObject sobject)
パラメータ
- sobject
- 型: SObject
- 挿入する外部オブジェクトレコード。
使用方法
レコード挿入が失敗しても例外は発生しません。返された SaveResult オブジェクトは、操作が完了したかどうかを示します。完了しなかった場合、オブジェクトはエラーコードと説明を返します。
merge(masterRecord, duplicateId)
署名
public static Database.MergeResult merge(sObject masterRecord, Id duplicateId)
パラメータ
戻り値
使用方法
実行された各 merge メソッドは、DML ステートメントのガバナ制限に含まれます。
merge(masterRecord, duplicateRecord)
署名
public static Database.MergeResult merge(sObject masterRecord, sObject duplicateRecord)
パラメータ
戻り値
使用方法
実行された各 merge メソッドは、DML ステートメントのガバナ制限に含まれます。
merge(masterRecord, duplicateIds)
署名
public static List<Database.MergeResult> merge(sObject masterRecord, List<Id> duplicateIds)
パラメータ
戻り値
使用方法
実行された各 merge メソッドは、DML ステートメントのガバナ制限に含まれます。
merge(masterRecord, duplicateRecords)
署名
public static List<Database.MergeResult> merge(sObject masterRecord, List<SObject> duplicateRecords)
パラメータ
戻り値
使用方法
実行された各 merge メソッドは、DML ステートメントのガバナ制限に含まれます。
merge(masterRecord, duplicateId, allOrNone)
署名
public static Database.MergeResult merge(sObject masterRecord, Id duplicateId, Boolean allOrNone)
パラメータ
戻り値
使用方法
実行された各 merge メソッドは、DML ステートメントのガバナ制限に含まれます。
merge(masterRecord, duplicateRecord, allOrNone)
署名
public static Database.MergeResult merge(sObject masterRecord, sObject duplicateRecord, Boolean allOrNone)
パラメータ
戻り値
使用方法
実行された各 merge メソッドは、DML ステートメントのガバナ制限に含まれます。
merge(masterRecord, duplicateIds, allOrNone)
署名
public static List<Database.MergeResult> merge(sObject masterRecord, List<Id> duplicateIds, Boolean allOrNone)
パラメータ
戻り値
使用方法
実行された各 merge メソッドは、DML ステートメントのガバナ制限に含まれます。
merge(masterRecord, duplicateRecords, allOrNone)
署名
public static List<Database.MergeResult> merge(sObject masterRecord, List<SObject> duplicateRecords, Boolean allOrNone)
パラメータ
戻り値
使用方法
実行された各 merge メソッドは、DML ステートメントのガバナ制限に含まれます。
rollback(databaseSavepoint)
署名
public static Void rollback(System.Savepoint databaseSavepoint)
パラメータ
- databaseSavepoint
- 型: System.Savepoint
戻り値
型: Void
使用方法
- 各ロールバックは、DML ステートメントのガバナ制限に含まれます。データベースをそれ以上の回数ロールバックしようとすると、ランタイムエラーが発生します。
- savepoint の設定後に挿入された sObject の ID は、ロールバック後にクリアされません。ロールバック後に挿入するには、sObject を作成します。ロールバック前に作成した変数を使用して sObject を挿入しようとすると、その sObject 変数には ID があるため失敗します。同じ変数を使用して sObject を更新または更新/挿入しようとした場合も、sObject はデータベース内に存在せず、更新できないため失敗します。
「トランザクションの制御」の例を参照してください。
setSavepoint()
署名
public static System.Savepoint setSavepoint()
戻り値
型: System.Savepoint
使用方法
- 複数の savepoint を設定し、生成した最新 savepoint ではない savepoint にロールバックすると、ロールバックされた savepoint 変数は無効になります。たとえば、最初に savepoint SP1 を生成し、次に savepoint SP2 を生成した場合、SP1 にロールバックすると、変数 SP2 は無効になります。その変数を使用しようとすると、ランタイムエラーが発生します。
- 各トリガ呼び出しが新しいトリガコンテキストであるため、savepoints への参照は、トリガ呼び出しを通過することはできません。静的変数として savepoint を宣言し、トリガコンテキスト全体で使用しようとすると、ランタイムエラーが発生します。
- 設定した各セーブポイントは、DML ステートメントのガバナ制限に含まれます。
「トランザクションの制御」の例を参照してください。
undelete(recordToUndelete, allOrNone)
署名
public static Database.UndeleteResult undelete(sObject recordToUndelete, Boolean allOrNone)
パラメータ
戻り値
使用方法
undelete は SQL の UNDELETE ステートメントに類似しています。
実行された各 undelete メソッドは、DML ステートメントのガバナ制限に含まれます。
undelete(recordsToUndelete, allOrNone)
署名
public static Database.UndeleteResult[] undelete(sObject[] recordsToUndelete, Boolean allOrNone)
パラメータ
戻り値
使用方法
undelete は SQL の UNDELETE ステートメントに類似しています。
実行された各 undelete メソッドは、DML ステートメントのガバナ制限に含まれます。
例
1Account[] savedAccts = [SELECT Id, Name FROM Account
2 WHERE Name = 'Universal Containers' ALL ROWS];
3Database.UndeleteResult[] UDR_Dels = Database.undelete(savedAccts);undelete(recordID, allOrNone)
署名
public static Database.UndeleteResult undelete(ID recordID, Boolean allOrNone)
パラメータ
戻り値
使用方法
undelete は SQL の UNDELETE ステートメントに類似しています。
実行された各 undelete メソッドは、DML ステートメントのガバナ制限に含まれます。
undelete(recordIDs, allOrNone)
署名
public static Database.UndeleteResult[] undelete(ID[] recordIDs, Boolean allOrNone)
パラメータ
戻り値
使用方法
undelete は SQL の UNDELETE ステートメントに類似しています。
実行された各 undelete メソッドは、DML ステートメントのガバナ制限に含まれます。
update(recordToUpdate, allOrNone)
署名
public static Database.SaveResult update(sObject recordToUpdate, Boolean allOrNone)
パラメータ
戻り値
使用方法
update は SQL の UPDATE ステートメントに類似しています。
項目に割り当てた文字列値が長すぎる場合、API バージョン 15.0 以降を使用して保存 (コンパイル) した Apex クラスとトリガにはランタイムエラーが発生します。
実行された各 update メソッドは、DML ステートメントのガバナ制限に含まれます。
例
1Account a = new Account(Name='SFDC');
2insert(a);
3
4Account myAcct =
5 [SELECT Id, Name, BillingCity
6 FROM Account WHERE Id = :a.Id];
7myAcct.BillingCity = 'San Francisco';
8
9Database.SaveResult SR =
10 Database.update(myAcct);update(recordsToUpdate, allOrNone)
署名
public static Database.SaveResult[] update(sObject[] recordsToUpdate, Boolean allOrNone)
パラメータ
戻り値
型: Database.SaveResult[]
使用方法
update は SQL の UPDATE ステートメントに類似しています。
実行された各 update メソッドは、DML ステートメントのガバナ制限に含まれます。
update(recordToUpdate, dmlOptions)
署名
public static Database.SaveResult update(sObject recordToUpdate, Database.DmlOptions dmlOptions)
パラメータ
- recordToUpdate
- 型: sObject
- dmlOptions
- 型: Database.DMLOptions
- (省略可能) dmlOptions パラメータは、レコード挿入時にエラーが発生した場合の割り当てルールの情報やロールバック動作など、トランザクションの追加データを指定します。
戻り値
使用方法
update は SQL の UPDATE ステートメントに類似しています。
項目に割り当てた文字列値が長すぎる場合、API バージョン 15.0 以降を使用して保存 (コンパイル) した Apex クラスとトリガにはランタイムエラーが発生します。
実行された各 update メソッドは、DML ステートメントのガバナ制限に含まれます。
update(recordsToUpdate, dmlOptions)
署名
public static Database.SaveResult[] update(sObject[] recordsToUpdate, Database.DMLOptions dmlOptions)
パラメータ
- recordsToUpdate
- 型: sObject[]
- dmlOptions
- 型: Database.DMLOptions
- (省略可能) dmlOptions パラメータは、レコード挿入時にエラーが発生した場合の割り当てルールの情報やロールバック動作など、トランザクションの追加データを指定します。
戻り値
型: Database.SaveResult[]
使用方法
update は SQL の UPDATE ステートメントに類似しています。
項目に割り当てた文字列値が長すぎる場合、API バージョン 15.0 以降を使用して保存 (コンパイル) した Apex クラスとトリガにはランタイムエラーが発生します。
実行された各 update メソッドは、DML ステートメントのガバナ制限に含まれます。
upsert(recordToUpsert, externalIdField, allOrNone)
署名
public static Database.UpsertResult upsert(sObject recordToUpsert, Schema.SObjectField externalIDField, Boolean allOrNone)
パラメータ
- recordToUpsert
- 型: sObject
- externalIdField
- 型: Schema.SObjectField
- (省略可能) externalIdField は Schema.SObjectField のデータ型、つまり項目トークンです。fields 特殊メソッドを使用して、項目のトークンを検索します。たとえば、Schema.SObjectField f = Account.Fields.MyExternalId です。externalIdField パラメータは、upsert() が sObject を既存のレコードと照合するために使用する項目です。この項目は、外部 ID としてマークされたカスタム項目か、idLookup 属性のある標準項目にすることができます。
- allOrNone
- 型: Boolean
- (省略可能) allOrNone パラメータは、操作で部分的な完了を許可するかどうかを指定します。このパラメータを false に設定した場合、レコードが失敗しても、残りの DML 操作を正常に完了できます。このメソッドは、どのレコードが成功または失敗したか、およびその理由の確認に使用できる結果オブジェクトを返します。パラメータが設定されていないか true に設定されている場合、メソッドが失敗すると例外が発生します。
戻り値
使用方法
項目に割り当てた文字列値が長すぎる場合、API バージョン 15.0 以降を使用して保存 (コンパイル) した Apex クラスとトリガにはランタイムエラーが発生します。
実行された各 upsert メソッドは、DML ステートメントのガバナ制限に含まれます。
更新/挿入操作の仕組みについて詳細は、「Upsert ステートメント」を参照してください。
upsert(recordsToUpsert, externalIdField, allOrNone)
署名
public static Database.UpsertResult[] upsert(sObject[] recordsToUpsert, Schema.SObjectField externalIdField, Boolean allOrNone)
パラメータ
- recordsToUpsert
- 型: sObject[]
- externalIdField
- 型: Schema.SObjectField
- (省略可能) externalIdField は Schema.SObjectField のデータ型、つまり項目トークンです。fields 特殊メソッドを使用して、項目のトークンを検索します。たとえば、Schema.SObjectField f = Account.Fields.MyExternalId です。externalIdField パラメータは、upsert() が sObject を既存のレコードと照合するために使用する項目です。この項目は、外部 ID としてマークされたカスタム項目か、idLookup 属性のある標準項目にすることができます。
- allOrNone
- 型: Boolean
- (省略可能) allOrNone パラメータは、操作で部分的な完了を許可するかどうかを指定します。このパラメータを false に設定した場合、レコードが失敗しても、残りの DML 操作を正常に完了できます。このメソッドは、どのレコードが成功または失敗したか、およびその理由の確認に使用できる結果オブジェクトを返します。パラメータが設定されていないか true に設定されている場合、メソッドが失敗すると例外が発生します。
戻り値
使用方法
項目に割り当てた文字列値が長すぎる場合、API バージョン 15.0 以降を使用して保存 (コンパイル) した Apex クラスとトリガにはランタイムエラーが発生します。
実行された各 upsert メソッドは、DML ステートメントのガバナ制限に含まれます。
更新/挿入操作の仕組みについて詳細は、「Upsert ステートメント」を参照してください。
updateAsync(sobjects, callback)
署名
public static List<Database.SaveResult> updateAsync(List<SObject> sobjects, DataSource.AsyncSaveCallback callback)
パラメータ
- sobjects
- 型: List<SObject>
- 変更する外部オブジェクトレコードのリスト。
- callback
- 型: DataSource.AsyncSaveCallback
- 元のコンテキストの状態と挿入操作の完了後に実行するアクション (processSave メソッド) を含むコールバックオブジェクト。このアクションのコールバックを使用して、操作の結果を基に組織のデータを更新します。コールバックオブジェクトは DataSource.AsyncSaveCallback を拡張する必要があります。
戻り値
型: List<Database.SaveResult>
更新操作の状況の結果。各結果は、この非同期操作で処理されたレコードに対応し、一意の識別子 (asyncLocator) に関連付けられます。asyncLocator 値は、結果のエラー配列に含まれます。この識別子は Database.getAsyncLocator() で取得できます。Database.getAsyncSaveResult() を使用して最終結果を取得します。
updateAsync(sobject, callback)
署名
public static Database.SaveResult updateAsync(SObject sobject, DataSource.AsyncSaveCallback callback)
パラメータ
- sobject
- 型: SObject
- 変更する外部オブジェクトレコード。
- callback
- 型: DataSource.AsyncSaveCallback
- 元のコンテキストの状態と挿入操作の完了後に実行するアクション (processSave メソッド) を含むコールバックオブジェクト。このアクションのコールバックを使用して、操作の結果を基に組織のデータを更新します。コールバックオブジェクトは DataSource.AsyncSaveCallback を拡張する必要があります。
戻り値
挿入操作の状況の結果。結果は、この非同期操作で処理されたレコードに対応し、一意の識別子 (asyncLocator) に関連付けられます。asyncLocator 値は、結果のエラー配列に含まれます。この識別子は Database.getAsyncLocator() で取得できます。Database.getAsyncSaveResult() を使用して最終結果を取得します。
updateAsync(sobjects)
署名
public static List<Database.SaveResult> updateAsync(List<SObject> sobjects)
パラメータ
- sobjects
- 型: List<SObject>
- 変更する外部オブジェクトレコードのリスト。
戻り値
型: List<Database.SaveResult>
更新操作の状況の結果。各結果は、この非同期操作で処理されたレコードに対応し、一意の識別子 (asyncLocator) に関連付けられます。asyncLocator 値は、結果のエラー配列に含まれます。この識別子は Database.getAsyncLocator() で取得できます。Database.getAsyncSaveResult() を使用して最終結果を取得します。
updateAsync(sobject)
署名
public static Database.SaveResult updateAsync(SObject sobject)
パラメータ
- sobject
- 型: SObject
- 変更する外部オブジェクトレコード。
updateImmediate(sobjects)
署名
public static List<Database.SaveResult> updateImmediate(List<SObject> sobjects)
パラメータ
- sobjects
- 型: List<SObject>
- 変更する外部オブジェクトレコードのリスト。
使用方法
部分的な完了が操作で許可されます。1 つ以上のレコード更新が失敗した場合でも、例外は発生せず、残りの DML 操作を完了することができます。返された SaveResult オブジェクトは、操作が完了したかどうかを示します。完了しなかった場合、オブジェクトはエラーコードと説明も返します。
updateImmediate(sobject)
署名
public static Database.SaveResult updateImmediate(SObject sobject)
パラメータ
- sobject
- 型: SObject
- 変更する外部オブジェクトレコード。
使用方法
レコード更新が失敗しても例外は発生しません。返された SaveResult オブジェクトは、操作が完了したかどうかを示します。完了しなかった場合、オブジェクトはエラーコードと説明を返します。