|  | import{_ as a,r as n,o as l,c as s,a as r,d as t,e,b as d,w as o,f as g}from"./app-6e7c3980.js";const c={},u=g(`<h1 id="auto-create-metadata" tabindex="-1"><a class="header-anchor" href="#auto-create-metadata" aria-hidden="true">#</a> Auto create metadata</h1><p>Automatically creating schema means creating time series based on the characteristics of written data in case time series haven't defined by users themselves.<br> This function can not only solve the problem that entities and measurements are difficult to predict and model in advance under massive time series scenarios,<br> but also provide users with an out-of-the-box writing experience.</p><h2 id="auto-create-storage-group-metadata" tabindex="-1"><a class="header-anchor" href="#auto-create-storage-group-metadata" aria-hidden="true">#</a> Auto create storage group metadata</h2><ul><li>enable_auto_create_schema</li></ul><table><thead><tr><th style="text-align:center;">Name</th><th style="text-align:left;">enable_auto_create_schema</th></tr></thead><tbody><tr><td style="text-align:center;">Description</td><td style="text-align:left;">whether creating schema automatically is enabled</td></tr><tr><td style="text-align:center;">Type</td><td style="text-align:left;">boolean</td></tr><tr><td style="text-align:center;">Default</td><td style="text-align:left;">true</td></tr><tr><td style="text-align:center;">Effective</td><td style="text-align:left;">After restarting system</td></tr></tbody></table><ul><li>default_storage_group_level</li></ul><table><thead><tr><th style="text-align:center;">Name</th><th style="text-align:left;">default_storage_group_level</th></tr></thead><tbody><tr><td style="text-align:center;">Description</td><td style="text-align:left;">Specify which level storage group is in the time series, the default level is 1 (root is on level 0)</td></tr><tr><td style="text-align:center;">Type</td><td style="text-align:left;">int</td></tr><tr><td style="text-align:center;">Default</td><td style="text-align:left;">1</td></tr><tr><td style="text-align:center;">Effective</td><td style="text-align:left;">Only allowed to be modified in first start up</td></tr></tbody></table><p>Illustrated as the following figure:</p><ul><li><p>When default_storage_group_level=1, root.turbine1 and root.turbine2 will be set as storage group.</p></li><li><p>When default_storage_group_level=2, root.turbine1.d1, root.turbine1.d2, root.turbine2.d1 and root.turbine2.d2 will be set as storage group.</p></li></ul><img style="width:100%;max-width:800px;max-height:600px;margin-left:auto;margin-right:auto;display:block;" src="https://alioss.timecho.com/docs/img/UserGuide/Data-Concept/Auto-Create-MetaData/auto_create_sg_example.png?raw=true" alt="auto create storage group example"><h2 id="auto-create-time-series-metadata-specify-data-type-in-the-frontend" tabindex="-1"><a class="header-anchor" href="#auto-create-time-series-metadata-specify-data-type-in-the-frontend" aria-hidden="true">#</a> Auto create time series metadata(specify data type in the frontend)</h2><ul><li><p>Users should specify data type when writing:</p><ul><li>insertTablet method in Session module.</li><li>insert method using TSDataType in Session module.<div class="language-text line-numbers-mode" data-ext="text"><pre class="language-text"><code>public void insertRecord(String deviceId, long time, List<String> measurements, List<TSDataType> types, Object... values); | 
|  | public void insertRecords(List<String> deviceIds, List<Long> times, List<List<String>> measurementsList, List<List<TSDataType>> typesList, List<List<Object>> valuesList); | 
|  | </code></pre><div class="line-numbers" aria-hidden="true"><div class="line-number"></div><div class="line-number"></div></div></div></li><li>......</li></ul></li><li><p>Efficient, time series are auto created when inserting data.</p></li></ul><h2 id="auto-create-time-series-metadata-infer-data-type-in-the-backend" tabindex="-1"><a class="header-anchor" href="#auto-create-time-series-metadata-infer-data-type-in-the-backend" aria-hidden="true">#</a> Auto create time series metadata(infer data type in the backend)</h2><ul><li><p>Just pass string, and the database will infer the data type:</p><ul><li>insert command in CLI module.</li><li>insert method without using TSDataType in Session module.<div class="language-text line-numbers-mode" data-ext="text"><pre class="language-text"><code>public void insertRecord(String deviceId, long time, List<String> measurements, List<TSDataType> types, List<Object> values); | 
|  | public void insertRecords(List<String> deviceIds, List<Long> times, List<List<String>> measurementsList, List<List<String>> valuesList); | 
|  | </code></pre><div class="line-numbers" aria-hidden="true"><div class="line-number"></div><div class="line-number"></div></div></div></li><li>......</li></ul></li><li><p>Since type inference will increase the writing time, the efficiency of auto creating time series metadata through type inference is lower than that of auto creating time series metadata through specifying data type. We recommend users choose specifying data type in the frontend when possible.</p></li></ul><h3 id="type-inference" tabindex="-1"><a class="header-anchor" href="#type-inference" aria-hidden="true">#</a> Type inference</h3><table><thead><tr><th style="text-align:center;">Data(String Format)</th><th style="text-align:left;">Format Type</th><th style="text-align:left;">iotdb-engine.properties</th><th style="text-align:left;">Default</th></tr></thead><tbody><tr><td style="text-align:center;">true</td><td style="text-align:left;">boolean</td><td style="text-align:left;">boolean_string_infer_type</td><td style="text-align:left;">BOOLEAN</td></tr><tr><td style="text-align:center;">1</td><td style="text-align:left;">integer</td><td style="text-align:left;">integer_string_infer_type</td><td style="text-align:left;">FLOAT</td></tr><tr><td style="text-align:center;">17000000(integer > 2^24)</td><td style="text-align:left;">integer</td><td style="text-align:left;">long_string_infer_type</td><td style="text-align:left;">DOUBLE</td></tr><tr><td style="text-align:center;">1.2</td><td style="text-align:left;">floating</td><td style="text-align:left;">floating_string_infer_type</td><td style="text-align:left;">FLOAT</td></tr><tr><td style="text-align:center;">NaN</td><td style="text-align:left;">nan</td><td style="text-align:left;">nan_string_infer_type</td><td style="text-align:left;">DOUBLE</td></tr><tr><td style="text-align:center;">'I am text'</td><td style="text-align:left;">text</td><td style="text-align:left;">x</td><td style="text-align:left;">x</td></tr></tbody></table><ul><li><p>Data types can be configured as BOOLEAN, INT32, INT64, FLOAT, DOUBLE, TEXT.</p></li><li><p>long_string_infer_type is used to avoid precision loss caused by using integer_string_infer_type=FLOAT to infer num > 2^24.</p></li></ul><h3 id="encoding-type" tabindex="-1"><a class="header-anchor" href="#encoding-type" aria-hidden="true">#</a> Encoding Type</h3><table><thead><tr><th style="text-align:left;">Data Type</th><th style="text-align:left;">iotdb-engine.properties</th><th style="text-align:left;">Default</th></tr></thead><tbody><tr><td style="text-align:left;">BOOLEAN</td><td style="text-align:left;">default_boolean_encoding</td><td style="text-align:left;">RLE</td></tr><tr><td style="text-align:left;">INT32</td><td style="text-align:left;">default_int32_encoding</td><td style="text-align:left;">RLE</td></tr><tr><td style="text-align:left;">INT64</td><td style="text-align:left;">default_int64_encoding</td><td style="text-align:left;">RLE</td></tr><tr><td style="text-align:left;">FLOAT</td><td style="text-align:left;">default_float_encoding</td><td style="text-align:left;">GORILLA</td></tr><tr><td style="text-align:left;">DOUBLE</td><td style="text-align:left;">default_double_encoding</td><td style="text-align:left;">GORILLA</td></tr><tr><td style="text-align:left;">TEXT</td><td style="text-align:left;">default_text_encoding</td><td style="text-align:left;">PLAIN</td></tr></tbody></table>`,19),h=t("li",null,[t("p",null,"Encoding types can be configured as PLAIN, RLE, TS_2DIFF, GORILLA, DICTIONARY.")],-1);function f(y,p){const i=n("RouterLink");return l(),s("div",null,[r(` | 
|  |  | 
|  | Licensed to the Apache Software Foundation (ASF) under one | 
|  | or more contributor license agreements.  See the NOTICE file | 
|  | distributed with this work for additional information | 
|  | regarding copyright ownership.  The ASF licenses this file | 
|  | to you under the Apache License, Version 2.0 (the | 
|  | "License"); you may not use this file except in compliance | 
|  | with the License.  You may obtain a copy of the License at | 
|  |  | 
|  | http://www.apache.org/licenses/LICENSE-2.0 | 
|  |  | 
|  | Unless required by applicable law or agreed to in writing, | 
|  | software distributed under the License is distributed on an | 
|  | "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY | 
|  | KIND, either express or implied.  See the License for the | 
|  | specific language governing permissions and limitations | 
|  | under the License. | 
|  |  | 
|  | `),u,t("ul",null,[h,t("li",null,[t("p",null,[e("The corresponding relationship between data types and encoding types is detailed in "),d(i,{to:"/UserGuide/V0.13.x/Data-Concept/Encoding.html"},{default:o(()=>[e("Encoding")]),_:1}),e(".")])])])])}const x=a(c,[["render",f],["__file","Auto-Create-MetaData.html.vue"]]);export{x as default}; |