|  | import{_ as e,o as n,c as t,a,f as s}from"./app-dc5882c4.js";const i={},o=s(`<h1 id="continuous-interval-functions" tabindex="-1"><a class="header-anchor" href="#continuous-interval-functions" aria-hidden="true">#</a> Continuous Interval Functions</h1><p>The continuous interval functions are used to query all continuous intervals that meet specified conditions.<br> They can be divided into two categories according to return value:</p><ol><li>Returns the start timestamp and time span of the continuous interval that meets the conditions (a time span of 0 means that only the start time point meets the conditions)</li><li>Returns the start timestamp of the continuous interval that meets the condition and the number of points in the interval (a number of 1 means that only the start time point meets the conditions)</li></ol><table><thead><tr><th>Function Name</th><th>Allowed Input Series Data Types</th><th>Required Attributes</th><th>Output Series Data Type</th><th>Description</th></tr></thead><tbody><tr><td>ZERO_DURATION</td><td>INT32/ INT64/ FLOAT/ DOUBLE/ BOOLEAN</td><td><code>min</code>:Optional with default value <code>0L</code><br><code>max</code>:Optional with default value <code>Long.MAX_VALUE</code></td><td>Long</td><td>Return intervals' start times and duration times in which the value is always 0(false), and the duration time <code>t</code> satisfy <code>t >= min && t <= max</code>. The unit of <code>t</code> is ms</td></tr><tr><td>NON_ZERO_DURATION</td><td>INT32/ INT64/ FLOAT/ DOUBLE/ BOOLEAN</td><td><code>min</code>:Optional with default value <code>0L</code><br><code>max</code>:Optional with default value <code>Long.MAX_VALUE</code></td><td>Long</td><td>Return intervals' start times and duration times in which the value is always not 0, and the duration time <code>t</code> satisfy <code>t >= min && t <= max</code>. The unit of <code>t</code> is ms</td></tr><tr><td>ZERO_COUNT</td><td>INT32/ INT64/ FLOAT/ DOUBLE/ BOOLEAN</td><td><code>min</code>:Optional with default value <code>1L</code><br><code>max</code>:Optional with default value <code>Long.MAX_VALUE</code></td><td>Long</td><td>Return intervals' start times and the number of data points in the interval in which the value is always 0(false). Data points number <code>n</code> satisfy <code>n >= min && n <= max</code></td></tr><tr><td>NON_ZERO_COUNT</td><td>INT32/ INT64/ FLOAT/ DOUBLE/ BOOLEAN</td><td><code>min</code>:Optional with default value <code>1L</code><br><code>max</code>:Optional with default value <code>Long.MAX_VALUE</code></td><td>Long</td><td>Return intervals' start times and the number of data points in the interval in which the value is always not 0(false). Data points number <code>n</code> satisfy <code>n >= min && n <= max</code></td></tr></tbody></table><h2 id="demonstrate" tabindex="-1"><a class="header-anchor" href="#demonstrate" aria-hidden="true">#</a> Demonstrate</h2><p>Example data:</p><div class="language-text line-numbers-mode" data-ext="text"><pre class="language-text"><code>IoTDB> select s1,s2,s3,s4,s5 from root.sg.d2; | 
|  | +-----------------------------+-------------+-------------+-------------+-------------+-------------+ | 
|  | |                         Time|root.sg.d2.s1|root.sg.d2.s2|root.sg.d2.s3|root.sg.d2.s4|root.sg.d2.s5| | 
|  | +-----------------------------+-------------+-------------+-------------+-------------+-------------+ | 
|  | |1970-01-01T08:00:00.000+08:00|            0|            0|          0.0|          0.0|        false| | 
|  | |1970-01-01T08:00:00.001+08:00|            1|            1|          1.0|          1.0|         true| | 
|  | |1970-01-01T08:00:00.002+08:00|            1|            1|          1.0|          1.0|         true| | 
|  | |1970-01-01T08:00:00.003+08:00|            0|            0|          0.0|          0.0|        false| | 
|  | |1970-01-01T08:00:00.004+08:00|            1|            1|          1.0|          1.0|         true| | 
|  | |1970-01-01T08:00:00.005+08:00|            0|            0|          0.0|          0.0|        false| | 
|  | |1970-01-01T08:00:00.006+08:00|            0|            0|          0.0|          0.0|        false| | 
|  | |1970-01-01T08:00:00.007+08:00|            1|            1|          1.0|          1.0|         true| | 
|  | +-----------------------------+-------------+-------------+-------------+-------------+-------------+ | 
|  | </code></pre><div class="line-numbers" aria-hidden="true"><div class="line-number"></div><div class="line-number"></div><div class="line-number"></div><div class="line-number"></div><div class="line-number"></div><div class="line-number"></div><div class="line-number"></div><div class="line-number"></div><div class="line-number"></div><div class="line-number"></div><div class="line-number"></div><div class="line-number"></div><div class="line-number"></div></div></div><p>Sql:</p><div class="language-sql line-numbers-mode" data-ext="sql"><pre class="language-sql"><code><span class="token keyword">select</span> s1<span class="token punctuation">,</span> zero_count<span class="token punctuation">(</span>s1<span class="token punctuation">)</span><span class="token punctuation">,</span> non_zero_count<span class="token punctuation">(</span>s2<span class="token punctuation">)</span><span class="token punctuation">,</span> zero_duration<span class="token punctuation">(</span>s3<span class="token punctuation">)</span><span class="token punctuation">,</span> non_zero_duration<span class="token punctuation">(</span>s4<span class="token punctuation">)</span> <span class="token keyword">from</span> root<span class="token punctuation">.</span>sg<span class="token punctuation">.</span>d2<span class="token punctuation">;</span> | 
|  | </code></pre><div class="line-numbers" aria-hidden="true"><div class="line-number"></div></div></div><p>Result:</p><div class="language-text line-numbers-mode" data-ext="text"><pre class="language-text"><code>+-----------------------------+-------------+-------------------------+-----------------------------+----------------------------+--------------------------------+ | 
|  | |                         Time|root.sg.d2.s1|zero_count(root.sg.d2.s1)|non_zero_count(root.sg.d2.s2)|zero_duration(root.sg.d2.s3)|non_zero_duration(root.sg.d2.s4)| | 
|  | +-----------------------------+-------------+-------------------------+-----------------------------+----------------------------+--------------------------------+ | 
|  | |1970-01-01T08:00:00.000+08:00|            0|                        1|                         null|                           0|                            null| | 
|  | |1970-01-01T08:00:00.001+08:00|            1|                     null|                            2|                        null|                               1| | 
|  | |1970-01-01T08:00:00.002+08:00|            1|                     null|                         null|                        null|                            null| | 
|  | |1970-01-01T08:00:00.003+08:00|            0|                        1|                         null|                           0|                            null| | 
|  | |1970-01-01T08:00:00.004+08:00|            1|                     null|                            1|                        null|                               0| | 
|  | |1970-01-01T08:00:00.005+08:00|            0|                        2|                         null|                           1|                            null| | 
|  | |1970-01-01T08:00:00.006+08:00|            0|                     null|                         null|                        null|                            null| | 
|  | |1970-01-01T08:00:00.007+08:00|            1|                     null|                            1|                        null|                               0| | 
|  | +-----------------------------+-------------+-------------------------+-----------------------------+----------------------------+--------------------------------+ | 
|  | </code></pre><div class="line-numbers" aria-hidden="true"><div class="line-number"></div><div class="line-number"></div><div class="line-number"></div><div class="line-number"></div><div class="line-number"></div><div class="line-number"></div><div class="line-number"></div><div class="line-number"></div><div class="line-number"></div><div class="line-number"></div><div class="line-number"></div><div class="line-number"></div></div></div>`,11);function d(l,r){return n(),t("div",null,[a(` | 
|  |  | 
|  | 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. | 
|  |  | 
|  | `),o])}const u=e(i,[["render",d],["__file","Continuous-Interval.html.vue"]]);export{u as default}; |