Salesforceで親から子のレコードを取得するSOQL文を共有します。
targetList = [SELECT Id, (SELECT Id FROM Ko__r) FROM Oya__c ];
kinkun's blog
Salesforceで親から子のレコードを取得するSOQL文を共有します。
targetList = [SELECT Id, (SELECT Id FROM Ko__r) FROM Oya__c ];
SalesforceのApexトリガで、Updateの場合に、ワークフローによる該当オブジェクトの更新による、Apexトリガが二重で起動することがあります。
それによって、予期せぬ動きが発生する場合があります。
その防止対策として、Apexトリガのハンドラークラスに、static変数を使用して、初回起動かどうかをApexトリガが判断し、二重防止を回避する。
以下はサンプルです。
--- Apexトリガのハンドラクラス ---
public class ApexTriggerHandler {
public static boolean firstRun = true;
}
--- Apexトリガ ---
trigger ApexTestTrigger on TestObject__c (before update) {
if(p.firstRun==true){
system.debug('1回目の起動です。');
ApexTriggerHandler.firstRun=false;
}else{
system.debug('2回目の起動です。');
}
}
SalesforceのApexトリガでは、ガバナ制限することができません。
対応策としては、データローダでバッチサイズを調整してガバナ制限を対応する。
バッチサイズは、1トランザクションでのガバナ制限を超えないところに、設定する。
Salesforceの切り捨てについて共有します。
Decimal[] example = new Decimal[]{5.5, 1.1, -1.1, -2.7};
Long[] expected = new Long[]{5, 1, -1, -3};
for(integer x = 0; x < example.size(); x++){
System.debug(Math.floor(example[x]));
}
結果
5
1
-2
-3
Salesforceの四捨五入について共有します。
Decimal roundNumber = 10.4;
System.debug(roundNumber.setScale(0,RoundingMode.HALF_UP));
roundNumber = 10.5;
System.debug(roundNumber.setScale(0,RoundingMode.HALF_UP));
roundNumber = 10.6;
System.debug(roundNumber.setScale(0,RoundingMode.HALF_UP));
結果
10
11
11
salesforceのtry、cahch、ロールバックの例を共有します。
Savepoint sp = Database.setSavepoint();
try {
Merchandise__c m = new Merchandise__c();
insert m;
} catch(DmlException e) {
System.debug('The following exception has occurred: ' + e.getMessage());
Database.rollback(sp);
}
Visualforceでinputfieldでキャンセルボタン時には必須を適用させたくない場合に、以下の例で対応する。
<apex:commandButton action="{!cancel}" value="Cancel" immediate="true"/>
ポイントは、「immediate=”true”」パラメータで対応可能となります。
上記のパラメータがないと、キャンセルボタン押下時にも必須チェックが行われる。
Apexで月末日を計算するロジックを共有します。
date dateField = date.newInstance(1987, 12, 17);
Integer numberOfDays = Date.daysInMonth(dateField.year(), dateField.month());
Date lastDayOfMonth = Date.newInstance(dateField.year(), dateField.month(), numberOfDays);
system.debug('lastDayOfMonth:'+lastDayOfMonth);
Salesforceのデバッグログを一括削除する手順を共有します。
1.開発コンソルを開く
2.Query Editorにて、以下のSQL文を実行する。
select Id from ApexLog
3.Query Resultsに出力されたデバッグログIDを全選択して、「Delete Row」ボタン押下する。
そのほかの削除方法は以下です。
データローダで「デバッグログ」をExportしてDeleteする。
カスタム設定画面にて設定種別の選択肢としてリストを表示するための設定は以下です。
設定 > 検索 > スキーマ
検索結果で、スキーマ設定にて、
リストカスタム設定の種別を管理を有効化します。