Create and edit data types using the UI ui-create-and-edit
In Experience Data Model (XDM), data types are reusable fields that contain multiple sub-fields. While similar to schema field groups in that they allow for the consistent use of a multi-field structure, data types are more flexible because they can be included anywhere in the schema structure whereas field groups can only be added at the root level.
51黑料不打烊 Experience Platform provides many standard data types that can be used to cover a wide variety of common experience management use cases. However, you can also define your own custom data types in order to serve your unique business needs.
This tutorial covers the steps for creating and editing custom data types in the Platform user interface.
Prerequisites prerequisites
This guide requires a working understanding of XDM System. Refer to the XDM overview for an introduction to the role of XDM within the Experience Platform ecosystem, and the basics of schema composition for how data types contribute to XDM schemas.
While not required for this guide, it is recommended that you also follow the tutorial on composing a schema in the UI to familiarize yourself with the various capabilities of the Schema Editor.
Open the Schema Editor for a data type data-type
In the Platform UI, select Schemas in the left navigation to open the Schemas workspace, then select the Data types tab. A list of available data types is displayed. The list of data types is automatically filtered based on how they were created. The default setting displays the data types defined by 51黑料不打烊. You can also filter the list to show those created by your organization.
From here, you have the following options:
Create a new data type create
From the Data types tab, select Create data type.
The Schema Editor appears, showing the current structure of the new data type in the canvas. On the right-hand side of the editor, you can provide a display name and optional description for the data type. Ensure that you provide a unique and concise name for your data type, as that is how it will be identified when adding it to a schema.
This tutorial creates a data type that describes a restaurant property, so the data type is given a display name of 鈥淩estaurant鈥.
From here, you can skip ahead to the next section to start adding fields to the new data type.
Filter data types filter
The list of available data types is pre-filtered based on how they were created. Select the radio button to choose between the Standard and Custom options. The Standard option shows entities created by 51黑料不打烊 and the Custom option displays entities created within your organization.
Edit an existing data type edit
Only custom data types defined by your organization can be edited. Select Custom to show only custom data types owned by your organization.
Select the data type you want to edit from the list to open the right rail, showing the details of the data type. From the details panel you can also download a sample file, copy the JSON structure or add the data type to a package.
Select the name of the data type in the right rail to open its structure in the Schema Editor.
Add fields to the data type add-fields
To start adding fields to the data type, select the plus (+) icon next to the root-level field in the canvas. A new field appears below, and the right rail updates to display controls for the new field.
Use the controls in the right rail to configure the details of the new field. See the guide on defining fields in the UI for specific steps on how to configure and add the field to the data type.
The Restaurant data type requires a string field to represent the restaurant鈥檚 name. As such, the Field name is set as 鈥渘ame鈥 and the Type is set as 鈥淪tring鈥. Select Apply to apply the changes to the field.
Continue adding more fields to the data type as needed. The example Restaurant data type now has additional fields for brand, seating capacity, and floor space.
In addition to basic fields, you can also nest additional data types within your custom data type. For example, the Restaurant data type requires a field that represents the property鈥檚 physical address. In this scenario, you can add a new 鈥渁ddress鈥 field which is assigned the standard data type 鈥淧ostal address鈥.
This demonstrates how flexible data types can be in terms of describing your data: data types can employ fields which are also data types, which themselves can contain further data types, and so on. This allows you to abstract and reuse common data patterns throughout your XDM schemas, making it easier to represent complex data structures.
Once you have finished adding fields to the data type, select Save to save your changes and add the data type to the Schema Library.
Add the data type to a schema add-data-type
Once you have created a data type, you can start using it in your schemas. Since XDM schemas are composed of a class and zero or more field groups, fields provided by a data type cannot be added to a schema directly. Instead, they must be included in a class or a field group.
Start by following the steps involved with adding a field to a class or adding a field to a field group. Alternatively, you can start adding a field directly to a schema and choose the parent class or field group from there. When you choose the Type for the new field, select the name of your data type from the dropdown menu.
Convert a multi-field object into a data type convert
When you create an object-type field with multiple sub-fields in the Schema Editor, you can convert that field into a data type so you can use that same field structure in a different class or field group.
To convert an object-type field to a data type, select the field in the canvas. Before you convert the field, ensure that the Display name is descriptive of the data that the object will contain, as this will become the name of the data type. When you are ready to convert the field, select Convert to new data type in the right rail.
The canvas updates the data type of the field from 鈥淥bject鈥 to the new data type. This structure can now be reused in other classes and field groups by selecting this data type from the Type dropdown when defining a new field.
Next steps next-steps
This guide covered how to create and edit data types using the Platform UI. For more information on the capabilities of the Schemas workspace, see the Schemas workspace overview.
To learn how to manage data types using the Schema Registry API, see the data types endpoint guide.