Adobe Campaign のデータスキーマ使用に関する一般的な原理を一部紹介します。
Adobe Campaign でのデータスキーマの作成と設定について詳しくは、この節を参照してください。
データスキーマの XML ドキュメントには、name 属性と namespace 属性が設定された <srcschema>
ルート要素が必要です。これにより、スキーマの名前と名前空間が指定されます。
<srcSchema name="schema_name" namespace="namespace">
...
</srcSchema>
スキーマのエントリポイントは、スキーマのメイン要素です。メイン要素はスキーマと同じ名前なので、識別は容易です。また、メイン要素はルート要素の子でなければなりません。コンテンツの記述は、この要素から始まります。
コンテンツ管理スキーマでは、メイン要素は次の行で表されます。
<element name="book" template="ncm:content" xmlChildren="true">
template 属性をメイン要素に入力することで、汎用プロパティを持つスキーマを、名前、作成日、作成者、関連付けられた文字列などすべてのコンテンツ定義に拡張できます。
これらのプロパティは、ncm:content スキーマに記述します。
xmlChildren 属性が存在する場合、メイン要素に入力するデータ構造がコンテンツインスタンスの XML ドキュメントに保存されるということを意味します。
新しいスキーマを作成するときや、スキーマ拡張の際には、スキーマ全体で同じプライマリキーシーケンス値(@pkSequence)を維持する必要があります。
タイプが設定されたコンテンツ管理スキーマの例を次に示します。
<srcSchema name="book" namespace="cus">
<element name="book" template="ncm:content" xmlChildren="true">
<attribute name="title" type="string"/>
<attribute name="date" type="date"/>
<attribute name="language" type="string"/>
<element name="chapter">
<attribute name="name" type="string"/>
<element name="page" type="string>
<attribute name="number" type="short"/>
</element>
</element>
</element>
</element>
様々なプロパティを使用して、データスキーマの <element>
要素と <attribute>
要素をエンリッチメントできます。
コンテンツ管理で使用する主なプロパティには次のものがあります。
プロパティが設定されたスキーマの例を次に示します。
<srcSchema name="book" namespace="cus">
<enumeration name="language" basetype="string" default="eng">
<value name="fra" label="French"/>
<value name="eng" label="English"/>
</enumeration>
<element name="book" label="Book" desc="Example book" template="ncm:content" xmlChildren="true">
<attribute name="title" type="string" label="Title" default="'New book'"/>
<attribute name="date" type="date" default="GetDate()"/>
<attribute name="language" type="string" label="Language" enum="language"/>
<element name="chapter" label="Chapter">
<attribute name="name" type="string" label="Name" desc="Name of chapter"/>
<element name="page" type="string" label="Page" desc="Page content">
<attribute name="number" type="short" label="Number" default="CounterValue('numPage')"/>
</element>
</element>
</element>
</srcSchema>
コレクションは、同じ名前と同じ階層レベルを持つ要素のリストです。
次の例では、<chapter>
要素と <page>
要素がコレクション要素です。したがって、unbound 属性をこれらの要素の定義に追加する必要があります。
<element name="chapter" label="Chapter" unbound="true" ordered="true">
<element name="page" type="string" label="Page" desc="Content of page" unbound="true">
ordered="true" 属性を指定することによって、挿入されるコレクション要素を並べ替えることができます。
コンテンツスキーマでは、要素の参照が多用されます。これにより、同じ構造を持つ他の要素でも参照できるように、<element>
要素の定義を分解できます。
参照先要素の ref 属性には、参照元要素のパス(XPath)を設定する必要があります。
例:サンプルのスキーマの <chapter>
要素と同じ構造を持つ Appendix 節の追加。
<srcSchema name="book" namespace="cus">
<element name="section">
<attribute name="name" type="string" label="Name" desc="Name"/>
<element name="page" type="string" label="Page" desc="Content of page">
<attribute name="number" type="short" label="Number" default="CounterValue('numPage')"/>
</element>
<element name="book" label="Book" desc="Example book" template="ncm:content" xmlChildren="true">
<attribute name="title" type="string" label="Title" default="'New book'"/>
<attribute name="date" type="date" default="GetDate()"/>
<attribute name="language" type="string" label="Language" enum="language"/>
<element name="chapter" label="Chapter" ref="section"/>
<element name="appendix" label="Appendix" ref="section"/>
</element>
</srcSchema>
chapter の構造は、メイン要素の外側にある「section」という名前の要素に移されます。chapter と section は、「section」要素を参照します。
計算文字列は、コンテンツインスタンスを表す文字列を構成するのに使用する XPath 式です。
計算文字列が設定されたスキーマの例を次に示します。
<srcSchema name="book" namespace="cus">
<element name="book" label="Book" desc="Example book" template="ncm:content" xmlChildren="true">
<compute-string expr="@name"/>
...
</element>
</srcSchema>
編集フィールドを使用して、ソーススキーマの XML コンテンツを入力できます。
ソーススキーマを保存すると、拡張スキーマ生成が自動的に開始されます。
「名前」編集コントロールを使用して、名前と名前空間で構成されるスキーマのキーを入力できます。スキーマのルート要素の name 属性と namespace 属性が、スキーマの XML 編集フィールドで自動的に更新されます。