19
9

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 5 years have passed since last update.

Salesforce 選択リストのラベルとAPI参照名の分離について

Last updated at Posted at 2017-02-08

Spring'17(API39.0)では選択リストの各リスト値のラベル名とAPI名が分離するとのこと。
https://releasenotes.docs.salesforce.com/ja-jp/spring17/release-notes/rn_forcecom_picklists_ui_and_api_labels.htm

USの本家ブログでもメタデータの変更など説明されている。
https://developer.salesforce.com/blogs/developer-relations/2017/01/keeping-picklist-integrations-safe-using-api-names.html

今までは値しかなかったので、リスト値を変えるとインテグレーション等に影響が出てしまうという課題があって、そのために各リスト値をラベルとAPI名に分けるということだ。
それは別に良いし、むしろそうあるべきだと思う。
ただ、ちょっと動きが気になっている。

まず既存の選択リスト値がバージョンアップでどうなるかというと、ラベルとAPI名はまったく同じになっていた。
なので、これから書くこともラベルとAPI名が同じであればただちに影響はないと思われる。

次に分離の目的通り、ラベル名とAPI名を分けた選択リストを作った場合どうなるか。
例えばこんな感じ。
picklist.png

#表示系
この時、選択リストの値がどう取れるのか。

##標準UI
picklist2.png
表示はラベル名となる。

##レポート
picklist3.png
これもラベル名が出る。
ちなみにExcel,csvのエクスポートもラベル名だ。

##DataLoader
picklist4.png
ここはラベル名ではなくAPI名。

##SOQL
picklist5.png
ここもAPI名だ。

ただし、toLabel()を付ければラベル名が返ってくる。

##Apex

List<Obj1__c> records = [select Status__c from Obj1__c];
for(Obj1__c rec : records){
    System.debug(rec.Status__c);
}

picklist6.png
SOQLのクエリ結果を出すので当然ながらAPI名だ。

##表示系のまとめ

箇所 取れる値
標準UI ラベル名
レポート ラベル名
DataLoader API名
SOQL API名
SOQL(toLabel) ラベル名
Apex API名

こうなる。
つまりユーザの目の触れるようなところではラベル名で、開発やインテグレーションではAPI名ということだろうか。

今まではラベル名しかなかったのでそのまま表示していればよかったのだが、これからはSOQLやDataLoaderで選択リストを取得したら、ユーザに表示する場合はラベル名に変換する必要が出てくる。
ApexであればtoLabelを使えば何とかなるが、DataLoaderとかどうするんだろうね。

と、ここまで書いてふと思ったが「DataLoaderでもtoLabel付ければいいじゃないか!」と閃いたけどダメだった。
image
ざんねん。

#更新系
ついでに更新系も確認してみた。
更新系は項目の「値セットで定義された値に選択リストを制限します」のチェックによって動きが変わってくる。
image
これは定義された値以外は保存を許可しない、というフラグだ。
以下、定義のみフラグと勝手に呼ぶ。

##標準UI
キャプチャは省略するが、当然ながらラベル名で選択・保存する。
定義のみフラグがどちらの場合でも、定義されたものしか表示・選択されないので関係ない。

##DataLoader
【定義のみフラグがTRUE】
API名でのインポートは可能だが、ラベル名でインポートしようとするとエラーになる。
picklist_error.png
定義とはAPI名を指すようなので、ラベル名での更新はダメっぽい。

【定義のみフラグがFALSE】
定義以外でも可なので、ラベル名でもインポートは可能。
ただし、保存後のレコードをSOQLで取得してみると、そのままラベル名になっていた。
image

##Apex
DMLはどうか。
結論だけ書くとDataLoaderと同じだった。

##更新系まとめ
標準UIは省略して、DataLoaderおよびApex DMLの場合

定義のみフラグ 更新値 結果
TRUE API名 正常更新
TRUE ラベル名 エラー
FALSE API名 正常更新
FALSE ラベル名 更新されるが再取得するとAPI名ではなくラベル名がとれる

ようはAPI名で更新しろってことだな。

#ということで

今までは分離されていなかったので、表示も更新もユーザが目にするラベル名だけ考えていればよかったのだが、今後はきちんと目的を考えて、ラベルとAPI名の使い分けが出てきそうだ。
今までの感覚で取得/更新すると痛い目に合いそう。

既存項目はラベル名=API名になっているのですぐにどうなるもんでもないけど、多くの場合SOQLにtoLabelつけてないと思うので、新規項目作って分離させた名前付けたら、既存コード通ったときにラベルじゃなくてAPI名がとれてアカーン!ってことになるかも。
DataLoaderは・・・何かいい方法ありますかね。。

19
9
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
19
9

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?