diff --git a/docs/odata-csdl-json/odata-csdl-json.html b/docs/odata-csdl-json/odata-csdl-json.html index f7120333b..81bded837 100644 --- a/docs/odata-csdl-json/odata-csdl-json.html +++ b/docs/odata-csdl-json/odata-csdl-json.html @@ -698,14 +698,14 @@
A CSDL JSON document consists of a single JSON object. This document object MUST contain the member $Version
.
The document object MAY contain the member $Reference
to reference other CSDL documents.
It also MAY contain members for schemas.
If the CSDL JSON document is the metadata document of an OData service, the document object MUST contain the member $EntityContainer
.
$Version
$Version
The value of $Version
is a string containing either 4.0
or 4.01
.
$EntityContainer
$EntityContainer
The value of $EntityContainer
is the namespace-qualified name of the entity container of that service. This is the only place where a model element MUST be referenced with its namespace-qualified name and use of the alias-qualified name is not allowed.
The Core.SchemaVersion
annotation, defined in OData-VocCore, MAY be used to indicate a particular version of the referenced document. If the Core.SchemaVersion
annotation is present, the $schemaversion
system query option, defined OData-Protocol, SHOULD be used when retrieving the referenced schema document.
$Reference
$Reference
The value of $Reference
is an object that contains one member per referenced CSDL document. The name of the pair is a URI for the referenced document. The URI MAY be relative to the document containing the $Reference
. The value of each member is a reference object.
The reference object MAY contain the members $Include
and $IncludeAnnotations
as well as annotations.
The alias MUST NOT be one of the reserved values Edm
, odata
, System
, or Transient
.
An alias is only valid within the document in which it is declared; a referencing document may define its own aliases for included schemas.
$Include
$Include
The value of $Include
is an array. Array items are objects that MUST contain the member $Namespace
and MAY contain the member $Alias
.
The item objects MAY contain annotations.
-$Namespace
$Namespace
The value of $Namespace
is a string containing the namespace of the included schema.
$Alias
$Alias
The value of $Alias
is a string containing the alias for the included schema.
The target namespace also provides consumers insight about what namespaces are present in the referenced document. If the consumer is not interested in that particular target namespace, the consumer can opt not to inspect the referenced document.
$IncludeAnnotations
$IncludeAnnotations
The value of $IncludeAnnotations
is an array. Array items are objects that MUST contain the member $TermNamespace
and MAY contain the members $Qualifier
and $TargetNamespace
.
$TermNamespace
$TermNamespace
The value of $TermNamespace
is a namespace.
$Qualifier
$Qualifier
The value of $Qualifier
is a simple identifier.
$TargetNamespace
$TargetNamespace
The value of $TargetNamespace
is a namespace.
The schema's namespace is combined with the name of elements in the schema to create unique qualified names, so identifiers that are used to name types MUST be unique within a namespace to prevent ambiguity.
Names are case-sensitive, but service authors SHOULD NOT choose names that differ only in case.
The namespace MUST NOT be one of the reserved values Edm
, odata
, System
, or Transient
.
A schema is represented as a member of the document object whose name is the schema namespace. Its value is an object that MAY contain the members $Alias
and $Annotations
.
The schema object MAY contain members representing entity types, complex types, enumeration types, type definitions, actions, functions, terms, and an entity container.
The schema object MAY also contain annotations that apply to the schema itself.
@@ -873,8 +873,8 @@If a schema specifies an alias, the alias MUST be used instead of the namespace within qualified names throughout the document to identify model elements of that schema. A mixed use of namespace-qualified names and alias-qualified names is not allowed.
Aliases are document-global, so all schemas defined within or included into a document MUST have different aliases, and aliases MUST differ from the namespaces of all schemas defined within or included into a document. Aliases defined by a schema can be used throughout the containing document and are not restricted to the schema that defines them.
The alias MUST NOT be one of the reserved values Edm
, odata
, System
, or Transient
.
$Alias
$Alias
The value of $Alias
is a string containing the alias for the schema.
$Alias
$Annotations
$Annotations
The value of $Annotations
is an object with one member per annotation target. The member name is a path identifying the annotation target, the member value is an object containing annotations for that target.
The entity type's name is a simple identifier that MUST be unique within its schema.
An entity type can define two types of properties. A structural property is a named reference to a primitive, complex, or enumeration type, or a collection of primitive, complex, or enumeration types. A navigation property is a named reference to another entity type or collection of entity types.
All properties MUST have a unique name within an entity type. Properties MUST NOT have the same name as the declaring entity type. They MAY have the same name as one of the direct or indirect base types or derived types.
-An entity type is represented as a member of the schema object whose name is the unqualified name of the entity type and whose value is an object.
The entity type object MUST contain the member $Kind
with a string value of EntityType
.
It MAY contain the members $BaseType
, $Abstract
, $OpenType
, $HasStream
, and $Key
.
An entity type MUST NOT introduce an inheritance cycle by specifying a base type.
-$BaseType
$BaseType
The value of $BaseType
is the qualified name of the base type.
An abstract entity type MUST NOT inherit from a non-abstract entity type.
-$Abstract
$Abstract
The value of $Abstract
is one of the Boolean literals true
or false
. Absence of the member means false
.
An entity type MAY indicate that it is open and allows clients to add properties dynamically to instances of the type by specifying uniquely named property values in the payload used to insert or update an instance of the type.
An entity type derived from an open entity type MUST indicate that it is also open.
Note: structural and navigation properties MAY be returned by the service on instances of any structured type, whether or not the type is marked as open. Clients MUST always be prepared to deal with additional properties on instances of any structured type, see OData-Protocol.
-$OpenType
$OpenType
The value of $OpenType
is one of the Boolean literals true
or false
. Absence of the member means false
.
An entity type that does not specify a base type MAY indicate that it is a media entity type. Media entities are entities that represent a media stream, such as a photo. Use a media entity if the out-of-band stream is the main topic of interest and the media entity is just additional structured information attached to the stream. Use a normal entity with one or more properties of type Edm.Stream
if the structured data of the entity is the main topic of interest and the stream data is just additional information attached to the structured data. For more information on media entities see OData-Protocol.
An entity type derived from a media entity type MUST indicate that it is also a media entity type.
Media entity types MAY specify a list of acceptable media types using an annotation with term Core.AcceptableMediaTypes
, see OData-VocCore.
$HasStream
$HasStream
The value of $HasStream
is one of the Boolean literals true
or false
. Absence of the member means false
.
If the key property is a property of a complex property (recursively) or of a directly related entity type, the key MUST specify an alias for that property that MUST be a simple identifier and MUST be unique within the set of aliases, structural and navigation properties of the declaring entity type and any of its base types.
An alias MUST NOT be defined if the key property is a primitive property of the entity type itself.
For key properties that are a property of a complex or navigation property, the alias MUST be used in the key predicate of URLs instead of the path to the property because the required percent-encoding of the forward slash separating segments of the path to the property would make URL construction and parsing rather complicated. The alias MUST NOT be used in the query part of URLs, where paths to properties don't require special encoding and are a standard constituent of expressions anyway.
-$Key
$Key
The value of $Key
is an array with one item per key property.
Key properties without a key alias are represented as strings containing the property name.
Key properties with a key alias are represented as objects with one member whose name is the key alias and whose value is a string containing the path to the property.
@@ -1101,8 +1101,8 @@The property's name MUST be a simple identifier. It is used when referencing, serializing or deserializing the property. It MUST be unique within the set of structural and navigation properties of the declaring structured type, and MUST NOT match the name of any navigation property in any of its base types. If a structural property with the same name is defined in any of this type's base types, then the property's type MUST be a type derived from the type specified for the property of the base type and constrains this property to be of the specified subtype for instances of this structured type. The name MUST NOT match the name of any structural or navigation property of any of this type's base types for OData 4.0 responses.
Names are case-sensitive, but service authors SHOULD NOT choose names that differ only in case.
-Structural properties are represented as members of the object representing a structured type. The member name is the property name, the member value is an object.
The property object MAY contain the member $Kind
with a string value of Property
. This member SHOULD be omitted to reduce document size.
It MAY contain the member $Type
, $Collection
, $Nullable
, $MaxLength
, $Unicode
, $Precision
, $Scale
, $SRID
, and $DefaultValue
.
The property's type MUST be a primitive type, complex type, or enumeration type in scope, or a collection of one of these types.
A collection-valued property MAY be annotated with the Core.Ordered
term, defined in OData-VocCore, to specify that it supports a stable ordering.
A collection-valued property MAY be annotated with the Core.PositionalInsert
term, defined in OData-VocCore, to specify that it supports inserting items into a specific ordinal position.
$Type
and $Collection
$Type
and $Collection
For single-valued properties the value of $Type
is the qualified name of the property's type.
For collection-valued properties the value of $Type
is the qualified name of the property's item type, and the member $Collection
MUST be present with the literal value true
.
Absence of the $Type
member means the type is Edm.String
. This member SHOULD be omitted for string properties to reduce document size.
For single-valued properties the facets apply to the value of the property. For collection-valued properties the facets apply to the items in the collection.
A Boolean value specifying whether the property can have the value null
.
$Nullable
$Nullable
The value of $Nullable
is one of the Boolean literals true
or false
. Absence of the member means false
.
For single-valued properties the value true
means that the property allows the null
value.
For collection-valued properties the property value will always be a collection that MAY be empty. In this case $Nullable
applies to items of the collection and specifies whether the collection MAY contain null
values.
$Nullable
A positive integer value specifying the maximum length of a binary, stream or string value. For binary or stream values this is the octet length of the binary data, for string values it is the character length (number of code points for Unicode).
If no maximum length is specified, clients SHOULD expect arbitrary length.
-$MaxLength
$MaxLength
The value of $MaxLength
is a positive integer.
Note: OData-CSDL-XML defines a symbolic value max
that is only allowed in OData 4.0 responses. This symbolic value is not allowed in CDSL JSON documents at all. Services MAY instead specify the concrete maximum length supported for the type by the service or omit the member entirely.
For a temporal value (datetime-with-timezone-offset, duration, or time-of-day): the number of decimal places allowed in the seconds portion of the value; it MUST be a non-negative integer between zero and twelve.
Note: service authors SHOULD be aware that some clients are unable to support a precision greater than 28 for decimal properties and 7 for temporal properties. Client developers MUST be aware of the potential for data loss when round-tripping values of greater precision. Updating via PATCH
and exclusively specifying modified properties will reduce the risk for unintended data loss.
Note: duration properties supporting a granularity less than seconds (e.g. minutes, hours, days) can be annotated with term Measures.DurationGranularity
, see OData-VocMeasures.
$Precision
$Precision
The value of $Precision
is a number.
Absence of $Precision
means arbitrary precision.
An integer value means that the number of digits to the right of the decimal point may vary from zero to the value of the Scale
facet, and the number of digits to the left of the decimal point may vary from one to the value of the Precision
facet minus the value of the Scale
facet. If Precision
is equal to Scale
, a single zero MUST precede the decimal point.
The value of Scale
MUST be less than or equal to the value of Precision
.
Note: if the underlying data store allows negative scale, services may use a Precision
with the absolute value of the negative scale added to the actual number of significant decimal digits, and client-provided values may have to be rounded before being stored.
$Scale
$Scale
The value of $Scale
is a number or a string with one of the symbolic values floating
or variable
.
Services SHOULD use lower-case values; clients SHOULD accept values in a case-insensitive manner.
Absence of $Scale
means variable
.
$Scale
For a string property the Unicode
facet indicates whether the property might contain and accept string values with Unicode characters (code points) beyond the ASCII character set. The value false
indicates that the property will only contain and accept string values with characters limited to the ASCII character set.
If no value is specified, the Unicode
facet defaults to true
.
$Unicode
$Unicode
The value of $Unicode
is one of the Boolean literals true
or false
. Absence of the member means true
.
For a geometry or geography property the SRID
facet identifies which spatial reference system is applied to values of the property on type instances.
The value of the SRID
facet MUST be a non-negative integer or the special value variable
. If no value is specified, the facet defaults to 0
for Geometry
types or 4326
for Geography
types.
The valid values of the SRID
facet and their meanings are as defined by the European Petroleum Survey Group EPSG.
$SRID
$SRID
The value of $SRID
is a string containing a number or the symbolic value variable
.
A primitive or enumeration property MAY define a default value that is used if the property is not explicitly represented in an annotation or the body of a request or response.
If no value is specified, the client SHOULD NOT assume a default value.
-$DefaultValue
$DefaultValue
The value of $DefaultValue
is the type-specific JSON representation of the default value of the property, see OData-JSON. For properties of type Edm.Decimal
and Edm.Int64
the representation depends on the media type parameter IEEE754Compatible
.
Names are case-sensitive, but service authors SHOULD NOT choose names that differ only in case.
-Navigation properties are represented as members of the object representing a structured type. The member name is the property name, the member value is an object.
The navigation property object MUST contain the member $Kind
with a string value of NavigationProperty
.
It MUST contain the member $Type
, and it MAY contain the members $Collection
, $Nullable
, $Partner
, $ContainsTarget
, $ReferentialConstraint
, and $OnDelete
.
A collection-valued navigation property MAY be annotated with the Core.Ordered
term, defined in OData-VocCore, to specify that it supports a stable ordering.
A collection-valued navigation property MAY be annotated with the Core.PositionalInsert
term, defined in OData-VocCore, to specify that it supports inserting items into a specific ordinal position.
$Type
and $Collection
$Type
and $Collection
For single-valued navigation properties the value of $Type
is the qualified name of the navigation property's type.
For collection-valued navigation properties the value of $Type
is the qualified name of the navigation property's item type, and the member $Collection
MUST be present with the literal value true
.
A Boolean value specifying whether the declaring type MAY have no related entity. If false, instances of the declaring structured type MUST always have a related entity.
Nullable MUST NOT be specified for a collection-valued navigation property, a collection is allowed to have zero items.
-$Nullable
$Nullable
The value of $Nullable
is one of the Boolean literals true
or false
. Absence of the member means false
.
If no partner navigation property is specified, no assumptions can be made as to whether one of the navigation properties on the target type will lead back to the source entity.
If a partner navigation property is specified, this partner navigation property MUST either specify the current navigation property as its partner to define a bi-directional relationship or it MUST NOT specify a partner navigation property. The latter can occur if the partner navigation property is defined on a complex type, or if the current navigation property is defined on a type derived from the type of the partner navigation property.
-$Partner
$Partner
The value of $Partner
is a string containing the path to the partner navigation property.
An entity type inheritance chain MUST NOT contain more than one navigation property with a partner navigation property that is a containment navigation property.
Note: without a partner navigation property, there is no reliable way for a client to determine which entity contains a given contained entity. This may lead to problems for clients if the contained entity can also be reached via a non-containment navigation path.
-$ContainsTarget
$ContainsTarget
The value of $ContainsTarget
is one of the Boolean literals true
or false
. Absence of the member means false
.
$ReferentialConstraint
$ReferentialConstraint
The value of $ReferentialConstraint
is an object with one member per referential constraint. The member name is the path to the dependent property, this path is relative to the structured type declaring the navigation property. The member value is a string containing the path to the principal property, this path is relative to the entity type that is the target of the navigation property.
It also MAY contain annotations. These are prefixed with the path of the dependent property of the annotated referential constraint.
SetDefault
, meaning all properties of related entities that are tied to properties of the source entity via a referential constraint and that do not participate in other referential constraints will be set to their default value.If no on-delete action is specified, the action taken by the service is not predictable by the client and could vary per entity.
-$OnDelete
$OnDelete
The value of $OnDelete
is a string with one of the values Cascade
, None
, SetNull
, or SetDefault
.
Annotations for $OnDelete
are prefixed with $OnDelete
.
The complex type's name is a simple identifier that MUST be unique within its schema.
A complex type can define two types of properties. A structural property is a named reference to a primitive, complex, or enumeration type, or a collection of primitive, complex, or enumeration types. A navigation property is a named reference to an entity type or a collection of entity types.
All properties MUST have a unique name within a complex type. Properties MUST NOT have the same name as the declaring complex type. They MAY have the same name as one of the direct or indirect base types or derived types.
-A complex type is represented as a member of the schema object whose name is the unqualified name of the complex type and whose value is an object.
The complex type object MUST contain the member $Kind
with a string value of ComplexType
. It MAY contain the members $BaseType
, $Abstract
, and $OpenType
. It also MAY contain members representing structural properties and navigation properties as well as annotations.
$BaseType
$BaseType
The value of $BaseType
is the qualified name of the base type.
A complex type MAY indicate that it is abstract and cannot have instances.
-$Abstract
$Abstract
The value of $Abstract
is one of the Boolean literals true
or false
. Absence of the member means false
.
A complex type MAY indicate that it is open and allows clients to add properties dynamically to instances of the type by specifying uniquely named property values in the payload used to insert or update an instance of the type.
A complex type derived from an open complex type MUST indicate that it is also open.
Note: structural and navigation properties MAY be returned by the service on instances of any structured type, whether or not the type is marked as open. Clients MUST always be prepared to deal with additional properties on instances of any structured type, see OData‑Protocol.
-$OpenType
$OpenType
The value of $OpenType
is one of the Boolean literals true
or false
. Absence of the member means false
.
The enumeration type's name is a simple identifier that MUST be unique within its schema.
Although enumeration types have an underlying numeric value, the preferred representation for an enumeration value is the member name. Discrete sets of numeric values should be represented as numeric values annotated with the AllowedValues
annotation defined in OData-VocCore.
Enumeration types marked as flags allow values that consist of more than one enumeration member at a time.
-An enumeration type is represented as a member of the schema object whose name is the unqualified name of the enumeration type and whose value is an object.
The enumeration type object MUST contain the member $Kind
with a string value of EnumType
.
It MAY contain the members $UnderlyingType
and $IsFlags
.
An enumeration type MAY specify one of Edm.Byte
, Edm.SByte
, Edm.Int16
, Edm.Int32
, or Edm.Int64
as its underlying type.
If not explicitly specified, Edm.Int32
is used as the underlying type.
$UnderlyingType
$UnderlyingType
The value of $UnderlyingType
is the qualified name of the underlying type.
An enumeration type MAY indicate that the enumeration type allows multiple members to be selected simultaneously.
If not explicitly specified, only one enumeration type member MAY be selected simultaneously.
-$IsFlags
$IsFlags
The value of $IsFlags
is one of the Boolean literals true
or false
. Absence of the member means false
.
Enumeration type members are represented as JSON object members, where the object member name is the enumeration member name and the object member value is the enumeration member value.
For members of flags enumeration types a combined enumeration member value is equivalent to the bitwise OR of the discrete values.
Annotations for enumeration members are prefixed with the enumeration member name.
@@ -1572,8 +1572,8 @@The type definition's name is a simple identifier that MUST be unique within its schema.
Type definitions can be used wherever a primitive type is used (other than as the underlying type in a new type definition) and are type-comparable with their underlying types and any type definitions defined using the same underlying type.
It is up to the definition of a term to specify whether and how annotations with this term propagate to places where the annotated type definition is used, and whether they can be overridden.
-A type definition is represented as a member of the schema object whose name is the unqualified name of the type definition and whose value is an object.
The type definition object MUST contain the member $Kind
with a string value of TypeDefinition
and the member $UnderlyingType
. It MAY contain the members $MaxLength
, $Unicode
, $Precision
, $Scale
, and $SRID
, and it MAY contain annotations.
The underlying type of a type definition MUST be a primitive type that MUST NOT be another type definition.
-$UnderlyingType
$UnderlyingType
The value of $UnderlyingType
is the qualified name of the underlying type.
The type definition MAY specify facets applicable to the underlying type. Possible facets are: $MaxLength
, $Unicode
, $Precision
, $Scale
, or $SRID
.
Bound actions support overloading (multiple actions having the same name within the same schema) by binding parameter type. The combination of action name and the binding parameter type MUST be unique within a schema.
Unbound actions do not support overloads. The names of all unbound actions MUST be unique within a schema.
An unbound action MAY have the same name as a bound action.
-An action is represented as a member of the schema object whose name is the unqualified name of the action and whose value is an array. The array contains one object per action overload.
The action overload object MUST contain the member $Kind
with a string value of Action
.
It MAY contain the members $IsBound
, $EntitySetPath
, $Parameter
, and $ReturnType
, and it MAY contain annotations.
A function is represented as a member of the schema object whose name is the unqualified name of the function and whose value is an array. The array contains one object per function overload.
The function overload object MUST contain the member $Kind
with a string value of Function
.
It MUST contain the member $ReturnType
, and it MAY contain the members $IsBound
, $EntitySetPath
, and $Parameter
, and it MAY contain annotations.
Unbound actions are invoked from the entity container through an action import.
Unbound functions are invoked as static functions within a common expression (see OData-URL, section 5.1.1), or from the entity container through a function import.
-$IsBound
$IsBound
The value of $IsBound
is one of the Boolean literals true
or false
. Absence of the member means false
.
The entity set path consists of a series of segments joined together with forward slashes.
The first segment of the entity set path MUST be the name of the binding parameter. The remaining segments of the entity set path MUST represent navigation segments or type casts.
A navigation segment names the simple identifier of the navigation property to be traversed. A type-cast segment names the qualified name of the entity type that should be returned from the type cast.
-$EntitySetPath
$EntitySetPath
The value of $EntitySetPath
is a string containing the entity set path.
A function MAY indicate that it is composable. If not explicitly indicated, it is not composable.
A composable function can be invoked with additional path segments or key predicates appended to the resource path that identifies the composable function, and with system query options as appropriate for the type returned by the composable function.
-$IsComposable
$IsComposable
The value of $IsComposable
is one of the Boolean literals true
or false
. Absence of the member means false
.
The facets Nullable
, MaxLength
, Precision
, Scale
, and SRID
can be used as appropriate to specify value restrictions of the return type, as well as the Unicode
facet for 4.01 and greater payloads.
For a single-valued return type the facets apply to the returned value. For a collection-valued return type the facets apply to the items in the returned collection.
$ReturnType
$ReturnType
The value of $ReturnType
is an object. It MAY contain the members $Type
, $Collection
, $Nullable
, $MaxLength
, $Unicode
, $Precision
, $Scale
, and $SRID
.
It also MAY contain annotations.
-$Type
and $Collection
$Type
and $Collection
For single-valued return types the value of $Type
is the qualified name of the returned type.
For collection-valued return types the value of $Type
is the qualified name of the returned item type, and the member $Collection
MUST be present with the literal value true
.
Absence of the $Type
member means the type is Edm.String
.
$Nullable
$Nullable
The value of $Nullable
is one of the Boolean literals true
or false
. Absence of the member means false
.
If the return type is a collection of entity types, the $Nullable
member has no meaning and MUST NOT be specified.
For other collection-valued return types the result will always be a collection that MAY be empty. In this case $Nullable
applies to items of the collection and specifies whether the collection MAY contain null
values.
The facets MaxLength
, Precision
, Scale
, or SRID
can be used as appropriate to specify value restrictions of the parameter, as well as the Unicode
facet for 4.01 and greater payloads.
For single-valued parameters the facets apply to the parameter value. If the parameter value is a collection, the facets apply to the items in the collection.
$Parameter
$Parameter
The value of $Parameter
is an array. The array contains one object per parameter.
A parameter object MUST contain the member $Name
, and it MAY contain the members $Type
, $Collection
, $Nullable
, $MaxLength
, $Unicode
, $Precision
, $Scale
, and $SRID
.
Parameter objects MAY also contain annotations.
-$Name
$Name
The value of $Name
is a string containing the parameter name.
$Type
and $Collection
$Type
and $Collection
For single-valued parameters the value of $Type
is the qualified name of the accepted type.
For collection-valued parameters the value of $Type
is the qualified name of the accepted item type, and the member $Collection
MUST be present with the literal value true
.
Absence of the $Type
member means the type is Edm.String
.
$Nullable
$Nullable
The value of $Nullable
is one of the Boolean literals true
or false
. Absence of the member means false
.
For single-valued parameters the value true
means that the parameter accepts a null
value.
For collection-valued parameters the parameter value will always be a collection that MAY be empty. In this case $Nullable
applies to items of the collection and specifies whether the collection MAY contain null
values.
An entity set can expose instances of the specified entity type as well as any entity type inherited from the specified entity type.
A singleton allows addressing a single entity directly from the entity container without having to know its key, and without requiring an entity set.
A function import or an action import is used to expose a function or action defined in an entity model as a top level resource.
-An entity container is represented as a member of the schema object whose name is the unqualified name of the entity container and whose value is an object.
The entity container object MUST contain the member $Kind
with a string value of EntityContainer
.
The entity container object MAY contain the member $Extends
, members representing entity sets, singletons, action imports, and function imports, as well as annotations.
If the "extending" entity container defines an entity set with the same name as defined in any of its "base" containers, then the entity set's type MUST specify an entity type derived from the entity type specified for the identically named entity set in the "base" container. The same holds for singletons. Action imports and function imports cannot be redefined, nor can the "extending" container define a child with the same name as a child of a different kind in a "base" container.
Note: services should not introduce cycles by extending entity containers. Clients should be prepared to process cycles introduced by extending entity containers.
-$Extends
$Extends
The value of $Extends
is the qualified name of the entity container to be extended.
Entity sets that cannot be queried without specifying additional query options SHOULD NOT be included in the service document.
An entity set is represented as a member of the entity container object whose name is the name of the entity set and whose value is an object.
The entity set object MUST contain the members $Collection
and $Type
.
It MAY contain the members $IncludeInServiceDocument
and $NavigationPropertyBinding
as well as annotations.
$Collection
$Collection
The value of $Collection
is the Booelan value true
.
$Type
$Type
The value of $Type
is the qualified name of an entity type.
$IncludeInServiceDocument
$IncludeInServiceDocument
The value of $IncludeInServiceDocument
is one of the Boolean literals true
or false
. Absence of the member means true
.
A singleton MUST specify a type that MUST be an entity type in scope.
A singleton MUST reference an instance its entity type.
A singleton is represented as a member of the entity container object whose name is the name of the singleton and whose value is an object.
The singleton object MUST contain the member $Type
and it MAY contain the member $Nullable
.
It MAY contain the member $NavigationPropertyBinding
as well as annotations.
$Type
$Type
The value of $Type
is the qualified name of an entity type.
$Nullable
$Nullable
The value of $Nullable
is one of the Boolean literals true
or false
. Absence of the member means false
.In OData 4.0 responses this member MUST NOT be specified.
A navigation property binding MUST specify a target via a simple identifier or target path. It specifies the entity set, singleton, or containment navigation property that contains the related entities.
If the target is a simple identifier, it MUST resolve to an entity set or singleton defined in the same entity container.
If the target is a target path, it MUST resolve to an entity set, singleton, or direct or indirect containment navigation property of a singleton in scope. The path can traverse single-valued containment navigation properties or single-valued complex properties before ending in a containment navigation property, and there MUST NOT be any non-containment navigation properties prior to the final segment.
-$NavigationPropertyBinding
$NavigationPropertyBinding
The value of $NavigationPropertyBinding
is an object. It consists of members whose name is the navigation property binding path and whose value is a string containing the navigation property binding target. If the target is in the same entity container, the target MUST NOT be prefixed with the qualified entity container name.
An action import MUST specify the name of an unbound action in scope.
If the imported action returns an entity or a collection of entities, a simple identifier or target path value MAY be specified to identify the entity set that contains the returned entities. If a simple identifier is specified, it MUST resolve to an entity set defined in the same entity container. If a target path is specified, it MUST resolve to an entity set in scope.
An action import is represented as a member of the entity container object whose name is the name of the action import and whose value is an object.
The action import object MUST contain the member $Action
.
It MAY contain the member $EntitySet
.
It MAY also contain annotations.
-$Action
$Action
The value of $Action
is a string containing the qualified name of an unbound action.
$EntitySet
$EntitySet
The value of $EntitySet
is a string containing either the unqualified name of an entity set in the same entity container or a path to an entity set in a different entity container.
If the imported function returns an entity or a collection of entities, a simple identifier or target path value MAY be specified to identify the entity set that contains the returned entities. If a simple identifier is specified, it MUST resolve to an entity set defined in the same entity container. If a target path is specified, it MUST resolve to an entity set in scope.
A function import for a parameterless function MAY indicate whether it is included in the service document. If not explicitly indicated, it is not included.
A function import is represented as a member of the entity container object whose name is the name of the function import and whose value is an object.
The function import object MUST contain the member $Function
.
It MAY contain the members $EntitySet
and $IncludeInServiceDocument
.
It MAY also contain annotations.
-$Function
$Function
The value of $Function
is a string containing the qualified name of an unbound function.
$EntitySet
$EntitySet
The value of $EntitySet
is a string containing either the unqualified name of an entity set in the same entity container or a path to an entity set in a different entity container.
$IncludeInServiceDocument
$IncludeInServiceDocument
The value of $IncludeInServiceDocument
is one of the Boolean literals true
or false
. Absence of the member means false
.
The term's name is a simple identifier that MUST be unique within its schema.
The term's type MUST be a type in scope, or a collection of a type in scope.
A term is represented as a member of the schema object whose name is the unqualified name of the term and whose value is an object.
The term object MUST contain the member $Kind
with a string value of Term
.
It MAY contain the members $Type
, $Collection
, $AppliesTo
, $Nullable
, $MaxLength
, $Precision
, $Scale
, $SRID
, and $DefaultValue
, as well as $Unicode
for 4.01 and greater payloads.
It MAY contain annotations.
-$Type
and $Collection
$Type
and $Collection
For single-valued terms the value of $Type
is the qualified name of the term's type.
For collection-valued terms the value of $Type
is the qualified name of the term's item type, and the member $Collection
MUST be present with the literal value true
.
Absence of the $Type
member means the type is Edm.String
.
$DefaultValue
$DefaultValue
The value of $DefaultValue
is the type-specific JSON representation of the default value of the term, see OData-JSON.
Note: the $DefaultValue
member is purely for documentation and isomorphy to OData-CSDLXML. Annotations in CSDL JSON documents MUST always specify an explicit value.
A term MAY specialize another term in scope by specifying it as its base term.
When applying a specialized term, the base term MUST also be applied with the same qualifier, and so on until a term without a base term is reached.
-$BaseTerm
$BaseTerm
The value of $BaseTerm
is the qualified name of the base term.
$AppliesTo
$AppliesTo
The value of $AppliesTo
is an array whose items are strings containing symbolic values from the table above that identify model elements the term is intended to be applied to.
$AppliesTo
An annotation applies a term to a model element and defines how to calculate a value for the term application. Both term and model element MUST be in scope. Section 14.1.2 specifies which model elements MAY be annotated with a term.
The value of an annotation is specified as an annotation expression, which is either a constant expression representing a constant value, or a dynamic expression. The most common construct for assigning an annotation value is a path expression that refers to a property of the same or a related structured type.
-An annotation is represented as a member whose name consists of an at (@
) character, followed by the qualified name of a term, optionally followed by a hash (#
) and a qualifier.
The value of the annotation MUST be a constant expression or dynamic expression.
The annotation can be a member of the object representing the model element it annotates, or a second-level member of the $Annotations
member of a schema object.
The value path expression allows assigning a value by traversing an object graph. It can be used in annotations that target entity containers, entity sets, entity types, complex types, navigation properties of structured types, and structural properties of structured types. Its argument is an instance path.
The value of the path expression is the instance or collection of instances identified by the path.
-$Path
$Path
Path expressions are represented as an object with a single member $Path
whose value is a string containing a path.
The other comparison operators require two operand expressions that evaluate to comparable values.
$And
and $Or
$And
and $Or
The And
and Or
logical expressions are represented as an object with a single member whose value is an array with two annotation expressions. The member name is one of $And
, or $Or
.
It MAY contain annotations.
-$Not
$Not
Negation expressions are represented as an object with a single member $Not
whose value is an annotation expression.
It MAY contain annotations.
-$Eq
, $Ne
, $Gt
, $Ge
, $Lt
, $Le
, $Has
, and $In
$Eq
, $Ne
, $Gt
, $Ge
, $Lt
, $Le
, $Has
, and $In
All comparison expressions are represented as an object with a single member whose value is an array with two annotation expressions. The member name is one of $Eq
, $Ne
, $Gt
, $Ge
, $Lt
, $Le
, $Has
, or $In
.
They MAY contain annotations.
$Neg
$Neg
Negation expressions are represented as an object with a single member $Neg
whose value is an annotation expression.
It MAY contain annotations.
-$Add
, $Sub
, $Mul
, $Div
, $DivBy
, and $Mod
$Add
, $Sub
, $Mul
, $Div
, $DivBy
, and $Mod
These arithmetic expressions are represented as an object with as single member whose value is an array with two annotation expressions. The member name is one of $Add
, $Sub
, $Neg
, $Mul
, $Div
, $DivBy
, or $Mod
.
They MAY contain annotations.
The apply expression enables a value to be obtained by applying a client-side function. The apply expression MAY have operand expressions. The operand expressions are used as parameters to the client-side function.
-$Apply
$Apply
Apply expressions are represented as an object with a member $Apply
whose value is an array of annotation expressions, and a member $Function
whose value is a string containing the qualified name of the client-side function to be applied.
It MAY contain annotations.
The cast expression casts the value obtained from its single child expression to the specified type. The cast expression follows the same rules as the cast
canonical function defined in OData-URL.
$Cast
$Cast
Cast expressions are represented as an object with a member $Cast
whose value is an annotation expression, a member $Type
whose value is a string containing the qualified type name, and optionally a member $Collection
with a value of true
.
It MAY contain annotations.
If the specified type is a primitive type or a collection of primitive types, the facet members $MaxLength
, $Unicode
, $Precision
, $Scale
, and $SRID
MAY be specified if applicable to the specified primitive type. If the facet members are not specified, their values are considered unspecified.
The first child expression is the condition and MUST evaluate to a Boolean result, e.g. the comparison and logical operators can be used.
The second and third child expressions are evaluated conditionally. The result MUST be type compatible with the type expected by the surrounding expression.
If the first expression evaluates to true
, the second expression MUST be evaluated and its value MUST be returned as the result of the if-then-else expression. If the first expression evaluates to false
and a third child element is present, it MUST be evaluated and its value MUST be returned as the result of the if-then-else expression. If no third expression is present, nothing is added to the surrounding collection.
$If
$If
Conditional expressions are represented as an object with a member $If
whose value is an array of two or three annotation expressions.
It MAY contain annotations.
$If
The is-of
expression checks whether the value obtained from its single child expression is compatible with the specified type. It returns true
if the child expression returns a type that is compatible with the specified type, and false
otherwise.
$IsOf
$IsOf
Is-of expressions are represented as an object with a member $IsOf
whose value is an annotation expression, a member $Type
whose value is a string containing an qualified type name, and optionally a member $Collection
with a value of true
.
It MAY contain annotations.
If the specified type is a primitive type or a collection of primitive types, the facet members $MaxLength
, $Unicode
, $Precision
, $Scale
, and $SRID
MAY be specified if applicable to the specified primitive type. If the facet members are not specified, their values are considered unspecified.
The labeled element expression assigns a name to its single child expression. The value of the child expression can then be reused elsewhere with a labeled element reference expression.
A labeled element expression MUST contain exactly one child expression. The value of the child expression is also the value of the labeled element expression.
A labeled element expression MUST provide a simple identifier value as its name that MUST be unique within the schema containing the expression.
-$LabeledElement
$LabeledElement
Labeled element expressions are represented as an object with a member $LabeledElement
whose value is an annotation expression, and a member $Name
whose value is a string containing the labeled element's name.
It MAY contain annotations.
$LabeledE
The labeled element reference expression MUST specify the qualified name of a labeled element expression in scope and returns the value of the identified labeled element expression as its value.
-$LabeledElementReference
$LabeledElementReference
Labeled element reference expressions are represented as an object with a member $LabeledElementReference
whose value is a string containing an qualified name.
$Null
$Null
Null expression containing annotations are represented as an object with a member $Null
whose value is the literal null
.
The URL reference expression enables a value to be obtained by sending a GET
request.
The URL reference expression MUST contain exactly one expression of type Edm.String
. Its value is treated as a URL that MAY be relative or absolute; relative URLs are relative to the URL of the document containing the URL reference expression, or relative to a base URL specified in a format-specific way.
The response body of the GET
request MUST be returned as the result of the URL reference expression. The result of the URL reference expression MUST be type compatible with the type expected by the surrounding expression.
$UrlRef
$UrlRef
URL reference expressions are represented as an object with a single member $UrlRef
whose value is an annotation expression.
It MAY contain annotations.
edmx:Edmx
edmx:Edmx
The edmx:Edmx
element is the root element of a CSDL XML document. It MUST contain the Version
attribute and it MUST contain exactly one edmx:DataServices
element.
It MAY contain edmx:Reference
elements to reference other CSDL documents.
Version
Version
The Version
attribute specifies the OData protocol version of the service. For OData 4.0 responses the value of this attribute MUST be 4.0.
For OData 4.01 responses the value of this attribute MUST be 4.01.
Services MUST return an OData 4.0 response if the request was made with an OData-MaxVersion
header with a value of 4.0
.
edmx:DataServices
edmx:DataServices
The edmx:DataServices
element MUST contain one or more edm:Schema
elements which define the schemas exposed by the OData service.
The Core.SchemaVersion
annotation, defined in OData-VocCore, MAY be used to indicate a particular version of the referenced document. If the Core.SchemaVersion
annotation is present, the $schemaversion
system query option, defined OData-Protocol, SHOULD be used when retrieving the referenced schema document.
edmx:Reference
edmx:Reference
The edmx:Reference
element specifies external CSDL documents referenced by the referencing document. The child elements edmx:Include
and edmx:IncludeAnnotations
specify which parts of the referenced document are available for use in the referencing document.
The edmx:Reference
element MUST contain the Uri
attribute, and it MUST contain at least one edmx:Include
or edmx:IncludeAnnotations
child element.
It MAY contain edm:Annotation
elements.
Uri
Uri
The value of Uri
is an absolute or relative URI; relative URIs are relative to the xml:base
attribute, see XML-Base.
The alias MUST NOT be one of the reserved values Edm
, odata
, System
, or Transient
.
An alias is only valid within the document in which it is declared; a referencing document may define its own aliases for included schemas.
edmx:Include
edmx:Include
The edmx:Include
element specifies a schema to include from the referenced CSDL document. It MUST provide the Namespace
attribute and it MAY provide the Alias
attribute.
It MAY contain edm:Annotation
elements.
Namespace
Namespace
The value of Namespace
is the namespace of a schema defined in the referenced CSDL document.
Alias
Alias
The value of Alias
is a simple identifier that can be used in qualified names instead of the namespace.
The target namespace also provides consumers insight about what namespaces are present in the referenced document. If the consumer is not interested in that particular target namespace, the consumer can opt not to inspect the referenced document.
edmx:IncludeAnnotations
edmx:IncludeAnnotations
The edmx:IncludeAnnotations
element specifies the annotations to include from the referenced CSDL document. If no edmx:IncludeAnnotations
element is specified, a client MAY ignore all annotations in the referenced document that are not explicitly used in an edm:Path
expression of the referencing document.
The edmx:IncludeAnnotations
element MUST provide the TermNamespace
attribute, and it MAY provide the Qualifier
and TargetNamespace
attribute.
TermNamespace
TermNamespace
The value of TermNamespace
is a namespace.
Qualifier
Qualifier
The value of Qualifier
is a simple identifier.
TargetNamespace
TargetNamespace
The value of TargetNamespace
is a namespace.
Names are case-sensitive, but service authors SHOULD NOT choose names that differ only in case.
The namespace MUST NOT be one of the reserved values Edm
, odata
, System
, or Transient
.
edm:Schema
edm:Schema
The edm:Schema
element defines a schema. It MUST contain the Namespace
attribute and it MAY contain the Alias
attribute.
It MAY contain elements edm:Action
, edm:Annotations
, edm:Annotation
, edm:ComplexType
, edm:EntityContainer
, edm:EntityType
, edm:EnumType
, edm:Function
, edm:Term
, or edm:TypeDefinition
.
Namespace
Namespace
The value of Namespace
is the namespace of the schema
If a schema specifies an alias, the alias MAY be used instead of the namespace within qualified names to identify model elements of that schema. An alias only provides a more convenient notation, allowing a short string to be substituted for a long namespace. Every model element that can be identified via an alias-qualified name can alternatively be identified via its full namespace-qualified name.
Aliases are document-global, so all schemas defined within or included into a document MUST have different aliases, and aliases MUST differ from the namespaces of all schemas defined within or included into a document. Aliases defined by a schema can be used throughout the containing document and are not restricted to the schema that defines them.
The alias MUST NOT be one of the reserved values Edm
, odata
, System
, or Transient
.
Alias
Alias
The value of Alias
is a simple identifier.
Ali
edm:Annotations
edm:Annotations
The edm:Annotations
element is used to apply a group of annotations to a single model element. It MUST contain the Target
attribute and it MAY contain the Qualifier
attribute.
It MUST contain at least one edm:Annotation
element.
Target
Target
The value of Target
is a path expression identifying the annotation target. It MUST resolve to a model element in scope.
Qualifier
Qualifier
The value of Qualifier
is a simple identifier.
An entity type can define two types of properties. A structural property is a named reference to a primitive, complex, or enumeration type, or a collection of primitive, complex, or enumeration types. A navigation property is a named reference to another entity type or collection of entity types.
All properties MUST have a unique name within an entity type. Properties MUST NOT have the same name as the declaring entity type. They MAY have the same name as one of the direct or indirect base types or derived types.
edm:EntityType
edm:EntityType
The edm:EntityType
element MUST contain the Name
attribute, and it MAY contain the BaseType
, Abstract
, OpenType
, and HasStream
attributes.
It MAY contain edm:Property
and edm:NavigationProperty
elements describing the properties of the entity type.
It MAY contain one edm:Key
element.
It MAY contain edm:Annotation
elements.
Name
Name
The value of Name
is the entity type's name.
An entity type MUST NOT introduce an inheritance cycle by specifying a base type.
-BaseType
BaseType
The value of BaseType
is the qualified name of the base type.
An abstract entity type MUST NOT inherit from a non-abstract entity type.
-Abstract
Abstract
The value of Abstract
is one of the Boolean literals true
or false
. Absence of the attribute means false
.
An entity type MAY indicate that it is open and allows clients to add properties dynamically to instances of the type by specifying uniquely named property values in the payload used to insert or update an instance of the type.
An entity type derived from an open entity type MUST indicate that it is also open.
Note: structural and navigation properties MAY be returned by the service on instances of any structured type, whether or not the type is marked as open. Clients MUST always be prepared to deal with additional properties on instances of any structured type, see OData-Protocol.
-OpenType
OpenType
The value of OpenType
is one of the Boolean literals true
or false
. Absence of the attribute means false
.
An entity type that does not specify a base type MAY indicate that it is a media entity type. Media entities are entities that represent a media stream, such as a photo. Use a media entity if the out-of-band stream is the main topic of interest and the media entity is just additional structured information attached to the stream. Use a normal entity with one or more properties of type Edm.Stream
if the structured data of the entity is the main topic of interest and the stream data is just additional information attached to the structured data. For more information on media entities see OData-Protocol.
An entity type derived from a media entity type MUST indicate that it is also a media entity type.
Media entity types MAY specify a list of acceptable media types using an annotation with term Core.AcceptableMediaTypes
, see OData-VocCore.
HasStream
HasStream
The value of HasStream
is one of the Boolean literals true
or false
. Absence of the attribute means false
.
An alias MUST NOT be defined if the key property is a primitive property of the entity type itself.
For key properties that are a property of a complex or navigation property, the alias MUST be used in the key predicate of URLs instead of the path to the property because the required percent-encoding of the forward slash separating segments of the path to the property would make URL construction and parsing rather complicated. The alias MUST NOT be used in the query part of URLs, where paths to properties don't require special encoding and are a standard constituent of expressions anyway.
edm:Key
edm:Key
The edm:Key
element MUST contain at least one edm:PropertyRef
element.
edm:PropertyRef
edm:PropertyRef
The edm:PropertyRef
element MUST contain the Name
attribute and MAY contain the Alias
attribute.
Name
Name
The value of Name
is a path expression leading to a primitive property. The names of the properties in the path are joined together by forward slashes.
Alias
Alias
The value of Alias
is a simple identifier.
Names are case-sensitive, but service authors SHOULD NOT choose names that differ only in case.
edm:Property
edm:Property
The edm:Property
element MUST contain the Name
and the Type
attribute, and it MAY contain the facet attributes Nullable
, MaxLength
, Unicode
, Precision
, Scale
, SRID
, and DefaultValue
.
It MAY contain edm:Annotation
elements.
Name
Name
The value of Name
is the property's name.
The property's type MUST be a primitive type, complex type, or enumeration type in scope, or a collection of one of these types.
A collection-valued property MAY be annotated with the Core.Ordered
term, defined in OData-VocCore, to specify that it supports a stable ordering.
A collection-valued property MAY be annotated with the Core.PositionalInsert
term, defined in OData-VocCore, to specify that it supports inserting items into a specific ordinal position.
Type
Type
For single-valued properties the value of Type
is the qualified name of the property's type.
For collection-valued properties the value of Type
is the character sequence Collection(
followed by the qualified name of the property's item type, followed by a closing parenthesis )
.
For single-valued properties the facets apply to the value of the property. For collection-valued properties the facets apply to the items in the collection.
A Boolean value specifying whether the property can have the value null
.
Nullable
Nullable
The value of Nullable
is one of the Boolean literals true
or false
.
For single-valued properties the value true
means that the property allows the null
value.
For collection-valued properties the property value will always be a collection that MAY be empty. In this case the Nullable
attribute applies to items of the collection and specifies whether the collection MAY contain null
values.
A positive integer value specifying the maximum length of a binary, stream or string value. For binary or stream values this is the octet length of the binary data, for string values it is the character length (number of code points for Unicode).
If no maximum length is specified, clients SHOULD expect arbitrary length.
-MaxLength
MaxLength
The value of MaxLength
is a positive integer or the symbolic value max
as a shorthand for the maximum length supported for the type by the service.
Note: the symbolic value max
is only allowed in OData 4.0 responses; it is deprecated in OData 4.01. While clients MUST be prepared for this symbolic value, OData 4.01 and greater services MUST NOT return the symbolic value max
and MAY instead specify the concrete maximum length supported for the type by the service or omit the attribute entirely.
For a temporal value (datetime-with-timezone-offset, duration, or time-of-day): the number of decimal places allowed in the seconds portion of the value; it MUST be a non-negative integer between zero and twelve.
Note: service authors SHOULD be aware that some clients are unable to support a precision greater than 28 for decimal properties and 7 for temporal properties. Client developers MUST be aware of the potential for data loss when round-tripping values of greater precision. Updating via PATCH
and exclusively specifying modified properties will reduce the risk for unintended data loss.
Note: duration properties supporting a granularity less than seconds (e.g. minutes, hours, days) can be annotated with term Measures.DurationGranularity
, see OData-VocMeasures.
Precision
Precision
The value of Precision
is a number.
If not specified for a decimal property, the decimal property has arbitrary precision.
If not specified for a temporal property, the temporal property has a precision of zero.
@@ -1107,8 +1107,8 @@An integer value means that the number of digits to the right of the decimal point may vary from zero to the value of the Scale
facet, and the number of digits to the left of the decimal point may vary from one to the value of the Precision
facet minus the value of the Scale
facet. If Precision
is equal to Scale
, a single zero MUST precede the decimal point.
The value of Scale
MUST be less than or equal to the value of Precision
.
Note: if the underlying data store allows negative scale, services may use a Precision
with the absolute value of the negative scale added to the actual number of significant decimal digits, and client-provided values may have to be rounded before being stored.
Scale
Scale
The value of Scale
is a number or one of the symbolic values floating
or variable
.
Services SHOULD use lower-case values; clients SHOULD accept values in a case-insensitive manner.
If not specified, the Scale
facet defaults to zero.
S
7.2.5 Unicode
For a string property the Unicode
facet indicates whether the property might contain and accept string values with Unicode characters (code points) beyond the ASCII character set. The value false
indicates that the property will only contain and accept string values with characters limited to the ASCII character set.
If no value is specified, the Unicode
facet defaults to true
.
-
- Attribute Unicode
+
+Attribute Unicode
The value of Unicode
is one of the Boolean literals true
or false
. Absence of the attribute means true
.
7.2.6 SRID
For a geometry or geography property the SRID
facet identifies which spatial reference system is applied to values of the property on type instances.
The value of the SRID
facet MUST be a non-negative integer or the special value variable
. If no value is specified, the facet defaults to 0
for Geometry
types or 4326
for Geography
types.
The valid values of the SRID
facet and their meanings are as defined by the European Petroleum Survey Group EPSG.
-
- Attribute SRID
+
+Attribute SRID
The value of SRID
is a number or the symbolic value variable
.
7.2.7 Default Value
A primitive or enumeration property MAY define a default value that is used if the property is not explicitly represented in an annotation or the body of a request or response.
If no value is specified, the client SHOULD NOT assume a default value.
-
- Attribute DefaultValue
+
+Attribute DefaultValue
Default values of type Edm.String
MUST be represented according to the XML escaping rules for character data in attribute values. Values of other primitive types MUST be represented according to the appropriate alternative in the primitiveValue
rule defined in OData-ABNF, i.e. Edm.Binary
as binaryValue
, Edm.Boolean
as booleanValue
etc.
@@ -1157,11 +1157,11 @@ simple identifier. It is used when referencing, serializing or deserializing the navigation property. It MUST be unique within the set of structural and navigation properties of the declaring structured type, and MUST NOT match the name of any structural property in any of its base types. If a navigation property with the same name is defined in any of this type's base types, then the navigation property's type MUST be a type derived from the type specified for the navigation property of the base type, and constrains this navigation property to be of the specified subtype for instances of this structured type. The name MUST NOT match the name of any structural or navigation property of any of this type's base types for OData 4.0 responses.
Names are case-sensitive, but service authors SHOULD NOT choose names that differ only in case.
- Element edm:NavigationProperty
+Element edm:NavigationProperty
The edm:NavigationProperty
element MUST contain the Name
and Type
attributes, and it MAY contain the attributes Nullable
, Partner
, and ContainsTarget
.
It MAY contain child elements edm:ReferentialConstraint
and at most one child element edm:OnDelete
.
It MAY contain edm:Annotation
elements.
- Attribute Name
+Attribute Name
The value of Name
is the navigation property's name.
@@ -1186,16 +1186,16 @@ key defined.
A collection-valued navigation property MAY be annotated with the Core.Ordered
term, defined in OData-VocCore, to specify that it supports a stable ordering.
A collection-valued navigation property MAY be annotated with the Core.PositionalInsert
term, defined in OData-VocCore, to specify that it supports inserting items into a specific ordinal position.
-
- Attribute Type
+
+Attribute Type
For single-valued navigation properties the value of Type
is the qualified name of the navigation property's type.
For collection-valued navigation properties the value of Type
is the character sequence Collection(
followed by the qualified name of the navigation property's item type, followed by a closing parenthesis )
.
8.2 Nullable Navigation Property
A Boolean value specifying whether the declaring type MAY have no related entity. If false, instances of the declaring structured type MUST always have a related entity.
Nullable MUST NOT be specified for a collection-valued navigation property, a collection is allowed to have zero items.
-
- Attribute Nullable
+
+Attribute Nullable
The value of Nullable
is one of the Boolean literals true
or false
. Absence of the attribute means true
.
8.3 Partner Navigation Property
@@ -1204,8 +1204,8 @@ If the partner navigation property is single-valued, it MUST lead back to the source entity from all related entities. If the partner navigation property is collection-valued, the source entity MUST be part of that collection.
If no partner navigation property is specified, no assumptions can be made as to whether one of the navigation properties on the target type will lead back to the source entity.
If a partner navigation property is specified, this partner navigation property MUST either specify the current navigation property as its partner to define a bi-directional relationship or it MUST NOT specify a partner navigation property. The latter can occur if the partner navigation property is defined on a complex type, or if the current navigation property is defined on a type derived from the type of the partner navigation property.
-
- Attribute Partner
+
+Attribute Partner
The value of Partner
is the path to the of the partner navigation property.
8.4 Containment Navigation Property
@@ -1221,8 +1221,8 @@ nullable (for the root of the tree) and single-valued (for the parent of a non-root entity). If the containment is not recursive, the partner navigation property MUST NOT be nullable.
An entity type inheritance chain MUST NOT contain more than one navigation property with a partner navigation property that is a containment navigation property.
Note: without a partner navigation property, there is no reliable way for a client to determine which entity contains a given contained entity. This may lead to problems for clients if the contained entity can also be reached via a non-containment navigation path.
-
- Attribute ContainsTarget
+
+Attribute ContainsTarget
The value of ContainsTarget
is one of the Boolean literals true
or false
. Absence of the attribute means false
.
8.5 Referential Constraint
@@ -1232,12 +1232,12 @@
- Element edm:ReferentialConstraint
+Element edm:ReferentialConstraint
The edm:ReferentialConstraint
element MUST contain the attributes Property
and ReferencedProperty
.
It MAY contain edm:Annotation
elements.
- Attribute Property
+Attribute Property
The Property
attribute specifies the property that takes part in the referential constraint on the dependent structured type. Its value MUST be a path expression resolving to a property of the dependent structured type itself or to a property of a complex property (recursively) of the dependent structured type. The names of the properties in the path are joined together by forward slashes. The path is relative to the dependent structured type declaring the navigation property.
- Attribute ReferencedProperty
+Attribute ReferencedProperty
The ReferencedProperty
attribute specifies the corresponding property of the principal entity type. Its value MUST be a path expression resolving to a property of the principal entity type itself or to a property of a complex property (recursively) of the principal entity type that MUST have the same type as the property of the dependent entity type. The path is relative to the entity type that is the target of the navigation property.
@@ -1275,10 +1275,10 @@ 8.6
If no on-delete action is specified, the action taken by the service is not predictable by the client and could vary per entity.
- Element edm:OnDelete
+Element edm:OnDelete
The edm:OnDelete
element MUST contain the Action
attribute.
It MAY contain edm:Annotation
elements.
- Attribute Action
+Attribute Action
The value of Action
is one of the values Cascade
, None
, SetNull
, or SetDefault
.
@@ -1300,11 +1300,11 @@ 9 Complex Type
A complex type can define two types of properties. A structural property is a named reference to a primitive, complex, or enumeration type, or a collection of primitive, complex, or enumeration types. A navigation property is a named reference to an entity type or a collection of entity types.
All properties MUST have a unique name within a complex type. Properties MUST NOT have the same name as the declaring complex type. They MAY have the same name as one of the direct or indirect base types or derived types.
- Element edm:ComplexType
+Element edm:ComplexType
The edm:ComplexType
element MUST contain the Name
attribute, and it MAY contain the BaseType
, Abstract
, and OpenType
attributes.
It MAY contain edm:Property
and edm:NavigationProperty
elements describing the properties of the complex type.
It MAY contain edm:Annotation
elements.
- Attribute Name
+Attribute Name
The value of Name
is the complex type's name.
@@ -1331,22 +1331,22 @@ section 14.2.
-
- Attribute BaseType
+
+Attribute BaseType
The value of BaseType
is the qualified name of the base type.
9.2 Abstract Complex Type
A complex type MAY indicate that it is abstract and cannot have instances.
-
- Attribute Abstract
+
+Attribute Abstract
The value of Abstract
is one of the Boolean literals true
or false
. Absence of the attribute means false
.
9.3 Open Complex Type
A complex type MAY indicate that it is open and allows clients to add properties dynamically to instances of the type by specifying uniquely named property values in the payload used to insert or update an instance of the type.
A complex type derived from an open complex type MUST indicate that it is also open.
Note: structural and navigation properties MAY be returned by the service on instances of any structured type, whether or not the type is marked as open. Clients MUST always be prepared to deal with additional properties on instances of any structured type, see OData‑Protocol.
-
- Attribute OpenType
+
+Attribute OpenType
The value of OpenType
is one of the Boolean literals true
or false
. Absence of the attribute means false
.
@@ -1356,11 +1356,11 @@ 1
Although enumeration types have an underlying numeric value, the preferred representation for an enumeration value is the member name. Discrete sets of numeric values should be represented as numeric values annotated with the AllowedValues
annotation defined in OData-VocCore.
Enumeration types marked as flags allow values that consist of more than one enumeration member at a time.
- Element edm:EnumType
+Element edm:EnumType
The edm:EnumType
element MUST contain the Name attribute, and it MAY contain the UnderlyingType
and IsFlags
attributes.
It MUST contain one or more edm:Member
elements defining the members of the enumeration type.
It MAY contain edm:Annotation
elements.
- Attribute Name
+Attribute Name
The value of Name
is the enumeration type's name.
@@ -1375,15 +1375,15 @@ 10.1 Underlying Integer Type
An enumeration type MAY specify one of Edm.Byte
, Edm.SByte
, Edm.Int16
, Edm.Int32
, or Edm.Int64
as its underlying type.
If not explicitly specified, Edm.Int32
is used as the underlying type.
-
- Attribute UnderlyingType
+
+Attribute UnderlyingType
The value of UnderlyingType
is the qualified name of the underlying type.
10.2 Flags Enumeration Type
An enumeration type MAY indicate that the enumeration type allows multiple members to be selected simultaneously.
If not explicitly specified, only one enumeration type member MAY be selected simultaneously.
-
- Attribute IsFlags
+
+Attribute IsFlags
The value of IsFlags
is one of the Boolean literals true
or false
. Absence of the attribute means false
.
@@ -1411,12 +1411,12 @@
- Element edm:Member
+Element edm:Member
The edm:Member
element MUST contain the Name
attribute and it MAY contain the Value
attribute.
It MAY contain edm:Annotation
elements.
- Attribute Name
+Attribute Name
The value of Name
is the enumeration member's name.
- Attribute Value
+Attribute Value
If the IsFlags
attribute has a value of false
, either all members MUST specify an integer value for the Value
attribute, or all members MUST NOT specify a value for the Value
attribute. If no values are specified, the members are assigned consecutive integer values in the order of their appearance, starting with zero for the first member. Client libraries MUST preserve elements in document order.
If the IsFlags
attribute has a value of true
, a non-negative integer value MUST be specified for the Value
attribute. A combined value is equivalent to the bitwise OR of the discrete values.
@@ -1444,10 +1444,10 @@ 11 T
Type definitions can be used wherever a primitive type is used (other than as the underlying type in a new type definition) and are type-comparable with their underlying types and any type definitions defined using the same underlying type.
It is up to the definition of a term to specify whether and how annotations with this term propagate to places where the annotated type definition is used, and whether they can be overridden.
- Element edm:TypeDefinition
+Element edm:TypeDefinition
The edm:TypeDefinition
element MUST contain the Name
and UnderlyingType
attributes.
It MAY contain edm:Annotation
elements.
- Attribute Name
+Attribute Name
The value of Name
is the type definition's name.
@@ -1469,8 +1469,8 @@ 11.1 Underlying Primitive Type
The underlying type of a type definition MUST be a primitive type that MUST NOT be another type definition.
-
- Attribute UnderlyingType
+
+Attribute UnderlyingType
The value of UnderlyingType
is the qualified name of the underlying type.
The type definition MAY specify facets applicable to the underlying type. Possible facets are: MaxLength
, Unicode
, Precision
, Scale
, or SRID
.
@@ -1490,11 +1490,11 @@
Unbound actions do not support overloads. The names of all unbound actions MUST be unique within a schema.
An unbound action MAY have the same name as a bound action.
- Element edm:Action
+Element edm:Action
The edm:Action
element MUST contain the Name
attribute and it MAY contain the IsBound
and EntitySetPath
attributes.
It MAY contain at most one edm:ReturnType
element and MAY contain edm:Parameter
elements.
It MAY contain edm:Annotation
elements.
- Attribute Name
+Attribute Name
The value of Name
is the action's name.
12.3 Function
@@ -1519,11 +1519,11 @@ type definitions can be used to disambiguate overloads for both bound and unbound functions, even if they specify the same underlying type.
- Element edm:Function
+Element edm:Function
The edm:Function
element MUST contain the Name
attribute and it MAY contain the IsBound
and EntitySetPath
attributes.
It MUST contain one edm:ReturnType
element, and it MAY contain edm:Parameter
elements.
It MAY contain edm:Annotation
elements.
- Attribute Name
+Attribute Name
The value of Name
is the action's name.
12.5 Bound or Unbound Action or Function Overloads
@@ -1531,8 +1531,8 @@ nullable.
Unbound actions are invoked from the entity container through an action import.
Unbound functions are invoked as static functions within a common expression (see OData-URL, section 5.1.1), or from the entity container through a function import.
-
- Attribute IsBound
+
+Attribute IsBound
The value of IsBound
is one of the Boolean literals true
or false
. Absence of the attribute means false
.
12.6 Entity Set Path
@@ -1540,15 +1540,15 @@ 12.6
The entity set path consists of a series of segments joined together with forward slashes.
The first segment of the entity set path MUST be the name of the binding parameter. The remaining segments of the entity set path MUST represent navigation segments or type casts.
A navigation segment names the simple identifier of the navigation property to be traversed. A type-cast segment names the qualified name of the entity type that should be returned from the type cast.
-
- Attribute EntitySetPath
+
+Attribute EntitySetPath
The value of EntitySetPath
is the entity set path.
12.7 Composable Function
A function MAY indicate that it is composable. If not explicitly indicated, it is not composable.
A composable function can be invoked with additional path segments or key predicates appended to the resource path that identifies the composable function, and with system query options as appropriate for the type returned by the composable function.
-
- Attribute IsComposable
+
+Attribute IsComposable
The value of IsComposable
is one of the Boolean literals true
or false
. Absence of the attribute means false
.
12.8 Return Type
@@ -1556,13 +1556,13 @@ 12.8 Return Typ
The facets Nullable
, MaxLength
, Precision
, Scale
, and SRID
can be used as appropriate to specify value restrictions of the return type, as well as the Unicode
facet for 4.01 and greater payloads.
For a single-valued return type the facets apply to the returned value. For a collection-valued return type the facets apply to the items in the returned collection.
- Element edm:ReturnType
+Element edm:ReturnType
The edm:ReturnType
element MUST contain the Type
attribute, and it MAY contain the attributes Nullable
, MaxLength
, Unicode
, Precision
, Scale
, and SRID
.
It MAY contain edm:Annotation
elements.
- Attribute Type
+Attribute Type
For single-valued return types the value of Type
is the qualified name of the return type.
For collection-valued return types the value of Type
is the character sequence Collection(
followed by the qualified name of the return item type, followed by a closing parenthesis )
.
- Attribute Nullable
+Attribute Nullable
The value of Nullable
is one of the Boolean literals true
or false
. Absence of the attribute means true
.
If the return type is a collection of entity types, the Nullable
attribute has no meaning and MUST NOT be specified.
For other collection-valued return types the result will always be a collection that MAY be empty. In this case the Nullable
attribute applies to items of the collection and specifies whether the collection MAY contain null
values.
@@ -1576,15 +1576,15 @@ 12.9 Parameter<
The facets MaxLength
, Precision
, Scale
, or SRID
can be used as appropriate to specify value restrictions of the parameter, as well as the Unicode
facet for 4.01 and greater payloads.
For single-valued parameters the facets apply to the parameter value. If the parameter value is a collection, the facets apply to the items in the collection.
- Element edm:Parameter
+Element edm:Parameter
The edm:Parameter
element MUST contain the Name
and the Type
attribute, and it MAY contain the attributes Nullable
, MaxLength
, Unicode
, Precision
, Scale
, and SRID
.
It MAY contain edm:Annotation
elements.
- Attribute Name
+Attribute Name
The value of Name
is the parameter's name.
- Attribute Type
+Attribute Type
For single-valued parameters the value of Type
is the qualified name of the parameter.
For collection-valued parameters the value of Type
is the character sequence Collection(
followed by the qualified name of the parameter's type, followed by a closing parenthesis )
.
- Attribute Nullable
+Attribute Nullable
The value of Nullable
is one of the Boolean literals true
or false
. Absence of the attribute means true
.
The value true
means that the parameter accepts a null
value.
@@ -1623,10 +1623,10 @@ 1
A singleton allows addressing a single entity directly from the entity container without having to know its key, and without requiring an entity set.
A function import or an action import is used to expose a function or action defined in an entity model as a top level resource.
- Element edm:EntityContainer
+Element edm:EntityContainer
The edm:EntityContainer
MUST contain one or more edm:EntitySet
, edm:Singleton
, edm:ActionImport
, or edm:FunctionImport
elements.
It MAY contain edm:Annotation
elements.
- Attribute Name
+Attribute Name
The value of Name
is the entity container's name.
@@ -1652,8 +1652,8 @@ An entity container MAY specify that it extends another entity container in scope. All children of the "base" entity container are added to the "extending" entity container.
If the "extending" entity container defines an entity set with the same name as defined in any of its "base" containers, then the entity set's type MUST specify an entity type derived from the entity type specified for the identically named entity set in the "base" container. The same holds for singletons. Action imports and function imports cannot be redefined, nor can the "extending" container define a child with the same name as a child of a different kind in a "base" container.
Note: services should not introduce cycles by extending entity containers. Clients should be prepared to process cycles introduced by extending entity containers.
-
- Attribute Extends
+
+Attribute Extends
The value of Extends
is the qualified name of the entity container to be extended.
@@ -1670,15 +1670,15 @@ 13.2 Entity SetAn entity set MAY indicate whether it is included in the service document. If not explicitly indicated, it is included.
Entity sets that cannot be queried without specifying additional query options SHOULD NOT be included in the service document.
- Element edm:EntitySet
+Element edm:EntitySet
The edm:EntitySet
element MUST contain the attributes Name
and EntityType
, and it MAY contain the IncludeInServiceDocument
attribute.
It MAY contain edm:NavigationPropertyBinding
elements.
It MAY contain edm:Annotation
elements.
- Attribute Name
+Attribute Name
The value of Name
is the entity set's name.
- Attribute EntityType
+Attribute EntityType
The value of EntityType
is the qualified name of an entity type in scope.
- Attribute IncludeInServiceDocument
+Attribute IncludeInServiceDocument
The value of IncludeInServiceDocument
is one of the Boolean literals true
or false
. Absence of the attribute means true
.
13.3 Singleton
@@ -1687,15 +1687,15 @@ 13.3 Singleton<
A singleton MUST specify a type that MUST be an entity type in scope.
A singleton MUST reference an instance its entity type.
- Element edm:Singleton
+Element edm:Singleton
The edm:Singleton
element MUST include the attributes Name
and Type
, and it MAY contain the Nullable
attribute.
It MAY contain edm:NavigationPropertyBinding
elements.
It MAY contain edm:Annotation
elements.
- Attribute Name
+Attribute Name
The value of Name
is the singleton's name.
- Attribute Type
+Attribute Type
The value of Type
is whose value is the qualified name of an entity type in scope.
- Attribute Nullable
+Attribute Nullable
The value of Nullable
is one of the Boolean literals true
or false
.
If no value is specified, the Nullable
attribute defaults to false
.
In OData 4.0 responses this attribute MUST NOT be specified.
@@ -1716,11 +1716,11 @@ 13.4.
If the target is a simple identifier, it MUST resolve to an entity set or singleton defined in the same entity container.
If the target is a target path, it MUST resolve to an entity set, singleton, or direct or indirect containment navigation property of a singleton in scope. The path can traverse single-valued containment navigation properties or single-valued complex properties before ending in a containment navigation property, and there MUST NOT be any non-containment navigation properties prior to the final segment.
- Element edm:NavigationPropertyBinding
+Element edm:NavigationPropertyBinding
The edm:NavigationPropertyBinding
element MUST contain the attributes Path
and Target
.
- Attribute Path
+Attribute Path
The value of Path
is a path expression.
- Attribute Target
+Attribute Target
The value of Target
is a target path.
@@ -1750,14 +1750,14 @@ 13.5 Acti
An action import MUST specify the name of an unbound action in scope.
If the imported action returns an entity or a collection of entities, a simple identifier or target path value MAY be specified to identify the entity set that contains the returned entities. If a simple identifier is specified, it MUST resolve to an entity set defined in the same entity container. If a target path is specified, it MUST resolve to an entity set in scope.
- Element edm:ActionImport
+Element edm:ActionImport
The edm:ActionImport
element MUST contain the attributes Name
and Action
, and it MAY contain the EntitySet
attribute.
It MAY contain edm:Annotation
elements.
- Attribute Name
+Attribute Name
The value of Name
is the action import's name.
- Attribute Action
+Attribute Action
The value of Action
is the qualified name of an unbound action.
- Attribute EntitySet
+Attribute EntitySet
The value of EntitySet
is either the unqualified name of an entity set in the same entity container or a path to an entity set in a different entity container.
13.6 Function Import
@@ -1767,15 +1767,15 @@ 13.
If the imported function returns an entity or a collection of entities, a simple identifier or target path value MAY be specified to identify the entity set that contains the returned entities. If a simple identifier is specified, it MUST resolve to an entity set defined in the same entity container. If a target path is specified, it MUST resolve to an entity set in scope.
A function import for a parameterless function MAY indicate whether it is included in the service document. If not explicitly indicated, it is not included.
- Element edm:FunctionImport
+Element edm:FunctionImport
The edm:FunctionImport
element MUST contain the attributes Name
and Function
, and it MAY contain the attributes EntitySet
and IncludeInServiceDocument
.
- Attribute Name
+Attribute Name
The value of Name
is the function import's name.
- Attribute Function
+Attribute Function
The value of Function
is the qualified name of an unbound function.
- Attribute EntitySet
+Attribute EntitySet
The value of EntitySet
is either the unqualified name of an entity set in the same entity container or a path to an entity set in a different entity container.
- Attribute IncludeInServiceDocument
+Attribute IncludeInServiceDocument
The value of IncludeInServiceDocument
is one of the Boolean literals true
or false
. Absence of the attribute means false
.
@@ -1821,17 +1821,17 @@ 14.1 Term
The term's name is a simple identifier that MUST be unique within its schema.
The term's type MUST be a type in scope, or a collection of a type in scope.
- Element edm:Term
+Element edm:Term
The edm:Term
element MUST contain the attributes Name
and Type
. It MAY contain the attributes BaseTerm
and AppliesTo
.
It MAY specify values for the Nullable
, [ ]{.apple-converted-space}MaxLength
, Precision
, Scale
, or SRID
facet attributes, as well as the Unicode
facet attribute for 4.01 and greater payloads. These facets and their implications are described in section 7.2.
A edm:Term
element whose Type
attribute specifies a primitive or enumeration type MAY define a value for the DefaultValue
attribute.
It MAY contain edm:Annotation
elements.
- Attribute Name
+Attribute Name
The value of Name
is the term's name.
- Attribute Type
+Attribute Type
For single-valued properties the value of Type
is the qualified name of the property's type.
For collection-valued properties the value of Type
is the character sequence Collection(
followed by the qualified name of the property's item type, followed by a closing parenthesis )
.
- Attribute DefaultValue
+Attribute DefaultValue
The value of this attribute determines the value of the term when applied in an edm:Annotation
without providing an expression.
Default values of type Edm.String
MUST be represented according to the XML escaping rules for character data in attribute values. Values of other primitive types MUST be represented according to the appropriate alternative in the primitiveValue
rule defined in OData-ABNF, i.e. Edm.Binary
as binaryValue
, Edm.Boolean
as booleanValue
etc.
If no value is specified, the DefaultValue
attribute defaults to null
.
@@ -1839,8 +1839,8 @@ 14.1.1 Specialized Term
A term MAY specialize another term in scope by specifying it as its base term.
When applying a specialized term, the base term MUST also be applied with the same qualifier, and so on until a term without a base term is reached.
-
- Attribute BaseTerm
+
+Attribute BaseTerm
The value of BaseTerm
is the qualified name of the base term.
14.1.2 Applicability
@@ -1987,8 +1987,8 @@ 14.1.2
-
- Attribute AppliesTo
+
+Attribute AppliesTo
The value of AppliesTo
is a whitespace-separated list of symbolic values from the table above that identify model elements the term is intended to be applied to.
@@ -2007,13 +2007,13 @@ 14.2 Annotation<
An annotation applies a term to a model element and defines how to calculate a value for the term application. Both term and model element MUST be in scope. Section 14.1.2 specifies which model elements MAY be annotated with a term.
The value of an annotation is specified as an annotation expression, which is either a constant expression representing a constant value, or a dynamic expression. The most common construct for assigning an annotation value is a path expression that refers to a property of the same or a related structured type.
- Element edm:Annotation
+Element edm:Annotation
The edm:Annotation
element MUST contain the attribute Term
, and it MAY contain the attribute Qualifier
.
The value of the annotation MAY be a constant expression or dynamic expression.
If no expression is specified for a term with a primitive type, the annotation evaluates to the default value of the term definition. If no expression is specified for a term with a complex type, the annotation evaluates to a complex instance with default values for its properties. If no expression is specified for a collection-valued term, the annotation evaluates to an empty collection.
An edm:Annotation
element can be used as a child of the model element it annotates, or as the child of an edm:Annotations
element that targets the model element to be annotated.
An edm:Annotation
element MAY contain edm:Annotation
elements that annotate the annotation.
- Attribute Term
+Attribute Term
The value of Term
is the qualified name of a term in scope.
@@ -2035,8 +2035,8 @@ 14.2.1 Qualifier
A term can be applied multiple times to the same model element by providing a qualifier to distinguish the annotations. The qualifier is a simple identifier.
The combination of target model element, term, and qualifier uniquely identifies an annotation.
-
- Attribute Qualifier
+
+Attribute Qualifier
Annotation elements that are children of an edm:Annotations
element MUST NOT provide a value for the qualifier attribute if the parent edm:Annotations
element provides a value for the qualifier attribute.
@@ -2186,8 +2186,8 @@ 14.2.2 Target
14.3 Constant Expression
Constant expressions allow assigning a constant value to an applied term.
14.3.1 Binary
-
- Expression edm:Binary
+
+Expression edm:Binary
The edm:Binary
expression evaluates to a primitive binary value. A binary expression MUST be assigned a value conforming to the rule binaryValue
in OData-ABNF.
The binary expression MAY be provided using element notation or attribute notation.
@@ -2200,8 +2200,8 @@ Expression
</Annotation>
14.3.2 Boolean
-
- Expression edm:Bool
+
+Expression edm:Bool
The edm:Bool
expression evaluates to a primitive Boolean value. A Boolean expression MUST be assigned a Boolean value.
The Boolean expression MAY be provided using element notation or attribute notation.
@@ -2214,8 +2214,8 @@ Expression </Annotation>
14.3.3 Date
-
- Expression edm:Date
+
+Expression edm:Date
The edm:Date
expression evaluates to a primitive date value. A date expression MUST be assigned a value of type xs:date
, see XML-Schema-2, section 3.3.9. The value MUST also conform to rule dateValue
in OData-ABNF, i.e. it MUST NOT contain a time-zone offset.
The date expression MAY be provided using element notation or attribute notation.
@@ -2228,8 +2228,8 @@ Expression </Annotation>
14.3.4 DateTimeOffset
-
- Expression edm:DateTimeOffset
+
+Expression edm:DateTimeOffset
The edm:DateTimeOffset
expression evaluates to a primitive datetimestamp value with a time-zone offset. A datetimestamp expression MUST be assigned a value of type xs:dateTimeStamp
, see XML-Schema-2, section 3.4.28. The value MUST also conform to rule dateTimeOffsetValue
in OData-ABNF, i.e. it MUST NOT contain an end-of-day fragment (24:00:00).
The datetimestamp expression MAY be provided using element notation or attribute notation.
@@ -2244,8 +2244,8 @@ </Annotation>
14.3.5 Decimal
-
- Expression edm:Decimal
+
+Expression edm:Decimal
The edm:Decimal
expression evaluates to a primitive decimal value. A decimal expression MUST be assigned a value conforming to the rule decimalValue
in OData-ABNF.
The decimal expression MAY be provided using element notation or attribute notation.
@@ -2260,8 +2260,8 @@ Expressio
</Annotation>
14.3.6 Duration
-
- Expression edm:Duration
+
+Expression edm:Duration
The edm:Duration
expression evaluates to a primitive duration value. A duration expression MUST be assigned a value of type xs:dayTimeDuration
, see XML-Schema-2, section 3.4.27.
The duration expression MAY be provided using element notation or attribute notation.
@@ -2274,8 +2274,8 @@ Express
</Annotation>
14.3.7 Enumeration Member
-
- Expression edm:EnumMember
+
+Expression edm:EnumMember
The edm:EnumMember
expression references a member of an enumeration type. An enumeration member expression MUST be assigned a value that consists of the qualified name of the enumeration type, followed by a forward slash and the name of the enumeration member. If the enumeration type specifies an IsFlags
attribute with value true
, the expression MAY also be assigned a whitespace-separated list of values. Each of these values MUST resolve to the name of a member of the enumeration type of the specified term.
The enumeration member expression MAY be provided using element notation or attribute notation.
@@ -2298,8 +2298,8 @@ Exp
</Annotation>
14.3.8 Floating-Point Number
-
- Expression edm:Float
+
+Expression edm:Float
The edm:Float
expression evaluates to a primitive floating point (or double) value. A float expression MUST be assigned a value conforming to the rule doubleValue
in OData-ABNF.
The float expression MAY be provided using element notation or attribute notation.
@@ -2312,8 +2312,8 @@ Expression </Annotation>
edm:Guid
edm:Guid
The edm:Guid
expression evaluates to a primitive guid value. A guid expression MUST be assigned a value conforming to the rule guidValue
in OData-ABNF.
The guid expression MAY be provided using element notation or attribute notation.
edm:Int
edm:Int
The edm:Int
expression evaluates to a primitive integer value. An integer MUST be assigned a value conforming to the rule int64Value
in OData-ABNF.
The integer expression MAY be provided using element notation or attribute notation.
</Annotation>
edm:String
edm:String
The edm:String
expression evaluates to a primitive string value. A string expression MUST be assigned a value of the type xs:string
, see XML-Schema-2, section 3.3.1.
The string expression MAY be provided using element notation or attribute notation.
edm:TimeOfDay
edm:TimeOfDay
The edm:TimeOfDay
expression evaluates to a primitive time value. A time-of-day expression MUST be assigned a value conforming to the rule timeOfDayValue
in OData-ABNF.
The time-of-day expression MAY be provided using element notation or attribute notation.
A term or term property of type Edm.AnnotationPath
can be annotated with term Validation.AllowedTerms
(see OData-VocValidation) if its intended value is an annotation path that ends in a term cast with one of the listed terms.
The value of the annotation path expression is the path itself, not the value of the annotation identified by the path. This is useful for terms that reuse or refer to other terms.
-edm:AnnotationPath
edm:AnnotationPath
The edm:AnnotationPath
expression MAY be provided using element notation or attribute notation.
The model element path expression provides a value for terms or term properties that specify the built-in type Edm.ModelElementPath
. Its argument is a model path.
The value of the model element path expression is the path itself, not the instance(s) identified by the path.
-edm:ModelElementPath
edm:ModelElementPath
The edm:ModelElementPath
expression MAY be provided using element notation or attribute notation.
edm:NavigationPropertyPath
edm:NavigationPropertyPath
The edm:NavigationPropertyPath
expression MAY be provided using element notation or attribute notation.
The value of the property path expression is the path itself, not the value of the structural property or the value of the term cast identified by the path.
-edm:PropertyPath
edm:PropertyPath
The edm:PropertyPath
MAY be provided using either element notation or attribute notation.
The value path expression allows assigning a value by traversing an object graph. It can be used in annotations that target entity containers, entity sets, entity types, complex types, navigation properties of structured types, and structural properties of structured types. Its argument is an instance path.
The value of the path expression is the instance or collection of instances identified by the path.
-edm:Path
edm:Path
The edm:Path
expression MAY be provided using element notation or attribute notation.
The other comparison operators require two operand expressions that evaluate to comparable values.
edm:And
and edm:Or
edm:And
and edm:Or
The And
and Or
logical expressions are represented as elements edm:And
and edm:Or
that MUST contain two annotation expressions.
It MAY contain edm:Annotation
elements.
edm:Not
edm:Not
Negation expressions are represented as an element edm:Not
that MUST contain a single annotation expression.
It MAY contain edm:Annotation
elements.
edm:Eq
, edm:Ne
, edm:Gt
, edm:Ge
, edm:Lt
, edm:Le
, edm:Has
, and edm:In
edm:Eq
, edm:Ne
, edm:Gt
, edm:Ge
, edm:Lt
, edm:Le
, edm:Has
, and edm:In
All comparison expressions are represented as an element that MUST contain two annotation expressions.
They MAY contain edm:Annotation
elements.
edm:Neg
edm:Neg
Negation expressions are represented as an element edm:Neg
that MUST contain a single annotation expression.
It MAY contain edm:Annotation
elements.
edm:Add
, edm:Sub
, edm:Mul
, edm:Div
, edm:DivBy
, and edm:Mod
edm:Add
, edm:Sub
, edm:Mul
, edm:Div
, edm:DivBy
, and edm:Mod
These arithmetic expressions are represented as an element that MUST contain two annotation expressions.
They MAY contain edm:Annotation
elements.
The apply expression enables a value to be obtained by applying a client-side function. The apply expression MAY have operand expressions. The operand expressions are used as parameters to the client-side function.
edm:Apply
edm:Apply
The edm:Apply
element MUST contain the Function
attribute and MAY contain annotation expressions as operands for the applied function.
It MAY contain more edm:Annotation
elements.
Function
Function
The value of Function
is the qualified name of the client-side function to apply.
OData defines the following functions. Services MAY support additional functions that MUST be qualified with a namespace other than odata
. Function names qualified with odata
are reserved for this specification and its future versions.
The cast expression casts the value obtained from its single child expression to the specified type. The cast expression follows the same rules as the cast
canonical function defined in OData-URL.
edm:Cast
edm:Cast
The edm:Cast
element MUST contain the Type
attribute and MUST contain exactly one expression.
It MAY contain edm:Annotation
elements.
Type
Type
The value of Type
is a qualified type name in scope, or the character sequence Collection(
followed by the qualified name of a type in scope, followed by a closing parenthesis )
.
If the specified type is a primitive type or a collection of a primitive type, the facet attributes MaxLength
, Unicode
, Precision
, Scale
, and SRID
MAY be specified if applicable to the specified primitive type. If the facet attributes are not specified, their values are considered unspecified.
The collection expression enables a value to be obtained from zero or more item expressions. The value calculated by the collection expression is the collection of the values calculated by each of the item expressions. The values of the child expressions MUST all be type compatible.
-edm:Collection
edm:Collection
The edm:Collection
element contains zero or more child expressions.
The first child expression is the condition and MUST evaluate to a Boolean result, e.g. the comparison and logical operators can be used.
The second and third child expressions are evaluated conditionally. The result MUST be type compatible with the type expected by the surrounding expression.
If the first expression evaluates to true
, the second expression MUST be evaluated and its value MUST be returned as the result of the if-then-else expression. If the first expression evaluates to false
and a third child element is present, it MUST be evaluated and its value MUST be returned as the result of the if-then-else expression. If no third expression is present, nothing is added to the surrounding collection.
edm:If
edm:If
The edm:If
element MUST contain two or three child expressions that MUST use element notation.
It MAY contain edm:Annotation
elements.
ed
The is-of
expression checks whether the value obtained from its single child expression is compatible with the specified type. It returns true
if the child expression returns a type that is compatible with the specified type, and false
otherwise.
edm:UrlRef
edm:UrlRef
The edm:UrlRef
expression MAY be provided using element notation or attribute notation.
Relative URLs are relative to the xml:base
attribute, see XML-Base.
In element notation it MAY contain edm:Annotation
elements.
A labeled element expression MUST contain exactly one child expression. The value of the child expression is also the value of the labeled element expression.
A labeled element expression MUST provide a simple identifier value as its name that MUST be unique within the schema containing the expression.
edm:LabeledElement
edm:LabeledElement
The edm:LabeledElement
element MUST contain the Name attribute.
It MUST contain a child expression written either in attribute notation or element notation.
It MAY contain edm:Annotation
elements.
Name
Name
The value of Name
is the labeled element's name.
The labeled element reference expression MUST specify the qualified name of a labeled element expression in scope and returns the value of the identified labeled element expression as its value.
-edm:LabeledElementReference
edm:LabeledElementReference
The edm:LabeledElementReference
element MUST contain the qualified name of a labeled element expression in its body.
The null expression indicates the absence of a value. The null expression MAY be annotated.
-edm:Null
edm:Null
The edm:Null
element MAY contain edm:Annotation
elements.
A record expression contains zero or more property value expressions. For each single-valued structural or navigation property of the record expression's type that is neither nullable nor specifies a default value a property value expression MUST be provided. The only exception is if the record expression is the value of an annotation for a term that has a base term whose type is structured and directly or indirectly inherits from the type of its base term. In this case, property values that already have been specified in the annotation for the base term or its base term etc. need not be specified again.
For collection-valued properties the absence of a property value expression is equivalent to specifying an empty collection as its value.
edm:Record
edm:Record
The edm:Record
element MAY contain the Type
attribute and MAY contain edm:PropertyValue
elements.
It MAY contain edm:Annotation
elements.
Type
Type
The value of Type
is the qualified name of a structured type in scope.
edm:PropertyValue
edm:PropertyValue
The edm:PropertyValue
element MUST contain the Property
attribute, and it MUST contain exactly one expression that MAY be provided using either element notation or attribute notation.
It MAY contain edm:Annotation
elements.
Property
Property
The value of Property
is the name of a property of the type of the enclosing edm:Record
expression.
The URL reference expression enables a value to be obtained by sending a GET
request.
The URL reference expression MUST contain exactly one expression of type Edm.String
. Its value is treated as a URL that MAY be relative or absolute; relative URLs are relative to the URL of the document containing the URL reference expression, or relative to a base URL specified in a format-specific way.
The response body of the GET
request MUST be returned as the result of the URL reference expression. The result of the URL reference expression MUST be type compatible with the type expected by the surrounding expression.
edm:UrlRef
edm:UrlRef
The edm:UrlRef
expression MAY be provided using element notation or attribute notation.
Relative URLs are relative to the xml:base
attribute, see XML-Base.
In element notation it MAY contain edm:Annotation
elements.