レポートウィザードを使って、最新のMYOB AccountRight 連携データを使った帳票を作成。
Crystal Reports には、JDBC 標準向けのサポートが組み込まれています。この記事では、MYOB AccountRight の機能を持つ帳票を作成するレポート作成ウィザードの使い方を説明します。
MYOB AccountRight JDBC Driver のインストール
CData JDBC Driver for MYOB AccountRight を、ドライバーのJAR をCrystal Reports のクラスパスに含めてインストール:DataDriverCommonElement の下のClassPath element のパスに、 .jar を含むファイルのフルパスを追加します。
CRConfig.xml は通常C:\Program Files (x86)\SAP BusinessObjects\SAP BusinessObjects Enterprise XI 4.0\java に配置されます。— パスはインストールによって若干異なる場合があります。ドライバーのJAR はインストールディレクトリの[lib]サブフォルダ内にあります。
ClassPath にJAR を追加したら、Crystal Reports を再起動します。
MYOB AccountRight データに接続
下記の手順に従って、レポート作成ウィザードを使ってMYOB AccountRight 接続を作成します。
- 新しい空の帳票で、[Create New Connection]>[JDBC (JNDI)]をクリックします。
ウィザードでJDBC 接続URL を選択します。
jdbc:myob:OAuthClientId=YourClientId; OAuthClientSecret=YourClientSecret; CompanyFileId=yourCompanyFileId; CallbackURL=http://localhost:33333; User=companyFileUser; Password=companyFilePassword;
ドライバーのクラス名を設定:
cdata.jdbc.myob.MYOBDriver
これらのプロパティは会社のファイルに接続するときに必要です(クラウドインスタンスおよびオンプレミスインスタンスの両方)。
- User:会社のファイルに紐づいているユーザー名。
- Password:会社のファイルに紐づいているパスワード。
- CompanyFileId:会社ファイルのID。指定しない場合は、最初に返された会社ファイルのID が使用されます。CompanyFiles ビュー をクエリしてこれを見ることができます:
SELECT Id FROM CompanyFiles
オンプレミスインスタンスへの接続:
InitiateOAuth:OFF に設定。オンプレミスインスタンスに接続する場合は、上記に加えて、次の接続プロパティを設定する必要があります。
- Url: MYOB インスタンスのURL。
クラウドインスタンスへの接続:
MYOB のクラウドインスタンスに接続するには、OAuth アプリを作成する必要があります。このプロセスの詳細は、カスタムOAuth アプリの作成 にあります。
帳票をデザイン
JDBC 接続をMYOB AccountRight に追加したら、レポート作成ウィザードを使ってMYOB AccountRight を帳票に追加できます。
-
帳票に必要なテーブルやフィールドを選択して、データソースを設定します。この例では、Accounts テーブルのId およびName カラムを使います。
-
チャートの種類を設定 ウィザードを完了すると、Crystal Reports はMYOB AccountRight data に実行されるSQL クエリをビルドします。ドライバーは、ライブMYOB AccountRight data に対してクエリを実行します。
- 必要に応じて、ほかのフィルタや帳票テンプレートを設定します。
-
データのインポートが終わったら、データをサマライズもしくはソートするチャートやレポートオブジェクトを作成できます。[Insert]>[Chart]をクリックして、チャートエキスパートを開きます。Total Name by Id を表すグラフを作成するには、Id を[On Change Of]メニューセレクションの下のボックスに追加してからName を[Show Values]の下のボックスに追加します。
完成した帳票をプレビューして、チャートにデータが入っていることを確認します。Null 値を取り除きたい場合は、SelectionFormula を使います。
