[英]How to model a list in YANG with no common child elements?
我有一个看起来像这样的 XML。
<c>
<node>
<id1>value</id1>
<id2>value</id2>
</node>
<node>
<id3>value</id3>
<id4>value</id4>
</node>
</c>
这个列表如何在 YANG 中建模? 这里的问题是每个列表都需要一个键。 我试图做的事情:
container c {
list node {
key ""; /* What is the key? */
leaf id1 {
type string;
}
leaf id2{
type string;
}
leaf id3 {
type string;
}
leaf id4 {
type string;
}
}
}
model 这个在 YANG 没有好办法。 就像您说的那样,每个(配置为真)列表都需要一个密钥。 将叶子指定为键会使该叶子成为强制性的,因此您不能真正拥有像示例中那样的实例文档 - 如果您将所有四个叶子都设为键(您可以这样做,因为可能有多个列表键)每个节点都有让所有这些都有效,并且只让其中几个成为键,也不适用于您的示例。
请注意,配置错误列表不需要任何键。 如果您不是对配置(或 NETCONF/RESTCONF 相关数据)进行建模,那可能是您的出路。
list node {
config false;
// ...
}
否则,您别无选择 - 您需要引入另一个叶子作为条目的 id。
无论哪种方式,您都可能会利用unique
语句(我假设基于您的叶子名称)来使列表中的条目唯一。 它的工作方式与key
类似,但如果使用它,元素不需要出现在实例文档中 - 它只要求出现在实例中的节点组合在列表的所有条目中是唯一的。
list node {
config false;
unique "id1 id2 id3 id4";
// ...
}
注意:有一个类似的已回答问题,其中包含更多详细信息。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.