Salesforceからメールを送信する時の文字コードではまったのでメモです。 (はまったのはユーザ情報でメールの文字コードを「Shift_JIS」にしていたのに、送信されたメールで丸数字"①"などが化けていたという事象です。原因はメールテンプレートの文字コード…
Salesforceでは、あるレコードを参照できる人・できない人のセキュリティ制御が可能です。 標準機能のグローバル検索やビュー・レポートの結果も参照できるレコードのみで表示されるし、URLを直接変更されて参照できないレコードのIDを指定されてもアクセス…
visualforceの 「apex:relatedList」 で標準で用意される関連リストを表示したい時があります。 api41で使えるlist属性の値のメモです。 カスタムオブジェクトの標準関連リストで次をvisualforceで個別に表示します。 listで次を指定することで個別に指定で…
普段、Walkmanで音楽を聞いています。 CDの取り込み用のアプリケーション「x-アプリ」をインストールしていたPCに「Music Center for PC」をインストールしました。 その後「x-アプリ」をコントロールパネルから削除したら「Music Center for PC」が起動しな…
今さらですが、java8で追加されたStream APIをさわってみました。 自分でコードを書く際には使いませんが、別の人のコードを読むときや、Stream APIを使って書かれたコードを修正する時には知ってたほうがいいかなーと思っていて、ざっくりと理解しようとし…
Excel VBAでプログラムを書いておきたいなと思い、今までにいくつかExcel VBAのプログラムを書いてきました。 せっかくなのでSalesforceのAPIを操作して楽ができるツールがいいなと思い書いてきたのですが、通信制御のところで不具合があることがわかりまし…
Windowsサーバでバッチ処理を開発したり、バッチ処理の稼動を確認する時に便利だなと思ったコマンドのメモです。 よく使うコマンド(引数込み) コマンドで実現できること 利用したい時 備考 CERTUTIL -decode [intputfile] [outputfile] base64形式のテキス…
SalesforceのPartner WSDLでSOAP APIを使う時、sObjectのフィールド値をセットする時の書き方が各ライブラリによって大分違っています。 書き方の違いは、WSDLでの、complexType で anyの要素が各ライブラリで使い方が違うところに起因します。 各ライブラリ…
jdk9でjshellが追加されました。 簡単なバッチプログラムをjavaで書くことが多いのですが、コンパイルしたclassファイルよりも、テキストのjavaコードをそのまま実行するほうが好都合な時があります。 例えば、後で変更が見えてるような場合、柔軟に変更に対…
Salesforceへバイナリファイルを連携するには、通常はデータローダをはじめとするSOAP APIを使いbase64変換した文字列を送信します。 ファイル(ContentVersion)は2GBと大きいサイズでも登録が可能ですが、SOAP APIでは、Base64変換後のサイズで50MBのサイズ…
SalesforceのRest APIで思ったことのメモです。 まずSalesforceのRest APIは次の特徴を持ちます。(個人的に思っていることです。。詳細な仕様はSalesforceのヘルプを参照ください) httpsの通信ができれば、SalesforceとAPIのやり取りが可能 APIの送受信の…
レコードタイプの選択を、Visualforceで行いたい時があります。 標準のレコードタイプ選択画面であれば、ログインしているユーザのプロファイルに応じたリストが表示されますが、 そのリストをApexで作成する場合のメモです。 [サンプルコード] ※Sample__cは…
XMLでは、制御コードは改行やタブなどの決められたもの以外は許可されていません。(こちらの説明が詳しいです) なので、XMLで値をセットする際には許可されていない文字コードは除去する必要があります。(除去する方法はこの記事を参考にさせて頂きました)…
Winter18のバージョンアップでカスタム項目の型に、時間型が追加されていますね。 まだベータですが、時分を入力する項目を次のように用意することが多いので便利になります。 ・時分を入力するテキスト欄を用意 ・HH:MMを保証する入力規則を用意 ・もしくは…
他のライブラリを参照して開発する時に、参照先の定数を使うときがあります。 例えば、WebServiceのWSDLを展開したライブラリで、WebSerivceのendpointは定数として定義されていて、その定数を使いたい時があります。 開発しているプログラムでその定数を使…
いくつか関数を作ったのでメモです。 用意した関数は次の4つです。 トリガでよく使う参照項目のIdのSetを作る 文字のバイト数(Excelのlenbと同等) 文字のバイト数(Excelのleftbと同等) 文字のバイト数(Excelのrightbと同等) 1. トリガでよく使う参照…
Salesforceのバージョンアップに伴い、コマンドラインで動作するメタデータのエクスポートツールのバージョンを上げました。 ダウンロードはこちらです。 今回のバージョンアップでは、メタデータで目立って追加されているものはないように思います。(Topics…
テキストファイルなどutf8だと扱いづらく、shift_jisに変換したい時があります。 欲しいコマンドがみつからない時に、自分で作成するときの注意事項です。 結論として、utf8からshift_jisへの変換で、プログラムで工夫することで文字化けを回避できる文字が…
Javaで、SQLServer、MySQLのデータ連携プログラムを書くとき注意事項のメモです。(ある程度の件数がある時の場合です。) 結論としては jdbcのURLのパラメータをきちんと書かないと、「out of memory」のエラーになる可能性が高くなります。 「out of memor…
Salesforceのデータをまとめて編集をする時に、データローダを使います。 環境的な制約でうまく動作しなかった時のメモになります。 ※データローダのバージョンは40を前提としています。 環境的な問題 Javaのインストールが許可されていない メモリ不足のエ…
Salesforceから他システムへデータを渡したい時があります。 入力はsalesforceでPCとモバイルから行い、その後入力したデータを基幹システムや分析システムに連携することはよくあることだと思います。 その時に気をつけておくことのメモです。 大量データを…
しばらくTERADATAの開発を行った後に、通常のDB(業務用のSQL ServerやOracle)に戻った時がありました。 TERADATAでは、極力まとめて処理を行うのがポイントで、1000万件くらいであれば処理は数秒で終わります。 ※TERADATAにもキャパシティはあるので、その…
自分がApexでの開発で気をつけていることのメモです。 Salesforce IDの項目はID型で定義する。 トリガでの他オブジェクトの作成/更新処理を作り過ぎない 項目自動更新とトリガを混在させない そこでしか使わない処理は無名ブロックで囲み変数のスコープを限…
件名がやたら長くなってしまいました。 オブジェクトのメタデータは、オブジェクトの情報をまとめて取得する方法と、カスタム項目、リストビュー、レコードタイプ、入力規則、カスタムボタンまたはカスタムリンクを個別で取得する方法があります。個別で取得…
SalesforceのApex開発を行う場合、本番環境にリリースするためにテストクラスを作成する必要があります。 設定とちょっとのトリガなどの開発であれば、テストクラスの作成はさほど大変ではないのですが、サイトやコミュニティで多くの画面を作りこむ場合、テ…
Salesforceでは、標準レイアウトにカスタムボタンを配置してアプリケーションを作成していきます。(Lightning Experience ではなくClassicを対象とした場合です) 自分がカスタムボタンの作成時に注意することのメモです。 環境依存の文字列はカスタム表示…
今回がちょうど101回目になります。 100回書いてみて思ったことと、これからやってみたいことを書いてみようと思います。 [思ったこと] 文章を書くのが下手 プログラマとしてドキュメントを書くことは多く、今までそれなりに書いてきましたが、あらためて文…
自分は他の言語はあまりやらないので、Javaプログラムがメイン言語となっています。 なので、何か作ろうと思ったらコマンドラインのプログラムもJava、GUIのプログラムもJavaで済まそうとしてしまいます。 言語の拡張や新しい仕組みの導入などは無条件に受け…
前回CSVの加工の方法の1つとして紹介した「H2 Database」を使う方法です。 前提として、「Execute Query」と「H2 Database」のモジュールはダウンロードしていることとします。 次の内容です。 「Execute Query」を起動する。 JDBCドライバを設定する。 接…
CSVを加工する機会は多いと思います。データのやり取りはなんだかんだでCSVが主流で、Salesforceのデータローダでもインポート、エクスポートはCSVを使います。 自分がよく使うCSVの加工するやり方について書きます。 ちなみに、一番よく使うのは6の「H2 Dat…