問題
「Account」オブジェクトには、取引先の業種(Industry)フィールドがあります。Apexを使用して、業種が「Technology」の取引先の名前と年間売上をコンソールに出力するクラスを作成してください。
この問題を解決することで、Apexでのデータの取得方法、文字列フィールドのフィルタリング、および複数のフィールドの出力方法を練習することができます。
問題解決のフレームワーク
- 目的の確認:
- 問題文から、業種が「Technology」の取引先の名前と年間売上をコンソールに出力することが目的であることを理解する。
- 必要なデータの特定:
- 取引先の名前(「Account」オブジェクトの「Name」項目)
- 取引先の年間売上(「Account」オブジェクトの「AnnualRevenue」項目)
- データの取得方法の検討:
- SalesforceのSOQLを使用してデータを取得する。
- 「Account」オブジェクトからデータを取得する際に、業種が「Technology」である条件をWHERE句で指定する。
- コードの構築:
- 必要なクラスとメソッドの定義を行う。
- SOQLクエリを使用して、必要なデータを取得するコードを書く。
- データの処理:
- 取得した「Account」オブジェクトのリストをfor文でループ処理する。
- 条件に合致するデータ(業種が「Technology」の取引先の名前と年間売上)をコンソールに出力する。
- コードの最終形:
- 全ての処理を組み合わせて、最終的なコードを完成させる。
解答例
public class AccountIndustryLogger {
public static void logTechnologyAccounts(){
List<Account> accounts = [SELECT Name, AnnualRevenue FROM Account WHERE Industry='Technology'];
for(Account acc : accounts){
System.debug('Account in Technology Industry: ' + acc.Name + ' with Revenue: ' + acc.AnnualRevenue);
}
}
}
解説
このクラスは、Salesforceの標準オブジェクト「Account」から業種(Industry)が「Technology」である取引先の名前と年間売上を取得し、それをコンソールに出力する目的で作成されています。
- クラスとメソッドの定義:
AccountIndustryLogger
という名前のクラスが定義されています。このクラス内に、logTechnologyAccounts
という静的メソッドが定義されています。このメソッドは、業種が「Technology」の取引先の名前と年間売上をコンソールに出力するためのものです。
- データの取得:
- この行は、Salesforceの標準オブジェクト「Account」から業種が「Technology」の取引先の名前と年間売上を取得するSOQLクエリを実行しています。取得したデータは、
accounts
という名前のリストに格納されます。
- この行は、Salesforceの標準オブジェクト「Account」から業種が「Technology」の取引先の名前と年間売上を取得するSOQLクエリを実行しています。取得したデータは、
List<Account> accounts = [SELECT Name, AnnualRevenue FROM Account WHERE Industry='Technology'];
- データの処理と出力:
- このforループは、取得した業種が「Technology」の取引先のデータを1つずつ処理するためのものです。
System.debug
メソッドを使用して、現在の取引先の名前と年間売上をコンソールに出力しています。
- このforループは、取得した業種が「Technology」の取引先のデータを1つずつ処理するためのものです。
for(Account acc : accounts){
System.debug('Account in Technology Industry: ' + acc.Name + ' with Revenue: ' + acc.AnnualRevenue);
}
解答例(解説付き)
public class AccountIndustryLogger {
public static void logTechnologyAccounts(){
// Salesforceの標準オブジェクト「Account」から業種が「Technology」の取引先の名前と年間売上を取得
List<Account> accounts = [SELECT Name, AnnualRevenue FROM Account WHERE Industry='Technology'];
// 取得したデータを1つずつ処理してコンソールに出力
for(Account acc : accounts){
System.debug('Account in Technology Industry: ' + acc.Name + ' with Revenue: ' + acc.AnnualRevenue);
}
}
}
次の問題へ
【Apex練習問題】第6問
問題 「Account」オブジェクトに関連する「Contact」オブジェクトがあります。Apexを使用して、取引先の名前と、その取引先に関連する取引先責任者の数をコンソールに出…
前の問題へ
【Apex練習問題】第4問
問題 「Account」オブジェクトには、取引先の年間売上(AnnualRevenue)フィールドがあります。Apexを使用して、年間売上が1,000万以上の取引先のみをコンソールに出力す…
1問目から復習する
【Apex練習問題】第1問
問題 Salesforceには、取引先の情報を管理する標準オブジェクト「Account」があります。このオブジェクトには、取引先の名前(Name)フィールドがあります。Apexを使用し…
コメント