Oracle® Fusion Middleware Oracle Application Development Frameworkデスクトップ統合開発者ガイド 11gリリース1 (11.1.1.9.0) B66694-04 |
|
![]() 前 |
![]() 次 |
この章では、ADFデスクトップ統合により提供される表タイプ・コンポーネント、その構成方法と使用方法、Fusion Webアプリケーションからデータをダウンロードする方法、統合Excelワークブックで表タイプ・コンポーネントからデータ行の挿入、更新、削除を行う方法、変更内容の追跡方法、表タイプ・コンポーネントで特殊な列を構成する方法、および表タイプ・コンポーネントを使用して実行できるその他のタスクについて説明します。
この章の内容は次のとおりです。
ADFデスクトップ統合には、構造化データを表示するためのADF表コンポーネントがあります。エンド・ユーザーには、データ行をダウンロードする機能が提供されます。また、ダウンロードしたデータの編集または削除、新しいデータ行の挿入、および新しいデータ行または編集済のデータ行のアップロードをエンド・ユーザーが行えるようにします。この目的を達成するには、データ・コントロールのメソッドを公開し、ページ定義ファイルでアクション・バインディングを作成して、ExcelワークシートがホストするADF表コンポーネントのプロパティを設定する必要があります。図7-1に、ADF表コンポーネントを示します。
それぞれのADF表コンポーネントには、「キー」列が1つ含まれています。「キー」列には、ADFデスクトップ統合で表が正しく機能するために使用される重要な情報が含まれるため、削除しないでください。「キー」列を削除したり、「キー」列のセルを変更すると、エラーおよびデータ破損が発生します。「キー」列の詳細は、7.13項「ADF表コンポーネントのキー列の構成」を参照してください。
これらの表タイプ・コンポーネントとともに使用可能な他のADFデスクトップ統合コンポーネントの詳細は、第6章「ADFデスクトップ統合フォーム・タイプ・コンポーネントの使用」および第8章「値リストの使用」を参照してください。
表は、構造化された情報を表示するときに使用されます。たとえば、表7-2は、ADFデスクトップ統合のSummitサンプル・アプリケーションのADF表コンポーネントと、それぞれのFusion Webアプリケーションからダウンロードされたデータを示します。
統合Excelワークブックに表コンポーネントを追加した後、表を構成するために追加機能が必要になることがあります。表コンポーネントで使用可能な他の機能へのリンクは次のとおりです。
「検索および選択」ダイアログ: 8.4項「ADF表コンポーネントへのモデルドリブン・リスト・ピッカーの追加」で説明されているように、表の列のModelDrivenColumnComponent
サブコンポーネントを構成して、エンド・ユーザーがデータを検索および選択できるダイアログを表示できます。
依存値リスト: 表コンポーネントに依存値リスト・コンポーネントを追加できます。詳細は、8.5項「統合Excelワークブックでの依存値リストの作成」を参照してください。
スタイル: 事前定義済のExcelのスタイルをいくつか使用して、フォーム・タイプ・コンポーネントの表示を構成できます。詳細は、10.2項「スタイルの使用」を参照してください。
ツールチップ: 追加の情報や指示テキストをエンド・ユーザーに表示するようにツールチップを構成できます。詳細は、10.6項「ADFデスクトップ統合コンポーネントでのツールチップの表示」を参照してください。
EL式: EL式を表タイプ・コンポーネントとともに使用できます。詳細は、付録B「ADFデスクトップ統合のEL式」を参照してください。
ADF表コンポーネントは、ADFデスクトップ統合が公開するOracle ADFコンポーネントの1つです。これは、ADFデスクトップ統合デザイナの作業ウィンドウのコンポーネント・パレットに表示されます。Excelワークシートに挿入された後は、次の操作が可能です。
読取り専用
挿入専用
更新専用
挿入と更新
ADF表コンポーネントに固有のページ定義ファイルの要件の詳細は、次の項を参照してください。
エンド・ユーザーにデータ・エントリ機能を提供するようADF表コンポーネントを構成するには、Excelワークシートの基礎となるページ定義ファイルにADFバインディングをあらかじめ構成しておく必要があります。統合Excelワークブックのページ定義ファイルの要件の概要は、4.2項「統合Excelワークブックのページ定義ファイルの使用」を参照してください。
ADF表コンポーネント作成のためにページ定義ファイルを作成する際に、次のコントロール・バインディングを公開します。
目的の属性バインディングを公開するツリー・バインディング。ADFデスクトップ統合では、ビュー・オブジェクトに対して、スクロール可能な範囲ページング・アクセス・モードのみをサポートしています。他のアクセス・モードはサポートされていません。
統合Excelワークブックで大量のデータをダウンロードする必要がある場合は、範囲ページング・アクセス・モードを使用することを検討してください。詳細は、『Oracle Application Development Framework Fusion開発者ガイド』の範囲ページングを使用して大きい結果を効率的にスクロールする方法に関する項を参照してください。
範囲ページング・アクセス・モードを使用する場合は、ADFデスクトップ統合で使用する前に、このアクセス・モードがアプリケーションのビュー・オブジェクトでサポートされていることを確認してください。詳細は、『Oracle Application Development Framework Fusion開発者ガイド』の"TOP-N"問合せがどのようにサポートされているかの理解に関する項を参照してください。
また、範囲ページング・アクセス・モードを使用したビュー・オブジェクトは、ポストされていない行ではスクロールできません。このため、保留中の変更がADFデスクトップ統合のアクション・セットで想定どおりコミットまたはロールバックされることを確認してください。ADF表コンポーネントのDownload
アクションを起動する前に、保留中の変更がコミットまたはロールバックされないと、アプリケーションで次の例外がレポートされます。
An attempt has been made to navigate a rowset in range paging mode when the rowset has pending changes.
新しい行を挿入する前に、イテレータにより、必要に応じて最初の行に再配置されます。これは、最初の行の後に新しい行を挿入すると、予期しないスクロールが発生する場合があるためです。この動作は、ADF表コンポーネントのUpload
アクションおよび挿入行のダブルクリック・アクション・セットに適用されます。
ADF表コンポーネントのRowActions
およびBatchOptions
プロパティ・グループの値を構成する場合、メソッド・アクション・バインディングおよびアクション・バインディング(Execute
、Commit
、CreateInsert
など)になります。これらのプロパティ・グループに値を設定する手順の例には、次のものがあります。
図7-3に、ページ定義ファイルExcelCustomers.xml
に含まれるバインディングを示します。このページ定義ファイルは、関連付けられているExcelワークシートでのADF表コンポーネントの使用をサポートします。
ページ定義ファイルを正しく構成した後、ADF表コンポーネントをワークシートに挿入して、そのプロパティを構成し、必要な機能を使用可能にできます。ADF表コンポーネントを使用して、データ行のダウンロード、編集、アップロードを行うことができます。
次のいずれかの方法を使用して、ADF表コンポーネントを挿入します。
ADFデスクトップ統合デザイナの作業ウィンドウのバインディング・パレットで、使用するツリー・バインディングを選択して、バインディングの挿入をクリックします。
次の手順では、バインディング・パレットを使用してADF表コンポーネントを挿入する方法について説明します。他の2つの方法ではなく、この方法を使用する利点の1つは、実行時にコンポーネントに表示する各列を手動で追加する必要がないことです。
「Oracle ADF」タブで、「コンポーネントの挿入」ドロップダウン・リストから「ADF表」を選択します。
ADFデスクトップ統合デザイナの作業ウィンドウのコンポーネント・パレットで、「ADF表」を選択して、「コンポーネントの挿入」をクリックします。
始める前に:
ADF表コンポーネントについて理解しておくと役立ちます。詳細は、7.3項「ExcelワークシートへのADF表コンポーネントの挿入」を参照してください。
他のADFデスクトップ統合の機能を使用して追加できる機能についても理解しておくと役立ちます。詳細は、7.1.2項「表タイプ・コンポーネントの追加機能」を参照してください。
ADF表コンポーネントをExcelワークシートに挿入する手順:
統合Excelワークブックを開きます。
ADF表コンポーネントを挿入するExcelワークシートのセルを選択します。
セルを選択する場合、次を確認します。
2つの表のデータが実行時に重複しない
選択したセルがマージされたセルではない
ADFデスクトップ統合デザイナの作業ウィンドウのバインディング・パレットで、使用するツリー・バインディングを選択して、バインディングの挿入をクリックします。
表示されたダイアログで、「ADF表」を選択して「OK」をクリックします。
注意:
|
表7-1の説明に従って、図7-4に示すプロパティ・インスペクタを使用して、ADF表コンポーネントのプロパティを構成します。
表7-1 ADF表コンポーネントのプロパティ
設定するプロパティ | 設定する値 |
---|---|
|
ページ定義ファイルで公開された |
|
ツリー・バインディングに関連付けられたイテレータの各行を一意に識別するバインディング式を指定します。ツリー・バインディングのイテレータが行キーをサポートしていない場合は、 |
|
(オプション) ADF表コンポーネントでダウンロードされる行数を決定するように、このプロパティ・グループを構成します。 詳細は、7.20項「表タイプ・コンポーネントがダウンロードする行数の制限」を参照してください。 |
「OK」をクリックします。
「コンポーネントの挿入: ADF表」ダイアログで適切なオプションを選択します。
はい: 新しい表でデータをダウンロードおよびアップロードするためのデフォルトのリボン・コマンドを作成します。これらのリボン・コマンドは後で削除または編集できます。デフォルトのリボン・コマンド・ラベルを変更することをお薦めします。詳細は、9.3.2項「実行時リボン・タブのワークシート・リボン・コマンドの構成方法」を参照してください。
いいえ: 7.4項「ADF表コンポーネントへのデータのダウンロード」および7.8項「ADF表コンポーネントからの変更のアップロード」で説明されているように、データを後でダウンロードおよびアップロードする場合、または利用可能なその他のいずれかの方法を使用する場合(例: ワークシート・イベント)。
図7-5は、設計モードでのEditCustomers-DT.xlsx
におけるADF表コンポーネントを示しています。
図7-6は、実行時のEditCustomers-DT.xlsx
におけるADF表コンポーネントを示しています。
ADF表コンポーネントに設定可能なプロパティの詳細は、A.11項「ADF表コンポーネントのプロパテおよびアクション」を参照してください。
表コンポーネントを削除するには、「削除」リボン・コマンドを使用します。詳細は5.14項「ADFデスクトップ統合コンポーネントの削除」を参照してください。
ツリー・バインディングを使用せずに表を挿入した場合(例: コンポーネント・パレットから表を挿入した場合)、列を表に追加して、表に表示する各属性のデータを表示します。たとえば、顧客の表には、顧客の名前、電話番号、信用評価などを表示する列があります。
ツリー・バインディングを使用して挿入した表に列を追加する場合も、手順は同じです。
始める前に:
ADF表コンポーネントについて理解しておくと役立ちます。詳細は、7.3項「ExcelワークシートへのADF表コンポーネントの挿入」を参照してください。
他のADFデスクトップ統合の機能を使用して追加できる機能についても理解しておくと役立ちます。詳細は、7.1.2項「表タイプ・コンポーネントの追加機能」を参照してください。
ADF表コンポーネントに列を追加するには:
統合Excelワークブックを開きます。
ADF表コンポーネントを参照するExcelワークシートのセルを選択し、「Oracle ADF」タブの「プロパティの編集」ボタンをクリックします。
「コンポーネントの編集: ADF表」ダイアログで、Columns
プロパティの参照(...)アイコンをクリックします。
「列の編集」ダイアログが表示され、選択したADF表コンポーネントのすべての列が一覧表示されます。
「追加」をクリックして、新しい列を追加します。新しい列が、Membersリストの末尾に挿入されます。列を特定の位置に移動するには、列を選択して「上」と「下へ」の配列キーを使用します。
ダイアログの右側ウィンドウにある新しい列のプロパティを構成します。
「OK」をクリックします。
ADFデスクトップ統合では、ADF表コンポーネントに追加できる列の数に制限はありません。Excelのバージョンでサポートされる数の列を追加できます。ただし、表の幅が広くなると、操作性とパフォーマンスが低下する場合があります。パフォーマンスが低下した場合は、他の原因を調査する前に、表の列の数を減らしてみてください。ADFデスクトップ統合では、パフォーマンスと操作性を最適化するために、可能であれば、1つの表当たり30列未満の構成にすることをお薦めします。
ワークシートにADF表コンポーネントを追加したら、Fusion Webアプリケーションからデータをダウンロードするようにワークシートを構成します。これを実行するには、ワークシート・リボン・コマンドなどのOracle ADFコンポーネントを構成して、アクション・セットを起動します。起動されるアクション・セットには、起動されるアクションの中からADF表コンポーネントDownload
アクションを含める必要があります。
ADF表コンポーネントに含まれる行数は、Fusion Webアプリケーションからダウンロードする行数に基づいて増減します。Excelが表タイプ・コンポーネントがダウンロードするデータを受け入れるために行を挿入するときに、複製する場合を除いて、表タイプ・コンポーネントの左右には何も配置しないでください。実行時に表タイプ・コンポーネントに対して位置が維持されるため、表タイプ・コンポーネントの上下には他のコンポーネントを配置できます。
ADF表コンポーネントのDownload
アクションを起動するリボン・コマンドを構成します。
始める前に:
他のADFデスクトップ統合の機能を使用して追加できる機能についても理解しておくと役立ちます。詳細は、7.1.2項「表タイプ・コンポーネントの追加機能」を参照してください。
ADFコンポーネントを構成してデータをADF表データ・コンポーネントにダウンロードする方法を理解しておくと役立ちます。詳細は、7.4項「ADF表コンポーネントへのデータのダウンロード」を参照してください。
データをADF表コンポーネントにダウンロードする手順:
統合Excelワークブックを開きます。
「Oracle ADF」タブで、「ワークシート・プロパティ」ボタンをクリックし、リボン・コマンドを追加します。ワークシートにリボン・コマンドを追加する方法の詳細は、9.3.1項「実行時リボン・タブのワークブック・リボン・コマンドの定義方法」を参照してください。
注意: リボン・コマンドを追加するかわりに、実行時にアクション・セットを起動するように、ワークシート・イベントを構成できます。 |
アクションの編集ダイアログを開き、アクション・セットを構成します。アクション・セットの起動の詳細は、9.2項「アクション・セットの使用」を参照してください。
実行時に起動するアクション・セットに、次のアクションを次の順に追加します。
ADFmAction Execute
アクション・バインディング: ADF表コンポーネントのTreeID
プロパティで参照されるイテレータ・バインディングで問合せを実行します。これにより、アクション・セットでADF表コンポーネントのDownload
アクションを起動する前に、バインディングが最新になります。
ADF表コンポーネントのDownload
アクション。
ADF表コンポーネントDownload
アクションは、ADF表コンポーネントTreeID
プロパティにより参照されるバインディングの現在の状態をダウンロードします。
図7-7に、Excelリボンの「ダウンロード」リボン・コマンドで起動されるアクション・セットが構成される、EditCustomers-DT.xlsx
ワークブックのアクションの編集ダイアログを示します。
「OK」をクリックします。
エンド・ユーザーは、構成されたアクション・セットを起動します。アクション・セットは、指定されたアクションのリストを順に起動します。これには、ADF表コンポーネントのDownload
アクションを起動するアクションが含まれます。起動時に、Download
アクションは、ADF表コンポーネントTreeID
プロパティにより参照されるツリー・バインディングからすべての行をダウンロードします。
実行時にDownload
アクションが起動される場合は、次の点に注意してください。
Download
アクションの起動時に、行が変更済とマークされている場合、エンド・ユーザーは、アクションを確認して続行するように求められます(図7-8を参照)。エンド・ユーザーが「いいえ」を選択すると、アクションとアクション・セットはエラーなしで中止されます。
既存のすべてのExcel行がExcelの表から削除されます。
ステータス列からすべてのメッセージが消去されます。
Excelのフィルタ機能を使用してワークシートに適用された条件は、Uploadアクションの前に自動的にクリアされます。
アクションによりダウンロードされる行数は、ADF表コンポーネントでRowLimit
グループ・プロパティに設定された値によって異なります。詳細は、7.20項「表タイプ・コンポーネントがダウンロードする行数の制限」を参照してください。
保留中の挿入行は、アップロード時に、新しいデータ行としてイテレータに挿入されるデータのあるワークシートの表の行です。たとえば、エンド・ユーザーが、右クリックのコンテキスト・メニューにある「挿入」オプションを使用して表に新しい行を作成する場合、新しい行は保留中の挿入行として扱われ、アップロード時にイテレータに挿入されます。
保留中の更新行は、アップロード時に、イテレータの既存のデータを更新するデータのあるワークシートの表の行です。たとえば、ツリー・バインディングのイテレータにデータベースから取得した行が含まれている場合、その行がADF表にダウンロードされると、その行は保留中の更新行として扱われます。エンド・ユーザーがこれらの行を変更しアップロードすると、イテレータ内の既存の行はADF表の行の新しい値で更新されます。
大部分の場合、ツリー・バインディングのイテレータ内の行は保留中の更新行としてADF表にダウンロードされます。一部の行を保留中の挿入としてダウンロードする場合は、これらの行の状態をSTATUS_INITIALIZED
に設定する必要があります。行の状態をSTATUS_INITIALIZED
に設定する方法の詳細は、Oracle Fusion Middleware Oracle ADFモデルJava APIリファレンスのsetNewRowStateメソッドを参照してください。
保留中の挿入行と保留中の更新行には次の違いがあります。
保留中の挿入行には、ADF表コンポーネントの各列に関連付けられた挿入コンポーネントに対するEL式の値が移入される(InsertUsesUpdate
列プロパティがFalse
に設定されている場合)のに対し、保留中の更新行には、ADF表コンポーネントの各列に関連付けられた更新コンポーネントに対するEL式の値が移入されます。
保留中の挿入行の検証時に、EL式#{components.componentID.currentRowMode}
はInsert
を返します。これに対し、保留中の更新行の場合は、同じEL式がUpdate
を返します。
EL式#{components.componentID.currentRowMode}
のcomponentID
部分は、ADF表コンポーネントのIDを参照します。
EL式の詳細は、付録B「ADFデスクトップ統合のEL式」を参照してください。
Download
アクションが起動されると、そのアクションはイテレータ内の各行の状態を確認します。状態がSTATUS_INITIALIZED
の行は保留中の挿入行として表にダウンロードされ、他の状態の行は保留中の更新行としてダウンロードされます。
STATUS_INITIALIZED
行を使用して、保留中の挿入行の一部の属性またはすべての属性の値を事前移入できます。STATUS_INITIALIZED
行は検証されないため、Download
アクションが起動される前に、STATUS_INITIALIZED
行の一部を移入し、その行をイテレータに挿入するアクションを構成できます。Download
アクションはこの行を保留中の挿入行として扱うため、事前移入された行に基づいて新しい行を挿入できます。
STATUS_INITIALIZED
行は、ダウンロード中にイテレータから自動的に削除されることに注意してください。ダウンロード後にSTATUS_INITIALIZED
行を削除する別のアクションを構成できます。たとえば、次の操作でアクション・セットを構成できます。
STATUS_INITIALIZED
行を作成するADFmAction
Table.Download
アクション
STATUS_INITIALIZED
行をクリーン・アップするADFmAction
ADFデスクトップ統合は、DownloadForInsert
と呼ばれる表アクションもサポートしています。DownloadForInsert
は現在サポートされていないアクションであり、Download
アクションと置き換えることができます。DownloadForInsert
は、以前のリリースと同様に、引き続き使用できます。Download
との主な違いは、DownloadForInsert
はイテレータにあるSTATUS_INITIALIZED
状態の行のみを考慮する点です。
この項では、表の既存のデータ行に対する変更を編集およびエンド・ユーザーがアップロードできるように、ADF表コンポーネントをどのように構成するかについて説明します。7.8項「ADF表コンポーネントからの変更のアップロード」では、変更したデータ行をエンド・ユーザーがアップロードできるように、ADF表コンポーネントをどのように構成できるかについて説明します。
エンド・ユーザーが既存のデータを編集できるようにしながら、データ行の追加や削除を制限する場合、追加の構成は必要ありません。次の手順に示すように、プロジェクトおよびADF表コンポーネントが構成されていることを確認します。
データをアップロードするようにADF表コンポーネントを構成する手順:
JDeveloperでプロジェクトを開きます。
存在しない場合は、Commit
アクション・バインディングを、ADF表コンポーネントをホストするExcelワークシートに関連付けられたページ定義ファイルに追加します。
詳細は、4.2項「統合Excelワークブックのページ定義ファイルの使用」と7.2項「ADF表コンポーネントのページ定義の要件」を参照してください。
統合Excelワークブックを開きます。
ADF表コンポーネントを参照するExcelワークシートのセルを選択し、「Oracle ADF」タブの「プロパティの編集」ボタンをクリックします。
表7-2や図7-9に示すように、ADF表コンポーネントのRowAction
プロパティが設定されていることを確認してください。
エンド・ユーザーが行のデータを変更すると、ADFデスクトップ統合によりその行にマークが付けられ、上向きの三角形が_ADF_ChangedColumn
列の行に表示されます。既存のデータを更新した後、エンド・ユーザーはアップロード処理を開始して変更を保存します。ADF表コンポーネントのアップロード処理の詳細は、7.8項「ADF表コンポーネントからの変更のアップロード」を参照してください。
Excelは、統合ワークブックで変更された行を、行ごとにではなくバッチ処理でアップロードします。アップロードされる行数をバッチごとに構成し、行のバッチのアップロードおよびコミット時にADF表コンポーネントが起動するアクションを構成できます。バッチ処理の詳細は、7.11項「ADF表コンポーネントでのバッチ処理」を参照してください。
ADF表コンポーネントに設定可能なプロパティの詳細は、A.11項「ADF表コンポーネントのプロパテおよびアクション」を参照してください。
注意: Excelのフィルタ機能を使用してワークシートに適用された条件は、Upload アクションの前に自動的にクリアされます。 |
エンド・ユーザーが新しいデータ行を挿入できるようにADF表コンポーネントを構成できます。このタスクを完了したら、7.8項「ADF表コンポーネントからの変更のアップロード」の説明に従って、エンド・ユーザーが新規および変更済データ行をアップロードできるようにコンポーネントを構成することもできます。
ADF表コンポーネントでエンド・ユーザーが行った変更をコミットするには、ADF表コンポーネントをホストするExcelワークシートに関連付けられているページ定義ファイルに、アクション・バインディングを追加し、ADF表コンポーネントのいくつかのプロパティを構成します。
始める前に:
ADF表コンポーネントを構成してデータを挿入する方法を理解しておくと役立ちます。詳細は、7.7項「ADF表コンポーネントでのデータの挿入」を参照してください。
他のADFデスクトップ統合の機能を使用して追加できる機能についても理解しておくと役立ちます。詳細は、7.1.2項「表タイプ・コンポーネントの追加機能」を参照してください。
ビュー・オブジェクトの操作を使用してデータを挿入するためにADF表コンポーネントを構成するには:
JDeveloperでプロジェクトを開きます。
プロジェクトがない場合は、CreateInsert
とCommit
アクション・バインディングを、ADF表コンポーネントをホストするExcelワークシートに関連付けられたページ定義ファイルに追加します。
詳細は、4.2項「統合Excelワークブックのページ定義ファイルの使用」と7.2項「ADF表コンポーネントのページ定義の要件」を参照してください。
統合Excelワークブックを開きます。
ADF表コンポーネントを参照するExcelワークシートのセルを選択し、「Oracle ADF」タブの「プロパティの編集」ボタンをクリックします。
コンポーネントの編集: ADF表ダイアログで、表7-3に示すようにADF表コンポーネントのRowActions
プロパティを構成します。
表7-3 ADF表コンポーネントのRowActionsプロパティ
設定するプロパティ | 設定する値 |
---|---|
|
ワークシート・プロパティの詳細は、A.15項「ワークシートのアクションおよびプロパティ」を参照してください。 |
|
|
|
ページ定義ファイルで公開された |
|
|
表7-4の説明に従って、ADF表コンポーネントのBatchOptions
プロパティを構成します。
表7-5に示すように、ADF表コンポーネントのColumns
プロパティを構成します。
注意: 7.3.1項「ADF表コンポーネントの挿入方法」の説明に従ってADF表を挿入する際にツリー・バインディングを選択した場合、ADFデスクトップ統合により自動的に適切なプロパティ値が設定されます。(オプション)必要に応じて、他の列プロパティ値を確認して調整します。詳細は、A.11.2項「ADF表コンポーネントの列プロパティ」を参照してください。 |
表7-5 ADF表コンポーネントのColumnsプロパティ
設定するプロパティ | 設定する値 |
---|---|
|
|
|
|
Uploadアクションの起動時にコミットするデータを含む列ごとに、手順7
を繰り返します。
ADF表コンポーネント・プロパティの詳細は、A.11項「ADF表コンポーネントのプロパティおよびアクション」を参照してください。
注意:
|
エンド・ユーザーがADF表コンポーネントでデータに加える変更をFusion Webアプリケーションにアップロードできるように、ADF表コンポーネントおよびホストされるワークシートを構成します。この機能を構成するには、どのようなユーザーによる操作やワークシート・イベントが、ADF表コンポーネントのUpload
アクションを起動するアクション・セットを起動するかを決定します。
Upload
アクションは、一部の行で失敗があっても、正常なすべての行をコミットします。1つ以上の行で失敗があったときに行の変更がコミットされないようにする場合は、かわりにUploadAllOrNothing
アクションを使用します(7.9項「UploadAllOrNothingアクションを使用したADF表コンポーネントからの変更のアップロード」を参照)。Fusion WebアプリケーションからのWebページで、エンド・ユーザーにデフォルトのアップロード用ダイアログとは異なるアップロード・オプションを提供するには、ADF表コンポーネントのUpload
を起動するアクションの前に、アクション・セットでDialog
アクションを指定する必要があります。詳細は、7.8.6項「カスタムのアップロード・ダイアログの作成方法」を参照してください。
注意: マスター/ディテール関係では、ADFデスクトップ統合はViewLink ソース属性の編集をサポートしていません。これは、子のビュー・オブジェクトの選択が結果的に変わるためです。誤って編集されないようにするため、ViewLink ソース属性を読取り専用にするか、マスターとディテール間のビュー・リンクを含まないモデル構成を使用してください。 |
ワークシート・リボン・コマンドなどの、ADFコンポーネントを構成し、アクション・セットを起動します。これは、続いてADF表コンポーネントのUpload
アクションを起動します。
始める前に:
ADFコンポーネントを構成してデータをADF表データ・コンポーネントからアップロードする方法を理解しておくと役立ちます。詳細は、7.8項「ADF表コンポーネントからの変更のアップロード」を参照してください。
他のADFデスクトップ統合の機能を使用して追加できる機能についても理解しておくと役立ちます。詳細は、7.1.2項「表タイプ・コンポーネントの追加機能」を参照してください。
ADFコンポーネントを構成してADF表コンポーネントに変更済データをアップロードするには:
統合Excelワークブックを開きます。
「アクションの編集」ダイアログを開いて、ADF表コンポーネントのUpload
アクションを起動するアクション・セットを構成します。
アクション・セットの詳細は、9.2項「アクション・セットの使用」を参照してください。
ADF表コンポーネントのUpload
アクションを、実行時にアクション・セットにより起動されるアクションのリストに追加します。
図7-10は、EditCustomers-DT.xlsx
ワークブックの「編集実行時」ダイアログを示しています。ここでは、実行時にUploadのラベルの付いたリボン・コマンドにより起動されるアクション・セットが構成されます。
「OK」をクリックします。
「アップロード・オプション」ダイアログを表示しない場合は、ADF表コンポーネントを参照するExcelワークシートのセルを選択し、「Oracle ADF」タブの「プロパティの編集」ボタンをクリックします。
「表のプロパティ」ダイアログでDisplayUploadOptions
をFalse
に設定して、「OK」をクリックします。
注意: このアクション・セットには、ADF表コンポーネントのバッチ・オプションにCommit へのコールがすでに含まれるため、コミット・タイプのアクションのコールは含まれません。詳細は、7.11.1項「ADF表コンポーネントのバッチ・オプションの構成方法」を参照してください。 |
実行時に、エンド・ユーザーは、構成したメカニズム(ADFコンポーネント、ワークシート・リボン・コマンドまたはワークシート・イベント)でアクション・セットを起動します。これによって、次の一連のイベントがトリガーされます。
ADF表コンポーネントに動的な列が含まれる場合、ADFデスクトップ統合は前回ADF表コンポーネントのDownload
アクションが起動されたときに展開された動的な列が、まだFusion Webアプリケーションに存在するかどうかを検証します。列が存在しない場合は、ADFデスクトップ統合はアップロード処理を続行するかどうか決めるようエンド・ユーザーにプロンプトを表示します。エンド・ユーザーが続行しないと決めた場合、ADFデスクトップ統合は実行中のアクション・セットに中止コードを返します。
ADF表コンポーネントにアップロードする保留中の変更がない場合、ADF表コンポーネントのUpload
アクションは実行中のアクション・セットに成功コードを返します。
ADF表コンポーネントは、変更した行を1行ずつではなく、バッチでアップロードします。バッチ・オプションはBatchOptions
プロパティ・グループを使用して構成できます。ADF表コンポーネントのバッチ・オプションの詳細は、7.11項「ADF表コンポーネントでのバッチ処理」を参照してください。
各バッチ行は次のように処理されて、各バッチの変更されたすべての行が終わるまで処理が続けられます。
挿入された行の場合は、InsertBeforeRowActionID
アクションが起動されます(指定されている場合)。
編集済の行の場合は、ツリー・バインディング・イテレータを正しい行に配置します。
キャッシュされたすべての行属性の値を含む、ワークシートからの属性をモデルに設定します。
編集された行の場合、UpdateRowActionID
アクションを起動し、挿入された行については、InsertAfterRowActionID
アクションを起動します(指定されている場合)。
アップロードされた行ごとに、成否が「ステータス」列に示されるステータス・メッセージを表示します。行のアップロードに失敗した場合は、「ステータス」列にメッセージが表示されます(例: Update Failed
)。失敗の詳細は、失敗した行のセルをエンド・ユーザーがクリックすると、ステータス・ビューアに表示されます。詳細は、13.2項「ステータス・ビューアを使用したエンド・ユーザーへのエラー・メッセージのレポート」を参照してください。
「ステータス」列の詳細は、7.12項「ADF表コンポーネント内の特殊な列」を参照してください。
行について失敗があった場合、ADF表コンポーネントでAbortOnFail
の値が検証されます。AbortOnFail
がFalse
に設定されている場合、アップロード処理は続行されます。それ以外の場合は、コンポーネントはデータのアップロードを停止し、Commit
アクションを起動します。
データをアップロードする際、ADF表コンポーネントは次の条件に基づいて実行中のアクション・セットに成功または失敗のコードを返します。
ADF表コンポーネントがすべてのバッチを問題なくコミットした場合、実行中のアクション・セットに成功のステータスが返されます。Table.DisplayUploadOptions
プロパティがTrue
に設定されており、エンド・ユーザーが「アップロード・オプション」ダイアログで「正常にアップロードした後はすべての行をダウンロードします」オプションを選択した場合、ADF表コンポーネントはFusion Webアプリケーションからすべての行をダウンロードします。
ADF表コンポーネントがすべてのバッチを正常にコミットしなかった場合、アクション・セットはRowActions.FailureActionID
プロパティで指定されたアクションを起動します(このプロパティにアクションが指定されている場合)。ADFデスクトップ統合は、アクション・セットに失敗コードを返します。
Table.DisplayUploadOptions
プロパティがTrue
に設定されており、「アップロード・オプション」ダイアログで「失敗した場合は、引き続き後続の行をアップロードします」チェック・ボックスを選択した場合、一部の行で検証に失敗した場合でも、Uploadアクションはアクション・セットに成功コードを返します。
注意: Excelフィルタが適用されたADF表でUpload アクションが起動されると、Excelフィルタの条件がクリアされ、非表示のExcelワークシート行が表示されますが、フィルタは削除されません。 |
実行時にADF表コンポーネント列のReadOnly
プロパティがTrue
に評価された場合、ADF表コンポーネントのUpload
アクションは列のセルにあるすべての変更を無視します。
変更トラッキングに関する詳細は、7.22項「読取り専用プロパティのEL式の評価」を参照してください。
ADF表コンポーネントがデータのアップロードを開始すると、ADFデスクトップ統合はアップロード処理を開始する前にDataControlFrame
セーブポイントを作成します(アップロードされた行のバッチごとに1回)。なんらかのエラーがあった場合、ADFデスクトップ統合はセーブポイントまで戻り、Fusion Webアプリケーションのサーバー・サイドの状態の整合性を維持します。
アップロードされた行のバッチの各行ごとに、ADFデスクトップ統合は次の処理を実行します。
構成されたアクションを起動し、行の属性値の変更を適用して、データの検証を実行。
なんらかのエラーがあった場合、セーブポイントの状態に復元。
注意: 必要に応じて2度目の繰り返しが実行され、アップロードに成功したすべての行でその後のアップロード・エラーによって変更が元に戻されたものが再度アップロードされます。 |
セーブポイントの詳細は、『Oracle Application Development Framework Fusion開発者ガイド』のツリーを使用したマスター/ディテール・オブジェクトの表示に関する項を参照してください。
実行時、エンド・ユーザーが統合ExcelワークブックからFusion Webアプリケーションにデータをアップロードすると、ADFデスクトップ統合は、行で失敗があった場合に、後続のデータ行を引き続きアップロードし、アップロードに成功すると、すべての行のデータをリフレッシュまたはダウンロードしません。
図7-11に示すように、Table.DisplayUploadOptions
プロパティを設定することで、必要に応じて「アップロード・オプション」ダイアログを有効または無効にできます。DisplayUploadOptions
がTrue
に設定されている場合、ADFデスクトップ統合には「アップロード・オプション」ダイアログが表示されます。
注意: Table.DisplayUploadOptions プロパティは、Table.DisplayUploadOptions プロパティが含まれていないバージョンのADFデスクトップ統合で作成された統合ExcelワークブックのADF表コンポーネントでは、デフォルトでTrue に設定されます。 |
「アップロード・オプション」ダイアログを使用して、エンド・ユーザーは次のオプションを有効または無効にできます。
失敗した場合は引き続き後続の行をアップロードする。これはデフォルトの動作です。
無効にすると、行で失敗があった場合に、ADFデスクトップ統合はアップロード処理を中断します。
正常にアップロードした後はすべてのデータ行をダウンロードする。この動作はデフォルトで無効になっています。
有効にした場合、アップロードが成功すると、ADFデスクトップ統合は、ビュー・オブジェクト・キャッシュから最新のデータをダウンロードします。
注意: 正常にアップロードした後はすべてのデータ行をダウンロードする。チェック・ボックスが選択されている場合、ADFデスクトップ統合は、データベースではなく、ビュー・オブジェクト・キャッシュから最新のデータをダウンロードします。したがって、エンド・ユーザーが更新したのと同じ行を別のユーザーが更新すると、そのエンド・ユーザーには、データ行のダウンロード後に、別のユーザーが行った更新が表示されません。 |
エンド・ユーザーが「アップロード・オプション」ダイアログの「取消」をクリックした場合、ADFデスクトップ統合は実行中のアクション・セットに中止コードを返します。エンド・ユーザーが「OK」をクリックすると、アクション・セットはアップロード操作のダイアログで指定したオプションの実行を続けます。
カスタムのアップロード・ダイアログを作成することもできます。詳細は、7.8.6項「カスタムのアップロード・ダイアログの作成方法」を参照してください。
デフォルトのアップロード・ダイアログのものとは異なるオプションをエンド・ユーザーに提供する、Fusion Webアプリケーションからのページを表示します。アクション・セットでADF表コンポーネントのUpload
アクションを起動するアクションの前に、Dialog
アクションを追加します。
注意: 7.8.5項「アップロード・オプションに関する必知事項」で説明されているように、DisplayUploadOptions プロパティをFalse に設定することで、標準の「アップロード・オプション」ダイアログを表示しないようにできます。 |
始める前に:
ADFコンポーネントを構成してデータをADF表データ・コンポーネントからアップロードする方法を理解しておくと役立ちます。詳細は、7.8項「ADF表コンポーネントからの変更のアップロード」を参照してください。
他のADFデスクトップ統合の機能を使用して追加できる機能についても理解しておくと役立ちます。詳細は、7.1.2項「表タイプ・コンポーネントの追加機能」を参照してください。
カスタムのアップロード・ダイアログを作成するには:
Fusion Webアプリケーションを開発するJDeveloperプロジェクトにページを作成します。このページの作成方法の詳細は、9.4項「Fusion WebアプリケーションからのWebページの表示」を参照してください。
9.4項「Fusion WebアプリケーションからのWebページの表示」に示すADFdi_CloseWindow
要素(span要素など)の他に、手順1で作成するページには表7-6に示す要素を含める必要があります。
表7-6 カスタム・アップロードに必要なSpan要素
名前 | 説明 |
---|---|
|
この要素を |
|
この要素を |
注意: 作成するページには、ADFデスクトップ統合がデフォルトのアップロード・ダイアログをエンド・ユーザーに表示しないように、両方の要素を含める必要があります。 |
手順1
で作成したページを起動するには、ADF表コンポーネントのUploadアクションを起動するアクション・セットのアクションより前に、Dialog
アクションを追加します。
Fusion Webアプリケーションからのページを表示する詳細は、9.4項「Fusion WebアプリケーションからのWebページの表示」を参照してください。
カスタムのダイアログが表示されるときに、デフォルトのアップロード・ダイアログではなく、表示されるアクション・セットでDialog
アクションを構成するFusion Webアプリケーションからのページが表示されます。
注意: エンド・ユーザーがデータをアップロードしようとしてサーバーに接続されていない場合、Dialog アクションでカスタムのアップロード・ページが見つからないとエンド・ユーザーにエラーが表示されます。サーバーへの接続がない場合、ADFデスクトップ統合が標準のダイアログに戻ることはありません。 |
Fusion Webアプリケーションからのページを表示する詳細は、9.4項「Fusion WebアプリケーションからのWebページの表示」を参照してください。 それ以外の、データをアップロードするために構成するアクション・セットの実行時の動作については、7.8.2項「実行時の処理: ADF表コンポーネントによるデータのアップロード」を参照してください。
ADFデスクトップ統合は、Table.Upload
操作時に正常にアップロードされたすべての行の変更を、1つ以上の行で失敗があった場合でもコミットします。たとえば、100行がアップロードされ、3行のみで失敗があった場合は、97行がデータベースにコミットされます。詳細は、7.8項「ADF表コンポーネントからの変更のアップロード」を参照してください。
UploadAllOrNothing
アクションを使用すると、すべての行が正常にアップロードされた場合にかぎり変更されたすべての行をコミットするように、アップロード・プロセスを構成できます。たとえば、100行がアップロードされ、いくつかの行で失敗があった場合は、行はデータベースにコミットされません。
UploadAllOrNothing
アクションで非常に多くの変更済ワークシート行をアップロードすると、アプリケーション・サーバーでのメモリー消費量が大幅に増加する可能性があります。これは、すべての行が正常に処理された場合のみUploadAllOrNothing
アクションがコミットするためです。このため、UploadAllOrNothing
アクションは、大きいデータ・セットでの使用を対象にしていません。UploadAllOrNothing.ChangedDataLimit
サーブレット・パラメータを使用して、UploadAllOrNothing
アクションでアップロードできるデータの量を制限できます。UploadAllOrNothing.ChangedDataLimit
サーブレット・パラメータの詳細は、7.9.3項「UploadAllOrNothingアクションを使用してアップロードできる変更済データの量の制限」を参照してください。
ワークシート・リボン・コマンドなどのADFコンポーネントを構成し、アクション・セットを起動します。これは、続いてADF表コンポーネントのUploadAllOrNothing
アクションを起動します。
始める前に:
ADFコンポーネントを構成してデータをADF表データ・コンポーネントからアップロードする方法を理解しておくと役立ちます。詳細は、7.9項「UploadAllOrNothingアクションを使用したADF表コンポーネントからの変更のアップロード」を参照してください。
他のADFデスクトップ統合の機能を使用して追加できる機能についても理解しておくと役立ちます。詳細は、7.1.2項「表タイプ・コンポーネントの追加機能」を参照してください。
UploadAllOrNothingアクションを使用するためにADFコンポーネントを構成するには:
統合Excelワークブックを開きます。
「Oracle ADF」タブで、「ワークシート・プロパティ」ボタンをクリックし、実行時にエンド・ユーザーがアクション・セットを起動するのに使用するリボン・コマンドを追加します。ワークシートにリボン・コマンドを追加する方法の詳細は、9.3.2項「実行時リボン・タブのワークシート・リボン・コマンドの構成方法」を参照してください。
アクションの編集ダイアログを開いて、ADF表コンポーネントのアクションを起動するアクション・セットを構成します。
アクション・セットの詳細は、9.2項「アクション・セットの使用」を参照してください。
ADF表コンポーネントのUploadAllOrNothing
アクションを、実行時にアクション・セットにより起動されるアクションのリストに追加します。
「OK」をクリックします。
UploadAllOrNothing
アクションを選択した場合、ADFデスクトップ統合は、すべての行が正常にアップロードされた場合にかぎり、行の変更をコミットします。
注意: UploadAllOrNothing アクションは、Upload アクションと同じ方法でデータをアップロードします。Upload アクションおよびUploadAllOrNothing アクション時にデータがアップロードされる方法の詳細は、7.8.2項「実行時の処理: ADF表コンポーネントによるデータのアップロード」を参照してください。 |
UploadAllOrNothing
アクション時に、ADFデスクトップ統合は、CommitBatchActionID
によって指定されたアクションが起動される前に、変更されたすべてのワークシート行をアップロードします。1つ以上の行レベルの失敗があると、FailureActionID
によって指定されたアクションは起動されますが、CommitBatchActionID
によって指定されたアクションは起動されません。
失敗があると、「変更済」列のすべての値は未変更のままになります。「ステータス」列には、エラーを含む行に対してメッセージが表示されますが、エラーのない行ではすべて空のままです。すべての行が正常にコミットされると、「変更済」列の値は消去され、アップロードされた行の「ステータス」列は成功を示します。
注意:
|
UploadAllOrNothing
アクションで非常に多くの変更済ワークシート行をアップロードすると、アプリケーション・サーバーでのメモリー消費量が大幅に増加する可能性があります。このため、これは、大きいデータ・セットでの使用を対象にしていません。UploadAllOrNothing
アクションの実行時にエンド・ユーザーが非常の多くのデータをアップロードすることを防ぐために、アップロードできる変更済データの合計を制限するUploadAllOrNothing.ChangedDataLimit
サーブレット・パラメータを設定します(Kb
で指定)。パラメータ値が指定されない場合は、デフォルトの制限値の10,240 Kb
が使用されます。このサーブレット・パラメータにデフォルトより大きい値を指定する場合は、パフォーマンスおよびスケーラビリティのテストと分析を実行し、アプリケーション・サーバーへの影響を測定するようにしてください。
変更済データのアップロードの合計がUploadAllOrNothing.ChangedDataLimit
値を超過すると、エンド・ユーザーにエラー・メッセージが報告され、UploadAllOrNothing
アクションが中止されます。変更済データの制限を超過すると、Table.RowActions.FailureActionID
によって指定されたアクションが起動されます。
アップロード可能な変更済データの量の上限を変更する手順:
Fusion Webアプリケーションのweb.xml
ファイルを開きます。
表7-7の説明に従って、UploadAllOrNothing.ChangedDataLimit
サーブレット・パラメータを追加します。
web.xml
ファイルを保存します。
Fusion Webアプリケーションをリビルドして再起動します。
例7-1に、ADFデスクトップ統合のweb.xml
ファイルのSummitサンプル・アプリケーションのUploadAllOrNothing.ChangedDataLimit
のエントリを示します。
例7-1 UploadAllOrNothing.ChangedDataLimitサーブレット・パラメータを含むweb.xmlファイル
<servlet> <servlet-name>adfdiRemote</servlet-name> <servlet-class>oracle.adf.desktopintegration.servlet.DIRemoteServlet</servlet-class> <init-param> <param-name>UploadAllOrNothing.ChangedDataLimit</param-name> <param-value>10240</param-value> </init-param> </servlet>
ADF表コンポーネントは、アクション(DeleteFlaggedRows
)を公開します。このアクションは起動されると、ADF表コンポーネントでフラグの付いた行に対応するFusion Webアプリケーションの行を削除します。ADF表コンポーネントでフラグの付けられた行とは、7.11項「ADF表コンポーネントでのバッチ処理」
に示すように、エンド・ユーザーがダブルクリックしたか、_ADF_FlagColumn列のセルに文字を入力した行です。_ADF_FlagColumn
列を構成してFusion Webアプリケーションの行を削除するには、列がADF表コンポーネントに存在する必要があります。
また、ADF表コンポーネントをホストするワークシートに関連付けるページ定義ファイルは、Delete
アクション・バインディングを公開する必要があります。
ADF表コンポーネントから行を削除するには、Delete
アクション・バインディングをページ定義ファイルに追加し、ADF表コンポーネントのRowActions
プロパティ・グループを構成して、さらにアクション・セットを構成してDeleteFlaggedRows
アクションを起動する必要があります。
始める前に:
ADF表コンポーネントを構成してFusion Webアプリケーションのデータ行を削除する方法を理解しておくと役立ちます。詳細は、7.10項「Fusion WebアプリケーションでのADF表コンポーネント行の削除」を参照してください。
他のADFデスクトップ統合の機能を使用して追加できる機能についても理解しておくと役立ちます。詳細は、7.1.2項「表タイプ・コンポーネントの追加機能」を参照してください。
ADF表コンポーネントを構成して、Fusion Webアプリケーションで行を削除するには:
JDeveloperでFusion Webアプリケーションを開きます。
存在しない場合は、Delete
アクション・バインディングを、ADF表コンポーネントをホストするExcelワークシートに関連付けられたページ定義ファイルに追加します。
詳細は、4.2項「統合Excelワークブックのページ定義ファイルの使用」を参照してください。
ADF表コンポーネントのプロパティ・インスペクタを開いて、表7-8に示すようにRowActions
プロパティ・グループの値を設定します。
表7-8 ADF表コンポーネントのRowActionsプロパティ
設定するプロパティ | 目的 |
---|---|
|
ページ定義ファイルで公開された |
|
デフォルト値は |
ADF表コンポーネント・プロパティの詳細は、A.11項「ADF表コンポーネントのプロパティおよびアクション」を参照してください。
「OK」をクリックします。
統合Excelワークブックを開きます。
「Oracle ADF」タブで、「ワークシート・プロパティ」ボタンをクリックし、実行時にエンド・ユーザーがアクション・セットを起動するのに使用するリボン・コマンドを追加します。ワークシートにリボン・コマンドを追加する方法の詳細は、9.3.2項「実行時リボン・タブのワークシート・リボン・コマンドの構成方法」を参照してください。
ADF表コンポーネントのDeleteFlaggedRows
アクションを、実行時にアクション・セットにより起動されるアクションのリストに追加します。
アクション・セットの起動の詳細は、9.2項「アクション・セットの使用」を参照してください。
(オプション)失敗した場合でも、アクション・セットで処理を継続する場合は、DeleteFlaggedRows
アクションのOptions.AbortOnFailure
プロパティをFalse
に設定します。デフォルト値はTrue
です。
「OK」をクリックします。
エンド・ユーザーは、7.12.1項「ADF表コンポーネントでの行のフラグ付け」で説明されているように、削除する行にフラグを付けます。それからエンド・ユーザーはアクション・セットを起動します。次に示す一連のイベントが発生します。
指定があれば、BatchOptions.StartBatchActionID
プロパティに参照されるアクション・バインディングが起動されます。
この手順での失敗はエラーとして処理されます。エラーがあると、アクション・セットの起動が停止します。また、アクション・セットにエラー条件が返されます。ActionSet.FailureActionID
プロパティにアクション・バインディングが指定されている場合、アクション・セットは指定されたアクション・バインディングを起動します。
バッチ・オプションの構成の詳細は、7.11項「ADF表コンポーネントでのバッチ処理」を参照してください。
アクション・セットは、ADF表コンポーネントでフラグ付けされた行ごとに、ツリー・バインディング・イテレータを正しい行に配置し、RowActions.DeleteRowActionID
で指定されたdelete-typeアクション・バインディングを起動します。
注意: ADF表コンポーネントのDownload アクションを最後に起動した後に挿入され、Fusion Webアプリケーションにアップロードされていない行は、削除のフラグが付いていても無視されます。 |
ADF表コンポーネントでフラグ付けされた各行について、RowActions.DeleteRowActionID
で指定されたdelete-typeアクション・バインディングが失敗した場合、次のイベントはDeleteFlaggedRows
アクションのOptions.AbortOnFailure
プロパティで指定した値に依存します。False
の場合、アクション・セットは、最初の失敗時に停止することなく、フラグ付けされたすべての行の削除を試みます。フラグ付けされた行の削除がアクション・セットで失敗すると、その行は次のようになります。
ADF表コンポーネントに残る
ADF表コンポーネントの「ステータス」列でFailed
とマークされる
正常に削除されたフラグ付きの行のバッチをアクション・セットがコミットする際にスキップされる
「フラグ付き」列のセルにフラグを付けたままにする
DeleteFlaggedRows
アクションのOptions.AbortOnFailure
プロパティがTrue
(デフォルト値)に設定されている場合、ADF表コンポーネントはDeleteFlaggedRows
アクションの起動を停止します。
BatchOptions.CommitBatchActionID
プロパティにアクション・バインディングが指定されている場合、アクション・セットがそれを起動します。この手順に失敗した場合、アクション・セットはバッチ処理を停止します。失敗がなかった場合、アクション・セットはBatchOptions.StartBatchActionID
プロパティによって指定されたアクション・バインディングを起動することにより、すべてのバッチがアクションによって処理されるまで次のバッチを処理します。
アクション・セットがすべてのバッチを正常に処理した場合、ActionOptions.SuccessActionID
プロパティにアクション・バインディングが指定されていれば、このプロパティにより指定されたアクション・バインディングが起動されます。RowActions.DeleteRowActionID
で指定されているdelete-typeアクション・バインディングが起動して、Fusion Webアプリケーションにより削除された行がワークシートから削除され、アクション・セットに成功コードが戻されます。
アクションがバッチを処理する間に失敗があった場合、アクション・セットはそのActionOptions.FailureActionID
プロパティで指定されたアクション・バインディングを起動します(このプロパティにアクション・バインディングが指定されている場合)。このアクション・バインディングは、アクション・セットに失敗コードを返します。
アクション・セットがアクションを起動する際に予期しない例外が発生した場合、アクション・セットにエラー・コードが返されます。関連するすべてのエラー・メッセージがステータス・ビューアに表示されます。詳細は、13.2項「ステータス・ビューアを使用したエンド・ユーザーへのエラー・メッセージのレポート」を参照してください。
注意: Excelフィルタが適用されたADF表でDeleteFlaggedRows アクションが起動されると、Excelフィルタの条件がクリアされ、非表示のExcelワークシート行が表示されますが、フィルタは削除されません。 |
パフォーマンスとスケーラビリティを最適化するために、ADF表コンポーネントのUpload
およびDeleteFlaggedRows
アクションは、行単位ではなく、バッチで変更をコミットします。バッチのサイズや、バッチのアップロード時にADF表コンポーネントが起動するアクションを決定するバッチ・オプションのプロパティを構成できます。
ADF表コンポーネントには、ADF表コンポーネントによる行のバッチの管理を構成できるプロパティ・グループ(BatchOptions
)があります。これらのプロパティの詳細は、A.11項「ADF表コンポーネントのプロパティおよびアクション」を参照してください。
始める前に:
ADF表コンポーネントのアップロード・データ、削除データ、およびバッチ・プロセスの両方のタスクについて理解しておくと役立ちます。詳細は、7.8.2項「実行時の処理: ADF表コンポーネントによるデータのアップロード」、7.10.2項「実行時の処理: Fusion Webアプリケーション内でのADF表コンポーネントによる行の削除」および7.11項「ADF表コンポーネントでのバッチ処理」を参照してください。
他のADFデスクトップ統合の機能を使用して追加できる機能についても理解しておくと役立ちます。詳細は、7.1.2項「表タイプ・コンポーネントの追加機能」を参照してください。
ADF表コンポーネントのバッチ・オプションを構成するには:
統合Excelワークブックを開きます。
ADF表コンポーネントを参照するExcelワークシートのセルを選択し、「Oracle ADF」タブの「プロパティの編集」ボタンをクリックします。
表示されたプロパティ・インスペクタでBatchOptions
プロパティ・グループの値を設定します。
表7-9 RowData.BatchOptionsプロパティ
設定するプロパティ | 目的 |
---|---|
|
ADF表コンポーネント・アクション( |
|
ADF表コンポーネントがそれぞれのバッチを処理した後で起動するアクション・バインディング。通常これは |
|
ADF表コンポーネントですべての行をアップロードする場合、または失敗時に行をアップロードしない場合、このプロパティを |
|
(オプション)各バッチの開始時に起動するアクション・バインディングを指定します。 |
「OK」をクリックします。
エンティティ・レベルでの失敗はバッチの失敗とは見なされません。コミット・レベルでの失敗(たとえば、外部キー属性の間違った値)はバッチの失敗と見なされます。
ADF表コンポーネントからデータをアップロードする際に、特定の状況でエンド・ユーザーにエラーがレポートされる可能性があります。バッチからの変更を記録した後に、ADFデスクトップ統合はCommitBatchActionID
で指定されたアクションを実行します。CommitBatchActionID
によって指定されたアクションの実行中に失敗があったバッチの行では、失敗の詳細がステータス・ビューアに表示されます。変更があったバッチの行は、失敗時にBatch Failed
が「ステータス」列に表示される前に、サーバーに正常にポストされます。
コミット・アクション中に発生したエラーは、それ以降のレコードのバッチにエラーがなくても、後に続くバッチ・コミット・アクションで引き続き報告される可能性があります。これは、CommitBatchActionID
アクションが失敗し、保留中のモデル更新が自動的に元に戻らなかった場合に発生する可能性があります。このようなエラーを回避するには、コミットが失敗した後に存在する保留中のモデル更新を明示的に元に戻す必要があります。たとえば、最初に保留中のモデル変更をコミットしようとするカスタムのアクションをCommitBatchActionID
に作成します。ただし、コミット中に例外が発生した場合は、カスタム・メソッドは後に続くすべてのバッチ・コミットが成功するように、最初に保留中のモデル変更をロールバックする必要があります。
注意: クライアントで期待されるとおりにコミット・エラーが報告されるように、ロールバック後にコミットの例外がスローされることが重要です。 |
ADF表コンポーネントには、ワークシートにADF表コンポーネントを挿入する際にいくつかの列がデフォルトで含まれています。これらの列は、必要に応じてそのまま残しておくことも、削除することもできます。次に、これらの列とその目的を示します。
_ADF_ChangedColumn
この列のセルは、ADF表コンポーネントの行の変更を追跡します。ダウンロードまたは最後に成功したアップロード以降にADF表コンポーネントの行のデータを変更した場合、上向き矢印のような記号が、_ADF_ChangedColumn
列の対応するセルに表示されます。ユーザーのこの列のセルをダブルクリックすると、この記号は切り替わります(表示または非表示)。図7-12に例を示します。
注意: エンド・ユーザーがADF表コンポーネントのUpload アクションで、この列によってマークされた行の変更をアップロードしない場合、ユーザーは対応するセルに表示されるエントリをクリアする必要があります。 |
ADF表コンポーネントがUpload
アクションを起動すると、空でないセルを含むすべての行が_ADF_ChangedColumn
列にアップロードされます。詳細は、7.8項「ADF表コンポーネントからの変更のアップロード」を参照してください。
_ADF_FlagColumn
エンド・ユーザーがこの列のセルをダブルクリックすると、対応する行がフラグ付けされた行処理としてフラグ付けされます。実線の円記号が表示され、フラグ付けされた行処理のために行にフラグが付けられたことが示されます。この列の詳細は、7.12.1項「ADF表コンポーネントでの行のフラグ付け」を参照してください。
注意: デフォルトでは、実線の円記号はフラグ付けされた行処理としてフラグ付けされた行を示します。ただし、_ADF_FlagColumn の空白でないセルは、フラグ付けされた行処理のために対応する行にフラグを付けます。 |
_ADF_StatusColumn
この列は、DeleteFlaggedRows
やUpload
などのADF表コンポーネント・アクションの起動の結果をレポートします。
_ADF_StatusColumn
のセルにメッセージが表示され、対応する行の起動結果が示されます。エンド・ユーザーがADF表列で定義されたDoubleClickActionSet
を起動してエラーが発生した場合、そのエラーは対応する行の「ステータス」列でもレポートされます。図7-13に、アップロードが失敗した行の「ステータス」列のメッセージの例を示します。ステータスの詳細は、13.2項「ステータス・ビューアを使用したエンド・ユーザーへのエラー・メッセージのレポート」で説明されているステータス・ビューアに表示されます。
_ADF_RowKeyColumn
「キー」列とも呼ばれるこの列には、実行時にADFデスクトップ統合によって使用されるADF表コンポーネントに関する重要な情報が含まれます。この列は実行時と設計時の両方に表示されます。「キー」列は、ADF表コンポーネントが正しく機能するために必要なため、削除しないでください。その外観に関連するプロパティを構成できます。
_ADF_RowKeyColumn
の詳細は、7.13項「ADF表コンポーネントのキー列の構成」を参照してください。
ADF表コンポーネントでは、_ADF_ChangedColumn
列、_ADF_FlagColumn
列、_ADF_RowKeyColumn
列および_ADF_StatusColumn
列のプロパティは、それが参照する他の列のプロパティとは別の方法で処理されます。InsertComponent
、InsertUsesUpdate
、UpdateComponent
などのプロパティの値セットは、表A-13に示すようなDisplayRowErrors
アクションを起動する場合を除いて無視されます。CellStyleName
やHeaderStyleName
など、スタイルや外観に関連するプロパティの値が読み取られます。
ADF表コンポーネントには、フラグの付いた処理で行を簡単に選択できる_ADF_FlagColumn
列がデフォルトで含まれています。_ADF_FlagColumn
列のセルをダブルクリックすると、対応する行にコンポーネント・アクションによって起動されるアクションによる処理のフラグが付きます。
エンド・ユーザーが_ADF_FlagColumn
列のセルをダブルクリックすると、セルに実線の円が表示されるか非表示になり、その行にフラグが付いているかどうかが示されます。図7-14はフラグの付いた列の例を示します。
注意: デフォルトでは、実線の円記号はフラグ付けされた行処理としてフラグ付けされた行を示します。ただし、_ADF_FlagColumn 列の空白でないセルは、フラグ付けされた行処理のために対応する行にフラグを付けます。 |
次のコンポーネント・アクションは、フラグ付けされた行に対して起動できます。
DeleteFlaggedRows
DownloadFlaggedRows
すべての行にフラグを付けるにはFlagAllRows
コンポーネント・アクションを、ADF表コンポーネントのすべての行からフラグを取るにはUnflagAllRows
コンポーネント・アクションを使用できます。
注意:
|
これらのコンポーネント・アクションの使用は、ADF表コンポーネントの_ADF_FlagColumn
列があるかどうかによって決まります。ADF表コンポーネントから_ADF_FlagColumn
列を削除すると、これらのコンポーネント・アクションはいずれも起動できません。これらのコンポーネント・アクションの詳細は、A.11.3項「ADF表コンポーネントのアクション」を参照してください。
実行時にはエンド・ユーザーは以前にリストされたすべてのコンポーネント・アクションをアクション・セットから起動できます。起動されたコンポーネント・アクションは、フラグ付けされたすべての行を処理します。たとえば、フラグ付けされたすべての行をダウンロードまたは削除します。コンポーネント・アクションを起動するアクション・セットの構成の詳細は、9.2.2項「アクション・セット内のコンポーネント・アクションの起動方法」を参照してください。
統合ExcelワークブックにADF表を追加すると、設計時に「キー」列(列ID: _ADF_RowKeyColumn
)が自動的に表示されます。「キー」列には、ADFデスクトップ統合で表が正しく機能するために使用される重要な情報が含まれます。実行時には「キー」列を削除しないでください。
「キー」列の位置、スタイルのプロパティ、ヘッダー・ラベルを構成できます。デフォルトでは、Key Cell
スタイルが適用されます。
始める前に:
ADF表コンポーネントのキー列について理解しておくと役立ちます。詳細は、7.13項「ADF表コンポーネントのキー列の構成」を参照してください。
他のADFデスクトップ統合の機能を使用して追加できる機能についても理解しておくと役立ちます。詳細は、7.1.2項「表タイプ・コンポーネントの追加機能」を参照してください。
「キー」列を構成するには:
統合Excelワークブックを開きます。
ADF表コンポーネントを参照するExcelワークシートのセルを選択し、「Oracle ADF」タブの「プロパティの編集」ボタンをクリックします。
「コンポーネントの編集: ADF表」ダイアログで、Columnsの入力フィールドの横にある参照(...)アイコンをクリックします。
「列の編集」ダイアログが表示され、選択したADF表コンポーネントのすべての列が一覧表示されます。
ID
が_ADF_RowKeyColumn
の列を選択します。
必要に応じて列のプロパティを変更します。ただし、次のプロパティは変更しないでください。
DynamicColumn
InsertComponent
InsertUsesUpdate
UpdateComponent
ID
Visible
必要に応じて、上矢印キーと下矢印キーを使用して列の位置を変更し、列の外観を決定するプロパティの値(Label
、Tooltip
およびStyle
)を変更します。
「OK」をクリックして、「列の編集」ダイアログを閉じます。
「OK」をクリックして、コンポーネントの編集: ADF表ダイアログを閉じます。
旧バージョンのADFデスクトップ統合を使用して準備および構成された統合Excelワークブックを使用する場合、設計時に「キー」列は使用できません。この列は実行時にのみ表示されます。「キー」列のプロパティを構成するには、設計時にこれをワークブックに追加します。
始める前に:
ADF表コンポーネントのキー列について理解しておくと役立ちます。詳細は、7.13項「ADF表コンポーネントのキー列の構成」を参照してください。
他のADFデスクトップ統合の機能を使用して追加できる機能についても理解しておくと役立ちます。詳細は、7.1.2項「表タイプ・コンポーネントの追加機能」を参照してください。
設計時に手動で「キー」列を追加するには:
統合Excelワークブックを開きます。
ADF表コンポーネントを参照するExcelワークシートのセルを選択し、「Oracle ADF」タブの「プロパティの編集」ボタンをクリックします。
表7-10の説明に従って、ADF表に新しい列を追加してプロパティを指定します。列の追加の詳細は、7.3.2項「ADF表コンポーネントへの列の追加方法」を参照してください。
表7-10 「キー」列のプロパティ
設定するプロパティ | 値 |
---|---|
|
|
|
|
|
|
|
|
|
|
|
|
|
Valueのプロパティは空白にする必要があります。 |
|
|
必要に応じて、上矢印キーと下矢印キーを使用して列の位置を変更し、列の外観を決定するプロパティの値(Label
、Tooltip
およびStyle
)を変更します。
「OK」をクリックします。
注意: 新しい列のID プロパティを_ADF_RowKeyColumn に指定する必要があります。そうしなければ、この列は「キー」列と見なされず、実行時に別の「キー」列が自動的に表示されます。 |
ビュー・オブジェクトによって返される使用可能な属性に応じて、実行時にADF表コンポーネントが拡張または収縮するように、ADF表コンポーネントに動的な列を追加できます。TableColumn
配列内にあるColumns
グループのDynamicColumn
プロパティによって、この動作は制御されます。列を動的にするには、DynamicColumn
プロパティをTrue
に設定します。TableColumn
配列の動的な列とは、属性名が設計時に認識されていないツリー・バインディングまたはツリー・ノード・バインディングにバインドされている列です。動的な列は、実行時に複数のワークシートの列に拡張できます。
ADF表コンポーネントの動的な列は、次のサブコンポーネント・タイプをサポートしています。
ModelDrivenColumnComponent
入力テキスト
出力テキスト
注意: ADFデスクトップ統合は、動的な列にあるサブコンポーネント・タイプTreeNodeListをサポートしていません。 |
モデルドリブンの値リストのサポート
また、動的な列を構成して、サブコンポーネント・タイプが実行時のモデルの構成から決定される値リスト・サブコンポーネントをサポートできます。設計時には、UpdateComponent
プロパティまたはInsertComponent
プロパティに対して、サブコンポーネント・タイプをModelDrivenColumnComponent
と指定します。実行時には、動的な列の拡張の際に、値リストをキャッシュする前にモデルドリブンのランタイム・コンポーネントが決定されます。リモート・サーブレットによって、クライアントはモデル構成を取得でき、クライアントは希望する列のサブコンポーネント・タイプを選択できるようになります。詳細は、7.15項「ADF表コンポーネントへのModelDrivenColumnComponentサブコンポーネントの追加」および8.3項「ADF表コンポーネント列での値リストの作成」を参照してください。
注意: 複数の<nodeDefinition> 要素を含むツリー・バインディングがADF表コンポーネントで使用される場合、動的な列に使用されるモデルドリブン・リストの名前は、すべてのノードで一意である必要があります。 |
EL式を次の形式で、ADF表コンポーネント列のInsertComponent
プロパティによってサブコンポーネントとして指定されたコンポーネントのValue
プロパティについて指定することにより、動的な列は、構成します。
#{bindings.TreeID.[TreeNodeID].AttributeNamePrefix*.inputValue}
または
#{bindings.TreeID.AttributeNamePrefix*.inputValue}
説明:
TreeID
はADF表コンポーネントで使用されるツリー・バインディングのIDです。
TreeNodeID
は、ツリー・ノード・バインディングIDを指定するオプションの値です。この値を省略する場合は、属性がどのツリー・ノード・バインディングに属するかに関係なく、ツリー・バインディングからの一致するすべての属性が表示されます。
AttributeNamePrefix
は、ツリー・バインディングの基底にあるイテレータ内に存在する属性のサブセットを識別します。AttributeNamePrefix
の値を指定しない場合、ツリー・バインディングまたはツリー・バインディング・ノードのすべての属性が返されます。常に*
文字を使用してください。
注意: 動的な列を追加する際、ツリー・ノード属性名がページ定義ファイルで指定されていないことを確認してください。実行時には、ツリー・ノード・オブジェクトは基底にあるイテレータからすべての属性名を返します。ページ定義ファイルに指定された属性名がある場合、ツリー・ノード・オブジェクトはそのリストに基づいて、使用可能な属性名のリストを限定します。 |
次の例は、EmpTree
バインディングのmodel.EmpView
ノードにある、"period
"で始まる名前を持つすべての属性を返します。
#{bindings.EmpTree.[model.EmpView].period*.inputValue}
宣言型SQLモードによるビュー・オブジェクトのサポート
宣言型SQLモードで構成され、実行時にカスタマイズされたビュー・オブジェクトをサポートするために、属性が定義されていないページ定義ファイルのツリー・バインディングを公開します。例:
<tree IterBinding="DeclSQLModeIterator" id="DeclSQLModeTree"> <nodeDefinition Name="DeclSQLModeTreeNode"/> </tree>
実行時に、ツリー・バインディングは選択した属性を、基礎となる宣言型SQLモード・ビュー・オブジェクトから統合Excelワークシートへ戻します。
ADF表コンポーネントのDownload
アクションまたはDownloadForInsert
アクションが起動されると、ADF表コンポーネントは一致する属性の最新のセットが含まれるように動的な列を自動的に更新します。Download
が起動されるたびに、ADFデスクトップ統合は動的な列に対して、すべての行に同じ属性セットがあることを要求します。Download
の際に属性のセットが行ごとに異なる場合、エラーが発生することがあります。
動的な列がInsert
操作とUpdate
操作をどちらもサポートする場合、動的な列のInsertComponent
サブコンポーネントとUpdateComponent
サブコンポーネントについて、Value
プロパティに同じEL式を指定する必要があります。実行時には、ADF表コンポーネントはEL式により返される属性バインディングの値を表示する動的な列を含むように拡張します。
通常、一致する属性のセットは、ADF表コンポーネントのDownload
アクションの起動からUpload
アクションの起動までの間は変更されません。ただし、ADF表コンポーネントがUpload
アクションを起動したときに、以前にダウンロードした属性がツリー・バインディングにもう存在しない場合、統合Excelワークブックは、データのアップロードを続行するかどうか決めるようエンド・ユーザーにプロンプトを表示します。前述のシナリオ(ダウンロードした属性がツリー・バインディングにもう存在しない)を回避する方法の詳細は、第16章「複数のWebセッション間における統合Excelワークブックの使用」を参照してください。
次の構文を使用して、動的な列のHeaderLabel
プロパティにEL式を記述します。
#{bindings.TreeID.[TreeNodeID].hints.AttributeNamePrefix*.label}
または
#{bindings.TreeID.hints.AttributeNamePrefix*.label}
動的な列でInsert
操作およびUpdate
操作がサポートされている場合、動的な列のInsertComponent
およびUpdateComponent
のValue
プロパティに指定するものと同じツリー・バインディングID、ツリー・ノード・バインディングID、および属性名の接頭辞の値を、動的な列のHeaderLabel
プロパティで指定します。
エンド・ユーザーが値を入力しなければならない必須の列に、記号や文字列でマークを付ける場合は、HeaderLabel
プロパティを構成する必要があります。次の構文を使用して、すべての必須の列に記号や文字列を追加するEL式を記述します。
=IF(#{bindings.
TreeID
.[TreeNodeID]
.hints.*.mandatory}, "
<prefix_for_mandatory_cols>
", "") & "#{bindings.
TreeID
.[
TreeNodeID
].hints.*.label}"
たとえば、次のEL式は必須の列のラベルにアスタリスク(*)文字を追加します。
=IF(#{bindings.MyTree.[myapp.model.MyChildNode].hints.*.mandatory}, "* ", "") & "#{bindings.MyTree.[myapp.model.MyChildNode].hints.*.label}"
展開したすべての列に同じスタイルを適用できる場合は、動的な列のCellStyleName
プロパティにリテラル・スタイル名を指定します。
ただし、展開した別の列に異なるスタイルが必要な場合、動的な列のCellStyleName
プロパティにEL式を指定する必要があります。
adfdiCellStyle
などのカスタム属性プロパティを使用して、属性ごとに異なるスタイルを指定できます。次の構文は、CellStyleName
EL式に使用されます。
#{bindings.TreeID.[TreeNodeID].hints.*.adfdiCellStyle}
カスタム属性プロパティの詳細は、10.8項「ADFデスクトップ統合ELベースのプロパティとカスタム属性プロパティの使用」を参照してください。
または、より複雑なEL式をスタイル名の計算に使用して、属性ごとに異なるスタイルを指定できます。
次の例では、すべてのdate列にMyDateStyle
スタイルが適用され、他のデータ型の列にはMyDefaultStyle
が適用されます。
=IF("#{bindings.MyTree.[myapp.model.MyChildNode].hints.*.dataType}"="date", "MyDateStyle", "MyDefaultStyle")
EL式の詳細は、付録B「ADFデスクトップ統合のEL式」を参照してください。
ModelDrivenColumnComponentは、ADF表コンポーネントを挿入したときのデフォルトのサブコンポーネントです。列サブコンポーネントのタイプは、サーバー上に指定された列の属性のコントロール・タイプのヒントにより、実行時に決まります。
設計時には、列について、UpdateComponent
プロパティまたはInsertComponent
プロパティに対して、サブコンポーネント・タイプをModelDrivenColumnComponent
と指定します。実行時に、属性に関連付けられたモデルドリブン・リストがある場合、列は、モデルドリブン・リスト項目を含むドロップダウン・リストを使用します。
注意:
|
モデルドリブン・リストの作成の詳細は、『Oracle Application Development Framework Fusion開発者ガイド』のモデルドリブン・リストの作成方法に関する項を参照してください。
ADF表コンポーネントの列幅を構成して、実行時に自動的にサイズ変更されるようすることができます。列は、Excelの列幅の自動調整機能を使用してサイズ変更できます。この機能は、列のデータ値に基づいて幅を決定します。ADFデスクトップ統合では、EL式から導出された明示的な幅値を使用して列をサイズ変更することもできます。
ADF表の列のサイズ変更の動作は、表レベルで構成されます。その後、列レベルでオーバーライドできます。
実行時の列幅のサイズ変更は、2ステップのプロセスです。まず、目的の幅関連プロパティ値で表の列を構成します。次に、ADF表コンポーネントのResizeColumns
アクションを目的のアクション・セットに追加します。通常は、アクション・セットのADF表コンポーネントのDownload
アクションの後に。このアクションを追加します。第2章「ADFデスクトップ統合のサンプル・アプリケーションの概要」に説明されているSummitサンプル・アプリケーションのEditCustomers-DT.xlsx
ワークブックは、この実装を示します。
設計時ResizeColumnsMode
プロパティを使用して、ADF表コンポーネントのすべての列の共通サイズ変更動作を指定できます。ResizeColumns
表コンポーネント・メソッドを使用して、サイズ変更がいつ行われるかを制御します。特定の列のサイズ変更動作をオーバーライドするには、列のResizeMode
プロパティを使用します。
始める前に:
これは、ADF表の列のサイズ変更動作の構成を理解するのに役立つことがあります。詳細は、7.16項「実行時にデータに基づいて列をサイズ変更するためのADF表コンポーネントの構成」を参照してください。
他のADFデスクトップ統合の機能を使用して追加できる機能についても理解しておくと役立ちます。詳細は、7.1.2項「表タイプ・コンポーネントの追加機能」を参照してください。
ADF表の列のサイズ変更動作を構成する手順:
統合Excelワークブックを開きます。
ADF表コンポーネントのセルを選択し、「Oracle ADF」タブの「プロパティの編集」ボタンをクリックします。
「コンポーネントの編集: ADF表」ダイアログで、ResizeColumnsMode
プロパティを表7-11の説明に従って構成および設定します。
表7-11 ADF表コンポーネントのResizeColumnsMode値
値 | 説明 |
---|---|
|
デフォルトです。表のすべての列のサイズは、その |
|
表の境界内のすべての列が、Excelの自動調整サポートを使用して最適なサイズに変更されます。ヘッダー・セルを含む列のセルのデータ値が最適なサイズの決定に使用されます。
表の上または下にある列のセルの値は、最適なサイズの検出時に考慮されません。 |
|
表の境界内のすべての列が、Excelの自動調整サポートを使用して最適なサイズに変更されます。ヘッダー・セルを除く列のセルのデータ値が最適なサイズの決定に使用されます。
表の上または下にある列のセルの値は、最適なサイズの検出時に考慮されません。 |
コマンドのサイズ変更動作を構成し、表レベルのサイズ変更動作をオーバーライドするには、ResizeMode
プロパティを設定します。
「コンポーネントの編集: ADF表」ダイアログで、Columns
プロパティを展開し、ResizeMode
プロパティを表7-12の説明に従って設定します。
表7-12 ADF表の列プロパティのResizeMode値
値 | 説明 |
---|---|
|
列はサイズ変更されません。列幅は現在の設定のままになります。 |
|
デフォルトです。列は表の
|
|
ヘッダー・セルを含め、列はExcelの自動調整サポートを使用して最適なサイズに変更されます。 |
|
ヘッダー・セルを除き、列はExcelの自動調整サポートを使用して最適なサイズに変更されます。 |
|
ADFデスクトップ統合では、 |
ADF表コンポーネントのResizeColumnsMode
プロパティがUseColumnValue
に設定され、列のResizeMode
プロパティがSpecifiedWidth
に設定されている場合は、Column.Width
プロパティを、列に表示する文字数に設定します。
列のWidth
プロパティは、リテラル数値、または1から255までの数値に評価されるEL式に設定できます。属性としてUIヒントdisplayWidth
を利用するWidth
のEL式の例を次に示します。
#{bindings.Customers.hints.Name.displayWidth}
注意:
|
「OK」をクリックします。
ADF表コンポーネントのResizeColumns
アクションを呼び出すように、ワークシート・リボン・コマンドまたはワークシート・イベントのアクション・セットを構成できます。
多くの列および多くの行のある表のサイズ変更には時間がかかることがあります。
始める前に:
これは、ADF表の列のサイズ変更動作の構成を理解するのに役立つことがあります。詳細は、7.16項「実行時にデータに基づいて列をサイズ変更するためのADF表コンポーネントの構成」および9.2項「アクション・セットの使用」を参照してください。
他のADFデスクトップ統合の機能を使用して追加できる機能についても理解しておくと役立ちます。詳細は、7.1.2項「表タイプ・コンポーネントの追加機能」を参照してください。
ADF表コンポーネントの列をサイズ変更するようにアクション・セットを構成する手順:
統合Excelワークブックを開きます。
「Oracle ADF」タブで、「ワークシート・プロパティ」ボタンをクリックし、リボン・コマンドを追加します。ワークシートにリボン・コマンドを追加する方法の詳細は、9.3.1項「実行時リボン・タブのワークブック・リボン・コマンドの定義方法」を参照してください。
注意: リボン・コマンドを追加するかわりに、実行時にアクション・セットを起動するように、ワークシート・イベントを構成できます。 |
アクションの編集ダイアログを開き、アクション・セットを構成します。アクション・セットの起動の詳細は、9.2項「アクション・セットの使用」を参照してください。
ADF表コンポーネントResizeColumns
アクションを、実行時にアクション・セットにより起動されるアクションのリストに追加します。ResizeColumns
はコンポーネント・アクションです。
「OK」をクリックします。
図7-15に、EditCustomers-DT.xlsx
ワークブックのワークシートEvents
プロパティに構成されている設計時のResizeColumns
アクションを示します。
注意: ワークシートStartup イベントで起動されるアクション・セットを構成し、Download アクション後に、このアクション・セットがADF表コンポーネントのResizeColumns アクションを起動する場合は、Download アクションの前に、アクション・セットがADF表コンポーネントのInitialize アクションを起動することを確認してください。図7-15に、この構成を示します。 |
ADF表の列は、アクション・セット内のTable.ResizeColumns
コンポーネント・アクションの実行結果としてサイズ変更されます(7.16.2項「実行時にADF表コンポーネントの列をサイズ変更するようにアクション・セットを構成する方法」を参照)。
ADF表コンポーネントの列を含むワークシート全体の列は、Table.ResizeColumnsMode
およびColumn.ResizeMode
プロパティの値に応じてサイズ変更されます。表の列のサイズ変更は、表の境界外の同じExcelワークシート列にあるセルまたは他のコンポーネント(フォーム・コンポーネントなど)の内容に影響します。
実行時に列のサイズが変更されるようにアクション・セットで構成されたADF表コンポーネントがワークシートに2つ以上含まれる場合、ADF表コンポーネントは、それらのサイズを個別に変更することを試みます。ただし、最後に実行されるADF表コンポーネントのResizeColumns
アクションは、列の幅を設定します。
ヒント: 複数のADF表コンポーネントを含むワークシートの場合は、プライマリ表に対してのみResizeColumns アクションをコールします。 |
注意:
|
たとえば、ADF表コンポーネントにレンダリングされる列のグループ・ヘッダーをレンダリングし、列のグループに説明ラベルを使用することで、エンド・ユーザーに直感的なインタフェースを提供できます。図7-22に、ADFデスクトップ統合のSummitサンプル・アプリケーションのEditAllInventory-DT.xlsx
ワークブックで、「製品」から補充日の列を在庫の詳細グループ・ヘッダーにグループ化し、「倉庫」から「国」の列が倉庫の詳細の列のグループにグループ化されている例を示します。
ADFデスクトップ統合には、実行時に、ADF表コンポーネントの標準の表ヘッダー行の上部に追加の表ヘッダー行をレンダリングすることで、図7-16に示す機能が実装されます。ADF表コンポーネントのいずれかの列定義にGroupHeader
プロパティを構成すると、この追加の表ヘッダー行がレンダリングされます。この機能を動的な列に実装することもできます。この機能を動的な列に実装する場合は、7.17.2項「動的な列でレンダリングする列をグループ化する方法」に説明されているカスタム属性を定義する必要があります。静的および動的な列にGroupHeader
プロパティを構成する方法の詳細は、7.17.1項「ADF表コンポーネントで列をグループ化する方法」を参照してください。
実行時に、既存のデータとスタイルが上書きされ、追加の表ヘッダー行がレンダリングされるため、グループ列に追加の表ヘッダー行をレンダリングする場合は、ADF表コンポーネントの上の行にデータとスタイルがない状態にします。
列のグループの開始列と終了列にGroupHeader
プロパティを構成して、ADF表コンポーネントの列をグループ化します。
始める前に:
ADF表コンポーネントで列をどのようにグループ化できるかについて理解しておくと役立ちます。詳細は、7.17項「ADF表コンポーネントでの列のグループ化」を参照してください。
他のADFデスクトップ統合の機能を使用して追加できる機能についても理解しておくと役立ちます。詳細は、7.1.2項「表タイプ・コンポーネントの追加機能」を参照してください。
動的な列にレンダリングされるヘッダー列をグループ化する場合は、7.17.2項「動的な列でレンダリングする列をグループ化する方法」の説明に従って、カスタム属性プロパティを定義します。この手順は、静的な列でヘッダー列をグループ化する場合は不要です。
ADF表コンポーネントで列をグループ化する手順:
統合Excelワークブックを開きます。
ADF表コンポーネントを参照するExcelワークシートのセルを選択し、「Oracle ADF」タブの「プロパティの編集」ボタンをクリックします。
「コンポーネントの編集: ADF表」ダイアログで、Columnsプロパティの参照(...)アイコンをクリックします。
「列の編集」ダイアログが表示され、選択したADF表コンポーネントのすべての列が一覧表示されます。
「列の編集」ダイアログで、列のグループを開始する列を選択します。
「列の編集」ダイアログの右側ウィンドウで、「レイアウト」フィールドのGroupHeaderプロパティを展開し、表7-13の説明に従って、プロパティを構成します。
表7-13 ADF表コンポーネントのグループの開始列のGroupHeaderプロパティ
設定するプロパティ | 設定する値 |
---|---|
|
これにより、列が列のグループの開始として定義されます。 列のグループの開始として動的な列を定義する場合は、7.17.2項「動的な列でレンダリングする列をグループ化する方法」の説明に従って、 |
|
このプロパティを文字列、または実行時に列グループ・ヘッダーのラベルに評価されるEL式に設定します。評価された値は、開始列のセルにレンダリングされます。列グループ・ヘッダーの開始列には、このプロパティの値が必要です。値を指定しないと、実行時に列グループ・ヘッダーが形成されません。ラベルの詳細は、10.4項「統合Excelワークブックでのラベルの使用」を参照してください。 ラベル・テキストが表示されるExcelセルを編集して、このプロパティを編集することもできます。セルのテキストを編集すると、このプロパティのみが直接影響を受けます。 |
|
このプロパティをワークブックで定義するスタイル、またはスタイル名に評価されるEL式に設定します。名前付きスタイルは、実行時に列グループのヘッダー・セルに適用されます。スタイルの詳細は、第10章「統合Excelワークブックの外観の構成」を参照してください。 |
|
(オプション)ツールチップを指定します。指定したツールチップは、グループの終了列の追加の表ヘッダー・セルからレンダリングされます。詳細は、7.17.3項「実行時の処理: ADF表コンポーネントによる列のグループ化」を参照してください。 ツールチップの詳細は、10.6.1項「ADF表コンポーネントへのツールチップの追加方法」を参照してください。 |
図7-17に、図7-16に示すEditAllInventory-DT.xlsx
ワークブックの在庫の詳細の列のグループを開始するようにGroupHeader
に構成された値を示します。
「列の編集」ダイアログで、列のグループを終了する列を選択します。
「列の編集」ダイアログの右側ウィンドウで、「レイアウト」カテゴリのGroupHeaderプロパティを展開し、次のプロパティを構成します。
Boundary
: end
または、end
に評価されるEL式に設定します。
これにより、列が列のグループの終了として定義されます。
列のグループの終了として動的な列を定義する場合は、7.17.1項「ADF表コンポーネントで列をグループ化する方法」の説明に従って、end
の値のカスタム属性プロパティを定義し、このカスタム属性プロパティの値を取得するEL式を記述します。
残りのプロパティの値はGroupHeader
に設定しないでください。手順5で開始列に設定した値により、実行時に列のヘッダーのグループにレンダリングされるラベル、スタイルおよびツールチップが決定されます。
注意: 開始列と終了列の間の列には、プロパティを設定する必要はありません。実行時に、統合Excelワークブックで、終了列として構成した列の左側に開始列が見つからない場合、終了列に指定した値は無視されます。 |
「OK」をクリックします。
注意: 実行時に、既存のデータとスタイルが上書きされ、ADF表コンポーネントの上に表示される追加の表ヘッダー行がレンダリングされるため、列をグループ化する場合は、ADF表コンポーネントの上の行にデータとスタイルがない状態にしてください。 |
動的な列は、実行時に複数のワークシートの列に拡張できます。実行時に、統合Excelワークブックは、動的な列の展開後に、GroupHeader
プロパティに定義されたEL式を評価します。GroupHeader
プロパティの評価結果に応じて、列グループが形成され、統合Excelワークブックによって、動的な列にグループ化済ヘッダーがレンダリングされます。
動的な列にレンダリングされる列のGroupHeader
プロパティを構成するには、実行時に動的な列にレンダリングされるビュー・オブジェクト属性で、最初にカスタム属性プロパティを定義します。
実行時に動的な列のグループ化済ヘッダーの開始境界線と終了境界線をレンダリングする属性に、カスタム属性プロパティを定義します。EL式を使用して、実行時にGroupHeader
Boundary
、Label
、StyleName
およびTooltip
プロパティで参照される開始属性にカスタム属性プロパティを構成します。EL式を使用して、実行時にGroupHeader
Boundary
プロパティで参照される終了属性にカスタム属性プロパティを構成します。
カスタム属性プロパティの定義の詳細は、10.8項「ADFデスクトップ統合ELベースのプロパティとカスタム属性プロパティの使用」を参照してください。
図7-18に、グループ化されたヘッダーを開始するカスタム属性プロパティを定義する属性(住所)を示します。
図7-19に、グループ化されたヘッダーを終了するカスタム属性プロパティを定義する属性(コメント)を示します。
実行時に、動的な列が展開し、ビュー・オブジェクトの属性の列がレンダリングされます。この例では、展開された列は、グループ化されたヘッダーをレンダリングするように構成された「住所」、「市区町村」および「コメント」です。図7-20に、設計時に動的な列に構成するGroupHeader
プロパティを示します。実行時に、図7-18および図7-19に示す構成済のカスタム属性プロパティの値がEL式で取得され、評価されます。「詳細」のラベルの付いたグループ化されたヘッダーにより、「住所」、「市区町村」および「コメント」の列が形成されます。
GroupHeader
プロパティの構成方法の詳細は、7.17.1項「ADF表コンポーネントで列をグループ化する方法」を参照してください。
GroupHeader
プロパティに値を構成すると、実行時に、ADF表コンポーネントの標準の表ヘッダー行の上に、追加の表ヘッダー行がレンダリングされます。各グループの開始列のLabel
、StyleName
およびTooltip
プロパティに指定した値により、グループ・ヘッダーのラベル、スタイルおよびツールチップが決定されます。列グループの他の列のこれらのGroupHeader
プロパティに構成した値は無視されます。
開始列として構成した列のGroupHeader.StyleName
プロパティによって指定されたスタイルは、グループのすべての列の追加の表ヘッダー・セルに適用されます。グループ・ヘッダー・ラベルの水平方向の配置は、グループのすべての列の追加の表ヘッダー・セルの中央になります。
開始列のGroupHeader.Tooltip
プロパティによって定義されたツールチップは、図7-21に示すように、グループの終了列の追加の表ヘッダー・セルにレンダリングされます。
開始列および終了列として構成した列が実行時にレンダリングされることを確認します。開始列として構成した列が実行時にレンダリングされない場合、列グループは形成されません。たとえば、列1を開始列、列3を終了列として構成し、そのVisible
プロパティがfalseを返すために、列1が実行時にレンダリングされない場合、列グループは形成されません。同様に、列3がレンダリングされないと、列1、列2および列3にまたがる列グループも形成されません。かわりに、列1が単一列のグループとしてレンダリングされます。
ADF表コンポーネントには、7.19項「ADF読取り専用表コンポーネントの作成」に説明されているADF読取り専用表コンポーネントでは使用できない機能が複数提供されます。ADF表コンポーネントで使用可能な機能の例には、動的な列、列のグループ化機能、および列のサイズ変更の機能があります。このため、ADF読取り専用表コンポーネントを作成するのではなく、ADF表コンポーネントを作成して、読取り専用として構成するようにしてください。Summitサンプル・アプリケーションのCustomerSearch-DT.xlsx
ワークブックには、読取り専用として構成されているADF表コンポーネントが含まれます。
ADF表コンポーネントを読取り専用にするには、RowActions
UpdateRowEnabled
およびInsertRowEnabled
プロパティをFalse
に設定して、_ADF_ChangedColumn
、_ADF_FlagColumn
および_ADF_StatusColumn
列をADF表コンポーネントから削除します。
始める前に:
ADF表コンポーネントについて理解しておくと役立ちます。詳細は、7.18項「読取り専用にするためのADF表コンポーネントの構成」を参照してください。
他のADFデスクトップ統合の機能を使用して追加できる機能についても理解しておくと役立ちます。詳細は、7.1.2項「表タイプ・コンポーネントの追加機能」を参照してください。
7.3項「ExcelワークシートへのADF表コンポーネントの挿入」の説明に従って、ADF表コンポーネントを統合Excelワークブックに挿入します。
ADF表コンポーネントを読取り専用に構成する手順:
統合Excelワークブックを開きます。
ADF表コンポーネントを参照するExcelワークシートのセルを選択し、「Oracle ADF」タブの「プロパティの編集」ボタンをクリックします。
「コンポーネントの編集: ADF表」ダイアログで、ADF表コンポーネントのRowActions.UpdateRowEnabled
プロパティをFalse
に設定します。
「コンポーネントの編集: ADF表」ダイアログで、Columnsプロパティの参照(...)アイコンをクリックします。
「列の編集」ダイアログが表示され、ADF表コンポーネントのすべての列がリストされます。
_ADF_ChangedColumn、_ADF_FlagColumnおよび_ADF_StatusColumn列を選択し、「列の編集」の削除をクリックして、これらの列を削除します。
(オプション)各列のUpdateComponent
コンポーネント・タイプ値をModelDrivenColumnComponent
からOutputText
に変更することを検討してください。
これは、ビュー・オブジェクトが読取り専用として構成されている場合は不要です。これは、ADF表コンポーネントをツリー・バインディングから作成する場合に、各UpdateComponent
のReadOnly
プロパティが、対応するreadOnly
属性ヒントにデフォルトでバインドされているためです。CustomerSearch-DT.xlsx
ワークブックは、この実装を示しています。
(オプション)読取り専用のセルと編集可能なセルを視覚的に区別できるように、各列のCellStyleName
プロパティをRead-only Cell
に変更することを検討してください。
詳細は、10.2項「スタイルの使用」を参照してください。
「OK」をクリックします。
実行時、ADF読取り専用表コンポーネントは、参照するツリー・バインディングのデータを表示する、連続した範囲のセルにまたがる表をレンダリングします。エンド・ユーザーが編集できないデータを表示する場合に、このコンポーネントを使用します。
注意: ADF表コンポーネントには、ADF読取り専用表コンポーネントで使用できない機能が複数用意されています。このため、ADF読取り専用表コンポーネントを作成するのではなく、ADF表コンポーネントを作成して、読取り専用として構成することを検討してください。詳細は、7.18項「読取り専用にするためのADF表コンポーネントの構成」を参照してください。 |
ADF読取り専用表コンポーネントは、Download
アクションの起動時にコンポーネントがダウンロードする行数を決定するRowLimit
などの複数のプロパティをサポートします。また、これには実行時にExcelワークシートに表示されるツリー・バインディングの列を決定するプロパティ・グループ(Columns
)も含まれます。TreeID
プロパティは、コンポーネントが参照するツリー・バインディングを指定します。これらのプロパティや、ADF読取り専用表コンポーネントがサポートする他のプロパティの詳細は、A.12項「ADF読取り専用表コンポーネントのプロパティおよびアクション」を参照してください。
注意:
|
ADFデスクトップ統合デザイナの作業ウィンドウを使用して、ADF読取り専用表コンポーネントをワークシートに挿入します。
始める前に:
ADF読取り専用表コンポーネントについて理解しておくと役立ちます。詳細は、7.19項「ADF読取り専用表コンポーネントの作成」を参照してください。
他のADFデスクトップ統合の機能を使用して追加できる機能についても理解しておくと役立ちます。詳細は、7.1.2項「表タイプ・コンポーネントの追加機能」を参照してください。
ADF読取り専用表コンポーネントを挿入するには:
統合Excelワークブックを開きます。
コンポーネントを配置するExcelワークシートのセルを選択します。
表コンポーネントへの挿入の際、2つの表のデータが実行時に重複しないことと、選択したセルがマージされたセルでないことを確認する必要があります。
バインディング・パレットで、ADF読取り専用表コンポーネントを作成するバインディングを選択して、バインディングの挿入をクリックします。
表示されるダイアログで、「ADF読取り専用表」を選択します。
注意: または、コンポーネント・パレットまたは「Oracle ADF」タブを使用しても、ADF読取り専用表コンポーネントを挿入できます。「ADF読取り専用表」を選択して、コンポーネントの挿入をクリックします。コンポーネント・パレットを使用してコンポーネントを作成する場合は、実行時にコンポーネントに表示されるそれぞれの列を追加する必要があります。 |
表示されるプロパティ・インスペクタでプロパティを構成し、表示される列とコンポーネントが実行時に起動するアクションを決定します。
「OK」をクリックします。
注意: コンポーネントのプロパティを後から変更するには、コンポーネントを配置するワークシートのセルを選択して、プロパティ・インスペクタを表示します。表コンポーネントを削除するには、「削除」リボン・コマンドを使用します。詳細は5.14項「ADFデスクトップ統合コンポーネントの削除」を参照してください。 |
ADF表またはADF読取り専用表コンポーネントがダウンロードする行数は、コンポーネントのRowLimit
プロパティ・グループの値を設定すれば構成できます。また、必要に応じて、ダウンロード可能な行数が指定した行数を超過したときにエンド・ユーザーに警告する警告メッセージを表示できます。
Download
アクションを起動するときにコンポーネントがダウンロードする行数を、RowLimit.MaxRows
プロパティの値として指定します。オプションで、ダウンロード可能な行数がRowLimit.MaxRows
で指定した値を超過した場合に、エンド・ユーザーがメッセージを受信するように、RowLimit.WarningMessage
プロパティのEL式を記述します。
始める前に:
ADF表コンポーネントにデータをダウンロードする際に行数を制限する方法を理解しておくと役立ちます。詳細は、7.20項「表タイプ・コンポーネントがダウンロードする行数の制限」を参照してください。
他のADFデスクトップ統合の機能を使用して追加できる機能についても理解しておくと役立ちます。詳細は、7.1.2項「表タイプ・コンポーネントの追加機能」を参照してください。
表タイプ・コンポーネントがダウンロードする行数を制限するには:
統合Excelワークブックを開きます。
表タイプ・コンポーネントを参照するExcelワークシートのセルを選択し、「Oracle ADF」タブの「プロパティの編集」ボタンをクリックします。
詳細は、9.2項「アクション・セットの使用」を参照してください。
表7-14
の説明に従って、RowLimitプロパティ・グループのプロパティを構成します。これらのプロパティの詳細は、A.1項「ADFデスクトップ統合で頻繁に使用するプロパティ」を参照してください。
表7-14 RowLimitプロパティ・グループ
設定するプロパティ | 設定する値 |
---|---|
|
|
|
ダウンロードする最大行数に評価されるEL式を記述します。 |
|
このプロパティにEL式を記述して、ダウンロード可能な行数が このプロパティの値がNULLの場合、 |
「OK」をクリックします。
図7-22は、ADF表コンポーネントの行の制限が構成されているEditCustomers-DT.xlsx
ワークブックの「コンポーネントの編集」ダイアログを示しています。
表タイプ・コンポーネントのDownload
アクションが起動されると、RowLimit.MaxRows
の値として指定した行数がFusion Webアプリケーションからダウンロードされます。RowLimit.MaxRowsにEL式を指定したり、デフォルト値を変更しない場合、図7-23
に示すものに似たメッセージ・ダイアログが表示されます。
エンド・ユーザーは、ADF表コンポーネントをホストする統合Excelワークブックのセルで、データを作成したり変更できます。
列が更新可能で読取り専用でなければ、変更の追跡がアクティブ化されます。エンド・ユーザーが次の変更を行うと、変更の追跡がアクティブ化されます。
セルの値の編集
セルの値の挿入または削除
どこかでコピーした値をADF表コンポーネント列のセルに貼り付ける場合
エンド・ユーザーが対応する行のデータを変更した場合、上向きの矢印に似た記号が_ADF_ChangedColumn
列に表示されます。図7-24に例を示します。
この記号は、コンポーネントのReadOnly
プロパティの値がFalse
に設定されているコンポーネントによってホストされているデータを、エンド・ユーザーが変更すると表示されます。ModelDrivenColumnComponentなどの様々なサブコンポーネントに、ReadOnly
プロパティがあります。True
あるいはFalse
に評価されるこのReadOnly
プロパティに、EL式またはリテラル文字列を記述できます。True
に評価される静的な文字列またはEL式を記述する場合、_ADF_ChangedColumn
列には記号は表示されません。ReadOnly
EL式と変更トラッキングの詳細は、7.22項「読取り専用プロパティのEL式の評価」を参照してください。
表の列の読取り専用プロパティのEL式にバインディング式(#{row.bindings.color.inputValue}
など)が含まれる場合、その式の実行時の評価は、評価が行われるタイミングによって異なります。評価は次のときに行われます。
データのダウンロード(Download
、DownloadFlaggedRows
、DownloadForInsert
)
データのアップロード(Upload
、UploadAllOrNothing
)および変更トラッキング
Upload
中、またはエンド・ユーザーが変更可能表の値を変更する場合、EL式はDownload
とは異なる方法で評価されます。具体的には、EL式の評価の前に、空白の文字列がバインディング式に対して置換されます。
たとえば、次のEL式が編集可能コールにある場合:
=IF("#{row.bindings.color.inputValue}"="RED", True, False)
Upload
中、またはエンド・ユーザーが変更可能表の値を変更する場合、EL式は=IF(""="RED", True, False),
に評価され、常にFalse
が返されます。
注意: 変更のトラッキング中に、列コンポーネントValue プロパティは評価されません。このため、たとえば、構成した値のEL式に関係なく、新しく挿入した行のセル値は空白になります。 |
Upload
および変更トラッキング中に、EL式を適切に評価するためには、サーバーとの追加のデータ転送がバインディング値を取得するために必要です。サーバーとの追加のデータ転送はパフォーマンスにマイナスの影響を与え、エンド・ユーザーに現在有効なセッションがない場合には新しいログインが必要になることもあります。
注意: 同じEL式の評価の動作は、表の変更トラッキング中に新しいワークシートの行を挿入する場合、CellStyleName EL式に適切に適用されます。 |
動作の違いにより、可能ならば、バインディング式を含む読取り専用EL式は避ける必要があります。ただし、指定したユースケースが読取り専用式で属性値を使用することが重要な場合、ワークシートの保護をAutomatic
へ設定することを検討する必要があります。ワークシート保護の詳細は、10.7項「ワークシート保護の使用」を参照してください。
たとえば、次のEL式がセルにある場合:
=IF("#{row.bindings.color.inputValue}"="RED", True, False)
Download
中に、この列のRED
セルをLocked
に設定すると、エンド・ユーザーはこれらのセルを編集できません。