模式特性

引用现有表的模式的特征如下:

  • Adobe Campaign不得修改相对于现有表的SQL对象,
  • 必须明确指定表和列的名称,
  • 必须声明索引。
重要

请勿删除标准收件人表中的字段,即使这些字段无用也是如此。 这可能会导致Adobe Campaign数据库中的行为错误。

视图属性

源架构接受 视图 属性 srcSchema 根元素。 在自定义表中处理Adobe Campaign时,必须使用该函数。 的 view="true" 属性告知数据库结构更新向导忽略此模式。 因此,禁止应用程序将表、其列及其索引与相应模式同步。

当此属性设置为 true,此模式仅用于生成SQL查询以访问此表的数据。

表和列的名称

当通过表更新向导创建表时,表和列的名称会根据各个架构和属性的名称自动生成。 但是,可以通过输入以下属性来强制使用SQL名称:

  • sqltable 在架构的主元素中,指定表,
  • sqlname 在每个属性中,指定列。

示例:

<element label="Individual" name="individual" sqltable="individual">
    <key internal="true" name="id">
      <keyfield xpath="@id"/>
    </key> 
    <attribute name="id" type="long" length="32" />
    <attribute name="lastName" type="string" length="100" sqlname="Last_Name"/>
    <attribute name="firstName" type="string" length="100" sqlname="First_Name"/>
    <attribute name="email" type="string" length="100"/>
    <attribute name="mobile" type="string" length="100"/>
</element>

在本例中,如果未明确指定表和列的名称,则应用程序将使用 CusIndivilual 对于桌子, lastNamefirstName 列。

在架构中,只能填充现有表列的一部分。 未填充的列将不允许用户访问。

索引字段

在客户端控制台中对列表记录进行排序时,对索引字段进行排序可获得更好的性能。 在架构中声明索引时,控制台会在列标签左侧的排序箭头下,以红线显示索引字段,如下所示:

在架构中,索引的定义如下:

<dbindex name="name_of_index" unique="true/false"
  <keyfield xpath="xpath_1st_field"/
  <keyfield xpath="xpath_2nd_field"/
  ...
</dbindex

因此,在匹配架构中声明自定义表的现有索引很重要。

为源模式的每个键和链接声明隐式声明索引。 通过指定 noDbIndex="true" 属性:

示例:

<key internal="true" name="customer" noDbIndex="true">
  <keyfield xpath="@customerId"/>
</key>

在此页面上