blob: d7e96a1405790651326e5391e9e98117d7da31cf [file] [log] [blame]
(window.webpackJsonp=window.webpackJsonp||[]).push([[287],{682:function(e,t,a){"use strict";a.r(t);var s=a(29),r=Object(s.a)({},(function(){var e=this,t=e._self._c;return t("ContentSlotsDistributor",{attrs:{"slot-key":e.$parent.slotKey}},[t("h1",{attrs:{id:"data-model"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#data-model"}},[e._v("#")]),e._v(" Data Model")]),e._v(" "),t("p",[e._v("A wind power IoT scenario is taken as an example to illustrate how to creat a correct data model in IoTDB.")]),e._v(" "),t("p",[e._v('According to the enterprise organization structure and equipment entity hierarchy, it is expressed as an attribute hierarchy structure, as shown below. The hierarchical from top to bottom is: power group layer - power plant layer - entity layer - measurement layer. ROOT is the root node, and each node of measurement layer is a leaf node. In the process of using IoTDB, the attributes on the path from ROOT node is directly connected to each leaf node with ".", thus forming the name of a timeseries in IoTDB. For example, The left-most path in Figure 2.1 can generate a timeseries named '),t("code",[e._v("root.ln.wf01.wt01.status")]),e._v(".")]),e._v(" "),t("center",[t("img",{staticStyle:{width:"100%","max-width":"800px","max-height":"600px","margin-left":"auto","margin-right":"auto",display:"block"},attrs:{src:"https://user-images.githubusercontent.com/19167280/122668849-b1c69280-d1ec-11eb-83cb-3b73c40bdf72.png"}})]),e._v(" "),t("p",[e._v("Here are the basic concepts of the model involved in IoTDB.")]),e._v(" "),t("h2",{attrs:{id:"measurement-entity-storage-group-path"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#measurement-entity-storage-group-path"}},[e._v("#")]),e._v(" Measurement, Entity, Storage Group, Path")]),e._v(" "),t("h3",{attrs:{id:"measurement-also-called-field"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#measurement-also-called-field"}},[e._v("#")]),e._v(" Measurement (Also called field)")]),e._v(" "),t("p",[e._v("It is information measured by detection equipment in an actual scene and can transform the sensed information into an electrical signal or other desired form of information output and send it to IoTDB. In IoTDB, all data and paths stored are organized in units of measurements.")]),e._v(" "),t("h3",{attrs:{id:"entity-also-called-device"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#entity-also-called-device"}},[e._v("#")]),e._v(" Entity (Also called device)")]),e._v(" "),t("p",[t("strong",[e._v("An entity")]),e._v(" is an equipped with measurements in real scenarios. In IoTDB, all measurements should have their corresponding entities.")]),e._v(" "),t("h3",{attrs:{id:"storage-group"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#storage-group"}},[e._v("#")]),e._v(" Storage Group")]),e._v(" "),t("p",[t("strong",[e._v("A group of entities.")]),e._v(" Users can set any prefix path as a storage group. Provided that there are four timeseries "),t("code",[e._v("root.ln.wf01.wt01.status")]),e._v(", "),t("code",[e._v("root.ln.wf01.wt01.temperature")]),e._v(", "),t("code",[e._v("root.ln.wf02.wt02.hardware")]),e._v(", "),t("code",[e._v("root.ln.wf02.wt02.status")]),e._v(", two devices "),t("code",[e._v("wt01")]),e._v(", "),t("code",[e._v("wt02")]),e._v(" under the path "),t("code",[e._v("root.ln")]),e._v(" may belong to the same owner or the same manufacturer, so d1 and d2 are closely related. At this point, the prefix path root.vehicle can be designated as a storage group, which will enable IoTDB to store all devices under it in the same folder. Newly added devices under "),t("code",[e._v("root.ln")]),e._v(" will also belong to this storage group.")]),e._v(" "),t("blockquote",[t("p",[e._v("Note1: A full path ("),t("code",[e._v("root.ln.wf01.wt01.status")]),e._v(" as in the above example) is not allowed to be set as a storage group.")]),e._v(" "),t("p",[e._v("Note2: The prefix of a timeseries must belong to a storage group. Before creating a timeseries, users must set which storage group the series belongs to. Only timeseries whose storage group is set can be persisted to disk.")])]),e._v(" "),t("p",[e._v("Once a prefix path is set as a storage group, the storage group settings cannot be changed.")]),e._v(" "),t("p",[e._v("After a storage group is set, the ancestral layers, children and descendant layers of the corresponding prefix path are not allowed to be set up again (for example, after "),t("code",[e._v("root.ln")]),e._v(" is set as the storage group, the root layer and "),t("code",[e._v("root.ln.wf01")]),e._v(" are not allowed to be set as storage groups).")]),e._v(" "),t("p",[e._v("The Layer Name of storage group can only consist of characters, numbers, underscores and hyphen, like "),t("code",[e._v("root.storagegroup_1-sg1")]),e._v(".")]),e._v(" "),t("h3",{attrs:{id:"path"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#path"}},[e._v("#")]),e._v(" Path")]),e._v(" "),t("p",[e._v("A "),t("code",[e._v("path")]),e._v(" is an expression that conforms to the following constraints:")]),e._v(" "),t("div",{staticClass:"language-sql line-numbers-mode"},[t("pre",{pre:!0,attrs:{class:"language-sql"}},[t("code",[e._v("path \n : layer_name "),t("span",{pre:!0,attrs:{class:"token punctuation"}},[e._v("(")]),t("span",{pre:!0,attrs:{class:"token string"}},[e._v("'.'")]),e._v(" layer_name"),t("span",{pre:!0,attrs:{class:"token punctuation"}},[e._v(")")]),t("span",{pre:!0,attrs:{class:"token operator"}},[e._v("*")]),e._v("\n "),t("span",{pre:!0,attrs:{class:"token punctuation"}},[e._v(";")]),e._v("\nlayer_name\n : wildcard? id wildcard?\n "),t("span",{pre:!0,attrs:{class:"token operator"}},[e._v("|")]),e._v(" wildcard\n "),t("span",{pre:!0,attrs:{class:"token punctuation"}},[e._v(";")]),e._v("\nwildcard \n : "),t("span",{pre:!0,attrs:{class:"token string"}},[e._v("'*'")]),e._v(" \n "),t("span",{pre:!0,attrs:{class:"token operator"}},[e._v("|")]),e._v(" "),t("span",{pre:!0,attrs:{class:"token string"}},[e._v("'**'")]),e._v("\n "),t("span",{pre:!0,attrs:{class:"token punctuation"}},[e._v(";")]),e._v("\n")])]),e._v(" "),t("div",{staticClass:"line-numbers-wrapper"},[t("span",{staticClass:"line-number"},[e._v("1")]),t("br"),t("span",{staticClass:"line-number"},[e._v("2")]),t("br"),t("span",{staticClass:"line-number"},[e._v("3")]),t("br"),t("span",{staticClass:"line-number"},[e._v("4")]),t("br"),t("span",{staticClass:"line-number"},[e._v("5")]),t("br"),t("span",{staticClass:"line-number"},[e._v("6")]),t("br"),t("span",{staticClass:"line-number"},[e._v("7")]),t("br"),t("span",{staticClass:"line-number"},[e._v("8")]),t("br"),t("span",{staticClass:"line-number"},[e._v("9")]),t("br"),t("span",{staticClass:"line-number"},[e._v("10")]),t("br"),t("span",{staticClass:"line-number"},[e._v("11")]),t("br")])]),t("p",[e._v("You can refer to the definition of "),t("code",[e._v("id")]),e._v(" in "),t("RouterLink",{attrs:{to:"/UserGuide/V0.13.x/Reference/Syntax-Conventions.html"}},[e._v("Syntax-Conventions")]),e._v(".")],1),e._v(" "),t("p",[e._v("We call the part of a path divided by "),t("code",[e._v("'.'")]),e._v(" as a layer ("),t("code",[e._v("layer_name")]),e._v("). For example: "),t("code",[e._v("root.a.b.c")]),e._v(" is a path with 4 layers.")]),e._v(" "),t("p",[e._v("The following are the constraints on the layer ("),t("code",[e._v("layer_name")]),e._v("):")]),e._v(" "),t("ul",[t("li",[t("p",[t("code",[e._v("root")]),e._v(" is a reserved character, and it is only allowed to appear at the beginning layer of the time series mentioned below. If "),t("code",[e._v("root")]),e._v(" appears in other layers, it cannot be parsed and an error will be reported.")])]),e._v(" "),t("li",[t("p",[e._v("Except for the beginning layer ("),t("code",[e._v("root")]),e._v(") of the time series, the characters supported in other layers are as follows:")]),e._v(" "),t("ul",[t("li",[e._v("Chinese characters: "),t("code",[e._v('"\\u2E80"')]),e._v(" to "),t("code",[e._v('"\\u9FFF"')])]),e._v(" "),t("li",[t("code",[e._v('"_","@","#","$"')])]),e._v(" "),t("li",[t("code",[e._v('"A"')]),e._v(" to "),t("code",[e._v('"Z"')]),e._v(", "),t("code",[e._v('"a"')]),e._v(" to "),t("code",[e._v('"z"')]),e._v(", "),t("code",[e._v('"0"')]),e._v(" to "),t("code",[e._v('"9"')])])])]),e._v(" "),t("li",[t("p",[e._v("In addition to the beginning layer ("),t("code",[e._v("root")]),e._v(") of the time series and the storage group layer, other layers also support the use of special strings referenced by ` or "),t("code",[e._v('"')]),e._v(" as its name. It should be noted that the quoted string cannot contain "),t("code",[e._v(".")]),e._v(" characters. Here are some legal examples:")]),e._v(" "),t("ul",[t("li",[e._v('root.sg."select"."+-from="."where""where"""."$", which contains 6 layers: root, sg, select, +-from, where"where", $')]),e._v(" "),t("li",[e._v('root.sg.````.`select`.`+="from"`.`$`, which contains 6 layers: root, sg, `, select, +-"from", $')])])]),e._v(" "),t("li",[t("p",[e._v("Layer ("),t("code",[e._v("layer_name")]),e._v(") cannot start with a digit unless the layer("),t("code",[e._v("layer_name")]),e._v(") is quoted with ` or "),t("code",[e._v('"')]),e._v(".")])]),e._v(" "),t("li",[t("p",[e._v("In particular, if the system is deployed on a Windows machine, the storage group layer name will be case-insensitive. For example, creating both "),t("code",[e._v("root.ln")]),e._v(" and "),t("code",[e._v("root.LN")]),e._v(" at the same time is not allowed.")])])]),e._v(" "),t("h3",{attrs:{id:"path-pattern"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#path-pattern"}},[e._v("#")]),e._v(" Path Pattern")]),e._v(" "),t("p",[e._v("In order to make it easier and faster to express multiple timeseries paths, IoTDB provides users with the path pattern. Users can construct a path pattern by using wildcard "),t("code",[e._v("*")]),e._v(" and "),t("code",[e._v("**")]),e._v(". Wildcard can appear in any layer of the path.")]),e._v(" "),t("p",[t("code",[e._v("*")]),e._v(" represents one layer. For example, "),t("code",[e._v("root.vehicle.*.sensor1")]),e._v(" represents a 4-layer path which is prefixed with "),t("code",[e._v("root.vehicle")]),e._v(" and suffixed with "),t("code",[e._v("sensor1")]),e._v(".")]),e._v(" "),t("p",[t("code",[e._v("**")]),e._v(" represents ("),t("code",[e._v("*")]),e._v(")+, which is one or more layers of "),t("code",[e._v("*")]),e._v(". For example, "),t("code",[e._v("root.vehicle.device1.**")]),e._v(" represents all paths prefixed by "),t("code",[e._v("root.vehicle.device1")]),e._v(" with layers greater than or equal to 4, like "),t("code",[e._v("root.vehicle.device1.*")]),e._v(", "),t("code",[e._v("root.vehicle.device1.*.*")]),e._v(", "),t("code",[e._v("root.vehicle.device1.*.*.*")]),e._v(", etc; "),t("code",[e._v("root.vehicle.**.sensor1")]),e._v(" represents a path which is prefixed with "),t("code",[e._v("root.vehicle")]),e._v(" and suffixed with "),t("code",[e._v("sensor1")]),e._v(" and has at least 4 layers.")]),e._v(" "),t("blockquote",[t("p",[e._v("Note1: Wildcard "),t("code",[e._v("*")]),e._v(" and "),t("code",[e._v("**")]),e._v(" cannot be placed at the beginning of the path.")])]),e._v(" "),t("h2",{attrs:{id:"timeseries"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#timeseries"}},[e._v("#")]),e._v(" Timeseries")]),e._v(" "),t("h3",{attrs:{id:"timestamp"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#timestamp"}},[e._v("#")]),e._v(" Timestamp")]),e._v(" "),t("p",[e._v("The timestamp is the time point at which data is produced. It includes absolute timestamps and relative timestamps. For detailed description, please go to "),t("RouterLink",{attrs:{to:"/UserGuide/V0.13.x/Data-Concept/Data-Type.html"}},[e._v("Data Type doc")]),e._v(".")],1),e._v(" "),t("h3",{attrs:{id:"data-point"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#data-point"}},[e._v("#")]),e._v(" Data point")]),e._v(" "),t("p",[t("strong",[e._v('A "time-value" pair')]),e._v(".")]),e._v(" "),t("h3",{attrs:{id:"timeseries-2"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#timeseries-2"}},[e._v("#")]),e._v(" Timeseries")]),e._v(" "),t("p",[t("strong",[e._v("The record of a measurement of an entity on the time axis.")]),e._v(" Timeseries is a series of data points.")]),e._v(" "),t("p",[e._v("A measurement of an entity corresponds to a timeseries.")]),e._v(" "),t("p",[e._v("Also called meter, timeline, and tag, parameter in real time database.")]),e._v(" "),t("p",[e._v("For example, if entity wt01 in power plant wf01 of power group ln has a measurement named status, its timeseries can be expressed as: "),t("code",[e._v("root.ln.wf01.wt01.status")]),e._v(".")]),e._v(" "),t("h3",{attrs:{id:"aligned-timeseries"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#aligned-timeseries"}},[e._v("#")]),e._v(" Aligned timeseries")]),e._v(" "),t("p",[e._v("There is a situation that multiple measurements of an entity are sampled simultaneously in practical applications, forming multiple timeseries aligned on a time column.")]),e._v(" "),t("p",[e._v("By using aligned timeseries, the timestamp columns of a group of aligned timeseries need to be stored only once in memory and disk when inserting data, instead of once per timeseries.")]),e._v(" "),t("p",[e._v("It would be best if you created a group of aligned timeseries at the same time.")]),e._v(" "),t("p",[e._v("You cannot create non-aligned timeseries under the entity to which the aligned timeseries belong, nor can you create aligned timeseries under the entity to which the non-aligned timeseries belong.")]),e._v(" "),t("p",[e._v("When querying, you can query each timeseries separately.")]),e._v(" "),t("p",[e._v("When inserting data, it is allowed to insert null value in the aligned timeseries.")]),e._v(" "),t("img",{staticStyle:{width:"100%","max-width":"800px","max-height":"600px","margin-left":"auto","margin-right":"auto",display:"block"},attrs:{src:"https://user-images.githubusercontent.com/19167280/114125919-f4850800-9929-11eb-8211-81d4c04af1ec.png"}}),e._v(" "),t("p",[e._v("In the following chapters of data definition language, data operation language and Java Native Interface, various operations related to aligned timeseries will be introduced one by one.")]),e._v(" "),t("h2",{attrs:{id:"schema-template"}},[t("a",{staticClass:"header-anchor",attrs:{href:"#schema-template"}},[e._v("#")]),e._v(" Schema Template")]),e._v(" "),t("p",[e._v("In the actual scenario, many entities collect the same measurements, that is, they have the same measurements name and type. A "),t("strong",[e._v("schema template")]),e._v(" can be declared to define the collectable measurements set. Schema template helps save memory by implementing schema sharing. For detailed description, please refer to "),t("RouterLink",{attrs:{to:"/UserGuide/V0.13.x/Data-Concept/Schema-Template.html"}},[e._v("Schema Template doc")]),e._v(".")],1),e._v(" "),t("p",[e._v("In the following chapters of, data definition language, data operation language and Java Native Interface, various operations related to schema template will be introduced one by one.")])],1)}),[],!1,null,null,null);t.default=r.exports}}]);