데이터 스키마

다음은 Adobe Campaign의 데이터 스키마 사용에 관한 몇 가지 일반적인 원칙입니다.

Adobe Campaign에서 데이터 스키마 생성 및 구성에 대한 자세한 내용은 이 섹션을 참조하십시오.

스키마 구조

스키마 이름 <srcschema> 및 해당 네임스페이스를 채우려면 데이터 스키마의 XML 문서에 이름네임스페이스 특성이 있는 루트 요소를포함해야 합니다.

<srcSchema name="schema_name" namespace="namespace">
...
</srcSchema>

스키마의 진입점은 기본요소입니다. 스키마와 동일한 이름을 가지며 루트 요소의 자식이어야 하므로 쉽게 식별할 수 있습니다. 컨텐츠의 설명은 이 요소로 시작합니다.

컨텐츠 관리 스키마에서 기본 요소는 다음 줄로 표시됩니다.

<element name="book" template="ncm:content" xmlChildren="true">

기본 요소에 입력된 템플릿 속성을 사용하면 일반 속성이 있는 스키마를 이름, 생성 날짜, 작성자, 연결된 문자열 등의 모든 컨텐츠 정의로 확장할 수 있습니다.

이러한 속성은 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> 요소를 강화할 수 있습니다.

컨텐츠 관리에 사용되는 기본 속성은 다음과 같습니다.

  • 레이블:간략한 설명,
  • desc:자세한 설명,
  • 기본값:표현식 컨텐츠 생성 시 기본값 반환,
  • userEnum:이 필드를 통해 입력한 값을 저장하고 표시하는 자유 열거형입니다.
  • enum:가능한 값 목록을 미리 알 때 사용되는 열거형을 수정했습니다.

다음은 속성이 채워진 예제 스키마입니다.

<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> 요소가 수집 요소입니다. 언바운드 ​속성은 이러한 요소의 정의에 추가해야 합니다.

<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> 추가

<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>

장 구조는 기본 요소 외부에 이름이 "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 내용을 입력할 수 있습니다.

소스 스키마가 저장되면 확장 스키마 생성이 자동으로 시작됩니다.

노트

이름 ​편집 컨트롤을 사용하면 이름 및 네임스페이스로 구성된 스키마 키를 입력할 수 있습니다. 스키마 루트 요소의 이름네임스페이스 속성은 스키마의 XML 편집 필드에서 자동으로 업데이트됩니다.

이 페이지에서는