<!DOCTYPE html>
<html lang="en-US">
  <head>
    <meta charset="utf-8">
    <meta name="viewport" content="width=device-width,initial-scale=1">
    <title> </title>
    <meta name="generator" content="VuePress 1.8.2">
    <link rel="icon" href="/favicon.ico">
    <meta name="description" content=" ">
    <meta name="Description" content="Apache IoTDB: Time Series Database for IoT">
    <meta name="Keywords" content="TSDB, time series, time series database, IoTDB, IoT database, IoT data management,时序数据库, 时间序列管理, IoTDB, 物联网数据库, 实时数据库, 物联网数据管理, 物联网数据">
    <meta name="baidu-site-verification" content="wfKETzB3OT">
    <meta name="google-site-verification" content="mZWAoRY0yj_HAr-s47zHCGHzx5Ju-RVm5wDbPnwQYFo">
    
    <link rel="preload" href="/assets/css/0.styles.f7fca28c.css" as="style"><link rel="preload" href="/assets/js/app.cd07c2fa.js" as="script"><link rel="preload" href="/assets/js/3.2a42f5e4.js" as="script"><link rel="preload" href="/assets/js/239.16e9e1fe.js" as="script"><link rel="prefetch" href="/assets/js/10.61872ae5.js"><link rel="prefetch" href="/assets/js/100.47b29810.js"><link rel="prefetch" href="/assets/js/101.be3f8e41.js"><link rel="prefetch" href="/assets/js/102.ab8764b7.js"><link rel="prefetch" href="/assets/js/103.4c142690.js"><link rel="prefetch" href="/assets/js/104.6042a8b3.js"><link rel="prefetch" href="/assets/js/105.f7c9efe5.js"><link rel="prefetch" href="/assets/js/106.2ba6adb1.js"><link rel="prefetch" href="/assets/js/107.5232a7c3.js"><link rel="prefetch" href="/assets/js/108.ccb521e0.js"><link rel="prefetch" href="/assets/js/109.c6797225.js"><link rel="prefetch" href="/assets/js/11.a080efae.js"><link rel="prefetch" href="/assets/js/110.2c0a21ac.js"><link rel="prefetch" href="/assets/js/111.64f69be0.js"><link rel="prefetch" href="/assets/js/112.3517c2ff.js"><link rel="prefetch" href="/assets/js/113.4b4bb4be.js"><link rel="prefetch" href="/assets/js/114.36c2b5e4.js"><link rel="prefetch" href="/assets/js/115.9447789e.js"><link rel="prefetch" href="/assets/js/116.870509a9.js"><link rel="prefetch" href="/assets/js/117.f1572c4d.js"><link rel="prefetch" href="/assets/js/118.1b482479.js"><link rel="prefetch" href="/assets/js/119.994db15b.js"><link rel="prefetch" href="/assets/js/12.4c48405a.js"><link rel="prefetch" href="/assets/js/120.b39ca53e.js"><link rel="prefetch" href="/assets/js/121.ac3af24a.js"><link rel="prefetch" href="/assets/js/122.d17d7d81.js"><link rel="prefetch" href="/assets/js/123.4aa29866.js"><link rel="prefetch" href="/assets/js/124.ee85ddde.js"><link rel="prefetch" href="/assets/js/125.118d7f8b.js"><link rel="prefetch" href="/assets/js/126.9c2f8dc7.js"><link rel="prefetch" href="/assets/js/127.5fa0f28c.js"><link rel="prefetch" href="/assets/js/128.bf1e94f3.js"><link rel="prefetch" href="/assets/js/129.4479fadb.js"><link rel="prefetch" href="/assets/js/13.16ded47d.js"><link rel="prefetch" href="/assets/js/130.59874ca0.js"><link rel="prefetch" href="/assets/js/131.f9d5e913.js"><link rel="prefetch" href="/assets/js/132.df382fa4.js"><link rel="prefetch" href="/assets/js/133.2605b87b.js"><link rel="prefetch" href="/assets/js/134.7f44a201.js"><link rel="prefetch" href="/assets/js/135.f867beb1.js"><link rel="prefetch" href="/assets/js/136.32dc30f5.js"><link rel="prefetch" href="/assets/js/137.a0b9469d.js"><link rel="prefetch" href="/assets/js/138.0d77670b.js"><link rel="prefetch" href="/assets/js/139.a4687aa3.js"><link rel="prefetch" href="/assets/js/14.81c4b95d.js"><link rel="prefetch" href="/assets/js/140.1c3b9c8e.js"><link rel="prefetch" href="/assets/js/141.ced0e8b4.js"><link rel="prefetch" href="/assets/js/142.0f0eab1f.js"><link rel="prefetch" href="/assets/js/143.b1cbf905.js"><link rel="prefetch" href="/assets/js/144.c8f1a948.js"><link rel="prefetch" href="/assets/js/145.20508b5b.js"><link rel="prefetch" href="/assets/js/146.d6f1ef22.js"><link rel="prefetch" href="/assets/js/147.d3ae33f7.js"><link rel="prefetch" href="/assets/js/148.fbd3c4b0.js"><link rel="prefetch" href="/assets/js/149.68309cce.js"><link rel="prefetch" href="/assets/js/15.bf1d2930.js"><link rel="prefetch" href="/assets/js/150.9bf1f73d.js"><link rel="prefetch" href="/assets/js/151.c102d923.js"><link rel="prefetch" href="/assets/js/152.e1bd669b.js"><link rel="prefetch" href="/assets/js/153.74bb0871.js"><link rel="prefetch" href="/assets/js/154.5930e226.js"><link rel="prefetch" href="/assets/js/155.d1c42f9d.js"><link rel="prefetch" href="/assets/js/156.38141ca2.js"><link rel="prefetch" href="/assets/js/157.d0fa5d7e.js"><link rel="prefetch" href="/assets/js/158.b424c315.js"><link rel="prefetch" href="/assets/js/159.5dcc300f.js"><link rel="prefetch" href="/assets/js/16.d2fb5036.js"><link rel="prefetch" href="/assets/js/160.0163ee71.js"><link rel="prefetch" href="/assets/js/161.ea35ffd3.js"><link rel="prefetch" href="/assets/js/162.ffc62b9b.js"><link rel="prefetch" href="/assets/js/163.63e5a86d.js"><link rel="prefetch" href="/assets/js/164.fc84bb91.js"><link rel="prefetch" href="/assets/js/165.6c824b8c.js"><link rel="prefetch" href="/assets/js/166.397b3e8c.js"><link rel="prefetch" href="/assets/js/167.05e14a7b.js"><link rel="prefetch" href="/assets/js/168.bfae89ef.js"><link rel="prefetch" href="/assets/js/169.2cbaff61.js"><link rel="prefetch" href="/assets/js/17.efe29df6.js"><link rel="prefetch" href="/assets/js/170.f26474b0.js"><link rel="prefetch" href="/assets/js/171.ba1d2df7.js"><link rel="prefetch" href="/assets/js/172.8a7cd300.js"><link rel="prefetch" href="/assets/js/173.4d45b322.js"><link rel="prefetch" href="/assets/js/174.f8eebecd.js"><link rel="prefetch" href="/assets/js/175.6a08a28f.js"><link rel="prefetch" href="/assets/js/176.f83d84c6.js"><link rel="prefetch" href="/assets/js/177.ace4f921.js"><link rel="prefetch" href="/assets/js/178.044fc356.js"><link rel="prefetch" href="/assets/js/179.04f818ee.js"><link rel="prefetch" href="/assets/js/18.ec2f64fe.js"><link rel="prefetch" href="/assets/js/180.50b6e9ae.js"><link rel="prefetch" href="/assets/js/181.38262468.js"><link rel="prefetch" href="/assets/js/182.6e5cc145.js"><link rel="prefetch" href="/assets/js/183.b90f3741.js"><link rel="prefetch" href="/assets/js/184.d8c296fd.js"><link rel="prefetch" href="/assets/js/185.f76280e7.js"><link rel="prefetch" href="/assets/js/186.0c977b03.js"><link rel="prefetch" href="/assets/js/187.26834b77.js"><link rel="prefetch" href="/assets/js/188.914d4380.js"><link rel="prefetch" href="/assets/js/189.28897e83.js"><link rel="prefetch" href="/assets/js/19.e46591ce.js"><link rel="prefetch" href="/assets/js/190.4531db7b.js"><link rel="prefetch" href="/assets/js/191.487b3857.js"><link rel="prefetch" href="/assets/js/192.1f3b6ca8.js"><link rel="prefetch" href="/assets/js/193.a4ebe434.js"><link rel="prefetch" href="/assets/js/194.80d52b93.js"><link rel="prefetch" href="/assets/js/195.3403576e.js"><link rel="prefetch" href="/assets/js/196.05c80d9a.js"><link rel="prefetch" href="/assets/js/197.64dbc6f3.js"><link rel="prefetch" href="/assets/js/198.7a43449a.js"><link rel="prefetch" href="/assets/js/199.4667308c.js"><link rel="prefetch" href="/assets/js/20.335cca54.js"><link rel="prefetch" href="/assets/js/200.6359ec70.js"><link rel="prefetch" href="/assets/js/201.7b157ca9.js"><link rel="prefetch" href="/assets/js/202.97011f10.js"><link rel="prefetch" href="/assets/js/203.e8e6e386.js"><link rel="prefetch" href="/assets/js/204.f9f53b05.js"><link rel="prefetch" href="/assets/js/205.a14130fa.js"><link rel="prefetch" href="/assets/js/206.571a8dbc.js"><link rel="prefetch" href="/assets/js/207.cd154c33.js"><link rel="prefetch" href="/assets/js/208.ec1e91a0.js"><link rel="prefetch" href="/assets/js/209.894ab478.js"><link rel="prefetch" href="/assets/js/21.8c3060b4.js"><link rel="prefetch" href="/assets/js/210.b47e7f1b.js"><link rel="prefetch" href="/assets/js/211.1182daf0.js"><link rel="prefetch" href="/assets/js/212.88cfd73c.js"><link rel="prefetch" href="/assets/js/213.b6784836.js"><link rel="prefetch" href="/assets/js/214.0a76e43e.js"><link rel="prefetch" href="/assets/js/215.31c34e00.js"><link rel="prefetch" href="/assets/js/216.c31c58b1.js"><link rel="prefetch" href="/assets/js/217.e56bd014.js"><link rel="prefetch" href="/assets/js/218.6a193a9b.js"><link rel="prefetch" href="/assets/js/219.c1702bf7.js"><link rel="prefetch" href="/assets/js/22.d30695a0.js"><link rel="prefetch" href="/assets/js/220.e4c8344e.js"><link rel="prefetch" href="/assets/js/221.6c4ef709.js"><link rel="prefetch" href="/assets/js/222.3e573e59.js"><link rel="prefetch" href="/assets/js/223.28393c51.js"><link rel="prefetch" href="/assets/js/224.8872f291.js"><link rel="prefetch" href="/assets/js/225.3d5bcb45.js"><link rel="prefetch" href="/assets/js/226.4b68a654.js"><link rel="prefetch" href="/assets/js/227.a0832c76.js"><link rel="prefetch" href="/assets/js/228.4834ee2a.js"><link rel="prefetch" href="/assets/js/229.0f86fa39.js"><link rel="prefetch" href="/assets/js/23.c21377c0.js"><link rel="prefetch" href="/assets/js/230.6dee403e.js"><link rel="prefetch" href="/assets/js/231.db4b00e9.js"><link rel="prefetch" href="/assets/js/232.46dde63d.js"><link rel="prefetch" href="/assets/js/233.3f928465.js"><link rel="prefetch" href="/assets/js/234.e451ab40.js"><link rel="prefetch" href="/assets/js/235.b83ef0bb.js"><link rel="prefetch" href="/assets/js/236.b647c8c6.js"><link rel="prefetch" href="/assets/js/237.7cbda94b.js"><link rel="prefetch" href="/assets/js/238.f4d80418.js"><link rel="prefetch" href="/assets/js/24.4a86b358.js"><link rel="prefetch" href="/assets/js/240.c85b394f.js"><link rel="prefetch" href="/assets/js/241.1f972f6c.js"><link rel="prefetch" href="/assets/js/242.90755a70.js"><link rel="prefetch" href="/assets/js/243.88b5d9c1.js"><link rel="prefetch" href="/assets/js/244.024e03e6.js"><link rel="prefetch" href="/assets/js/245.df7f3f34.js"><link rel="prefetch" href="/assets/js/246.013095a6.js"><link rel="prefetch" href="/assets/js/247.d09b8d82.js"><link rel="prefetch" href="/assets/js/248.41e0e656.js"><link rel="prefetch" href="/assets/js/249.5fbc353a.js"><link rel="prefetch" href="/assets/js/25.f8281c6e.js"><link rel="prefetch" href="/assets/js/250.0d3aaf39.js"><link rel="prefetch" href="/assets/js/251.0ae7ee46.js"><link rel="prefetch" href="/assets/js/252.d7ea910f.js"><link rel="prefetch" href="/assets/js/253.eb1f2101.js"><link rel="prefetch" href="/assets/js/254.f1632866.js"><link rel="prefetch" href="/assets/js/255.e0cc85d5.js"><link rel="prefetch" href="/assets/js/256.fd4c8b20.js"><link rel="prefetch" href="/assets/js/257.c5d7228d.js"><link rel="prefetch" href="/assets/js/258.f4ff7bfb.js"><link rel="prefetch" href="/assets/js/259.4429563b.js"><link rel="prefetch" href="/assets/js/26.108ee393.js"><link rel="prefetch" href="/assets/js/260.7c2580dd.js"><link rel="prefetch" href="/assets/js/261.b2b00e2e.js"><link rel="prefetch" href="/assets/js/262.ab88ace1.js"><link rel="prefetch" href="/assets/js/263.5f56c054.js"><link rel="prefetch" href="/assets/js/264.2b3be37f.js"><link rel="prefetch" href="/assets/js/265.5c5138c3.js"><link rel="prefetch" href="/assets/js/266.19b07017.js"><link rel="prefetch" href="/assets/js/267.c04bae9d.js"><link rel="prefetch" href="/assets/js/268.1c185126.js"><link rel="prefetch" href="/assets/js/269.9b00598c.js"><link rel="prefetch" href="/assets/js/27.ce2cad14.js"><link rel="prefetch" href="/assets/js/270.79253900.js"><link rel="prefetch" href="/assets/js/271.b2afe860.js"><link rel="prefetch" href="/assets/js/272.db8943f8.js"><link rel="prefetch" href="/assets/js/273.7e70e5b7.js"><link rel="prefetch" href="/assets/js/274.1b5f0c99.js"><link rel="prefetch" href="/assets/js/275.36a23724.js"><link rel="prefetch" href="/assets/js/276.9d87c99a.js"><link rel="prefetch" href="/assets/js/277.73c7fb5f.js"><link rel="prefetch" href="/assets/js/278.72590c19.js"><link rel="prefetch" href="/assets/js/279.6bba344e.js"><link rel="prefetch" href="/assets/js/28.196d9118.js"><link rel="prefetch" href="/assets/js/280.532a4551.js"><link rel="prefetch" href="/assets/js/281.47678c07.js"><link rel="prefetch" href="/assets/js/282.3d676bf0.js"><link rel="prefetch" href="/assets/js/283.8f2b46c3.js"><link rel="prefetch" href="/assets/js/284.6af96cb2.js"><link rel="prefetch" href="/assets/js/285.0a94ea52.js"><link rel="prefetch" href="/assets/js/286.66b3b404.js"><link rel="prefetch" href="/assets/js/287.e8e44717.js"><link rel="prefetch" href="/assets/js/288.c4c894b9.js"><link rel="prefetch" href="/assets/js/289.368cc017.js"><link rel="prefetch" href="/assets/js/29.35566993.js"><link rel="prefetch" href="/assets/js/290.ad040397.js"><link rel="prefetch" href="/assets/js/291.38908283.js"><link rel="prefetch" href="/assets/js/292.9d78c2c3.js"><link rel="prefetch" href="/assets/js/293.276dabda.js"><link rel="prefetch" href="/assets/js/294.14a7328e.js"><link rel="prefetch" href="/assets/js/295.022ce890.js"><link rel="prefetch" href="/assets/js/296.82da5f05.js"><link rel="prefetch" href="/assets/js/297.713c3b6e.js"><link rel="prefetch" href="/assets/js/298.051c397a.js"><link rel="prefetch" href="/assets/js/299.8cb2261f.js"><link rel="prefetch" href="/assets/js/30.2a46f39a.js"><link rel="prefetch" href="/assets/js/300.1edad926.js"><link rel="prefetch" href="/assets/js/301.9e8d9afc.js"><link rel="prefetch" href="/assets/js/302.64b08bcb.js"><link rel="prefetch" href="/assets/js/303.5142e505.js"><link rel="prefetch" href="/assets/js/304.326eed21.js"><link rel="prefetch" href="/assets/js/305.0aa215ce.js"><link rel="prefetch" href="/assets/js/306.857aae36.js"><link rel="prefetch" href="/assets/js/307.2fbda374.js"><link rel="prefetch" href="/assets/js/308.eb2b9bc2.js"><link rel="prefetch" href="/assets/js/309.dd7656fb.js"><link rel="prefetch" href="/assets/js/31.fab44020.js"><link rel="prefetch" href="/assets/js/310.1c1e4a93.js"><link rel="prefetch" href="/assets/js/311.05dd6d98.js"><link rel="prefetch" href="/assets/js/312.479348b4.js"><link rel="prefetch" href="/assets/js/313.665e106f.js"><link rel="prefetch" href="/assets/js/314.36b48a81.js"><link rel="prefetch" href="/assets/js/315.f2e0ffc6.js"><link rel="prefetch" href="/assets/js/316.31b4508b.js"><link rel="prefetch" href="/assets/js/317.9d5d4b6d.js"><link rel="prefetch" href="/assets/js/318.3362bfb2.js"><link rel="prefetch" href="/assets/js/319.a94279d5.js"><link rel="prefetch" href="/assets/js/32.8f287f6a.js"><link rel="prefetch" href="/assets/js/320.575c962a.js"><link rel="prefetch" href="/assets/js/321.e3971e75.js"><link rel="prefetch" href="/assets/js/322.46a74f5d.js"><link rel="prefetch" href="/assets/js/323.0ffeaf3b.js"><link rel="prefetch" href="/assets/js/324.7b5b9e9b.js"><link rel="prefetch" href="/assets/js/325.90e02cd4.js"><link rel="prefetch" href="/assets/js/326.00105535.js"><link rel="prefetch" href="/assets/js/327.4f0759d6.js"><link rel="prefetch" href="/assets/js/328.e458a662.js"><link rel="prefetch" href="/assets/js/329.fcf02a87.js"><link rel="prefetch" href="/assets/js/33.5af74851.js"><link rel="prefetch" href="/assets/js/330.ee20bd02.js"><link rel="prefetch" href="/assets/js/331.2fa6fbda.js"><link rel="prefetch" href="/assets/js/332.7feb498b.js"><link rel="prefetch" href="/assets/js/333.385ba052.js"><link rel="prefetch" href="/assets/js/334.cced60ec.js"><link rel="prefetch" href="/assets/js/335.616cbee6.js"><link rel="prefetch" href="/assets/js/336.ca5b5572.js"><link rel="prefetch" href="/assets/js/337.0c8ef97c.js"><link rel="prefetch" href="/assets/js/338.8a9a7a9e.js"><link rel="prefetch" href="/assets/js/339.a1accaad.js"><link rel="prefetch" href="/assets/js/34.5dfe1291.js"><link rel="prefetch" href="/assets/js/340.2d3d2ae5.js"><link rel="prefetch" href="/assets/js/341.0669ee46.js"><link rel="prefetch" href="/assets/js/342.f04286cc.js"><link rel="prefetch" href="/assets/js/343.10f0d15c.js"><link rel="prefetch" href="/assets/js/344.fc30101e.js"><link rel="prefetch" href="/assets/js/345.db8c549d.js"><link rel="prefetch" href="/assets/js/346.4e5b736e.js"><link rel="prefetch" href="/assets/js/347.30887da4.js"><link rel="prefetch" href="/assets/js/348.e89eebf8.js"><link rel="prefetch" href="/assets/js/349.ced465b2.js"><link rel="prefetch" href="/assets/js/35.0a7b7db7.js"><link rel="prefetch" href="/assets/js/350.54d82811.js"><link rel="prefetch" href="/assets/js/351.22c50fcc.js"><link rel="prefetch" href="/assets/js/352.9d30e57b.js"><link rel="prefetch" href="/assets/js/353.967b32bd.js"><link rel="prefetch" href="/assets/js/354.12fe5a6a.js"><link rel="prefetch" href="/assets/js/355.25ee5cda.js"><link rel="prefetch" href="/assets/js/356.01e8a40d.js"><link rel="prefetch" href="/assets/js/357.f8ae50b2.js"><link rel="prefetch" href="/assets/js/358.6f44cb1e.js"><link rel="prefetch" href="/assets/js/359.d2a8e208.js"><link rel="prefetch" href="/assets/js/36.8a8c44ca.js"><link rel="prefetch" href="/assets/js/360.1520ffcf.js"><link rel="prefetch" href="/assets/js/361.7c7f3d7b.js"><link rel="prefetch" href="/assets/js/362.3a08870e.js"><link rel="prefetch" href="/assets/js/363.f3e25c62.js"><link rel="prefetch" href="/assets/js/364.32b3c5a8.js"><link rel="prefetch" href="/assets/js/365.aeb08354.js"><link rel="prefetch" href="/assets/js/366.72517ac0.js"><link rel="prefetch" href="/assets/js/367.18b3b8f7.js"><link rel="prefetch" href="/assets/js/368.ec2a91f3.js"><link rel="prefetch" href="/assets/js/369.d6de0392.js"><link rel="prefetch" href="/assets/js/37.7ed1a8d1.js"><link rel="prefetch" href="/assets/js/370.ebfed179.js"><link rel="prefetch" href="/assets/js/371.5616eccf.js"><link rel="prefetch" href="/assets/js/372.a03558dc.js"><link rel="prefetch" href="/assets/js/373.5d45c61b.js"><link rel="prefetch" href="/assets/js/374.39b69121.js"><link rel="prefetch" href="/assets/js/375.7d7c64d7.js"><link rel="prefetch" href="/assets/js/376.7881cfc3.js"><link rel="prefetch" href="/assets/js/377.af9de350.js"><link rel="prefetch" href="/assets/js/378.1a1e8821.js"><link rel="prefetch" href="/assets/js/379.116b3170.js"><link rel="prefetch" href="/assets/js/38.8d2f9b02.js"><link rel="prefetch" href="/assets/js/380.370a093f.js"><link rel="prefetch" href="/assets/js/381.f37830ca.js"><link rel="prefetch" href="/assets/js/382.ab0212ff.js"><link rel="prefetch" href="/assets/js/383.25f8d756.js"><link rel="prefetch" href="/assets/js/384.97136bbd.js"><link rel="prefetch" href="/assets/js/385.498a0b96.js"><link rel="prefetch" href="/assets/js/386.3b60e408.js"><link rel="prefetch" href="/assets/js/387.9ba695cb.js"><link rel="prefetch" href="/assets/js/388.04a18c82.js"><link rel="prefetch" href="/assets/js/389.9ad76e17.js"><link rel="prefetch" href="/assets/js/39.977e55a2.js"><link rel="prefetch" href="/assets/js/390.914db4ab.js"><link rel="prefetch" href="/assets/js/391.f95a2c3c.js"><link rel="prefetch" href="/assets/js/392.c6e77723.js"><link rel="prefetch" href="/assets/js/393.0b442456.js"><link rel="prefetch" href="/assets/js/394.376eb224.js"><link rel="prefetch" href="/assets/js/395.f90c5b4c.js"><link rel="prefetch" href="/assets/js/396.50d8d5c4.js"><link rel="prefetch" href="/assets/js/397.6184ad09.js"><link rel="prefetch" href="/assets/js/398.965e0e4c.js"><link rel="prefetch" href="/assets/js/399.79ebc172.js"><link rel="prefetch" href="/assets/js/4.91d854a1.js"><link rel="prefetch" href="/assets/js/40.6f6fb483.js"><link rel="prefetch" href="/assets/js/400.34747ce2.js"><link rel="prefetch" href="/assets/js/401.c658fdf1.js"><link rel="prefetch" href="/assets/js/402.3e9a16e5.js"><link rel="prefetch" href="/assets/js/403.ba8ea8ab.js"><link rel="prefetch" href="/assets/js/404.906ae695.js"><link rel="prefetch" href="/assets/js/405.a071166e.js"><link rel="prefetch" href="/assets/js/406.ff33839d.js"><link rel="prefetch" href="/assets/js/407.865547ac.js"><link rel="prefetch" href="/assets/js/408.b6ab44a1.js"><link rel="prefetch" href="/assets/js/409.7d5b623b.js"><link rel="prefetch" href="/assets/js/41.f1dd1831.js"><link rel="prefetch" href="/assets/js/410.ecfdb8f1.js"><link rel="prefetch" href="/assets/js/411.bd2dbd0e.js"><link rel="prefetch" href="/assets/js/412.c66dd7de.js"><link rel="prefetch" href="/assets/js/413.dae89178.js"><link rel="prefetch" href="/assets/js/414.a440ee72.js"><link rel="prefetch" href="/assets/js/415.cc0002eb.js"><link rel="prefetch" href="/assets/js/416.3858a741.js"><link rel="prefetch" href="/assets/js/417.2166d5e6.js"><link rel="prefetch" href="/assets/js/418.88a5c742.js"><link rel="prefetch" href="/assets/js/419.ec38cce5.js"><link rel="prefetch" href="/assets/js/42.6727d6a6.js"><link rel="prefetch" href="/assets/js/420.baa3fb6b.js"><link rel="prefetch" href="/assets/js/421.b47f6537.js"><link rel="prefetch" href="/assets/js/422.8682c776.js"><link rel="prefetch" href="/assets/js/423.7090348c.js"><link rel="prefetch" href="/assets/js/424.5a36d297.js"><link rel="prefetch" href="/assets/js/425.d69cc603.js"><link rel="prefetch" href="/assets/js/426.0650311e.js"><link rel="prefetch" href="/assets/js/427.e532cec9.js"><link rel="prefetch" href="/assets/js/428.d7e5abc5.js"><link rel="prefetch" href="/assets/js/429.15e50e04.js"><link rel="prefetch" href="/assets/js/43.6b1d84bc.js"><link rel="prefetch" href="/assets/js/430.8aef2b31.js"><link rel="prefetch" href="/assets/js/431.cd3c2525.js"><link rel="prefetch" href="/assets/js/432.9b56bf1b.js"><link rel="prefetch" href="/assets/js/433.82470875.js"><link rel="prefetch" href="/assets/js/434.175df5a2.js"><link rel="prefetch" href="/assets/js/435.ef84b041.js"><link rel="prefetch" href="/assets/js/436.275cc028.js"><link rel="prefetch" href="/assets/js/437.681033bd.js"><link rel="prefetch" href="/assets/js/438.8c26bd38.js"><link rel="prefetch" href="/assets/js/439.4326cfc7.js"><link rel="prefetch" href="/assets/js/44.7bf207c6.js"><link rel="prefetch" href="/assets/js/440.abad0c5e.js"><link rel="prefetch" href="/assets/js/441.cbda2cfa.js"><link rel="prefetch" href="/assets/js/442.e42f442c.js"><link rel="prefetch" href="/assets/js/443.1fe1d886.js"><link rel="prefetch" href="/assets/js/444.7c71aab4.js"><link rel="prefetch" href="/assets/js/445.291ae37c.js"><link rel="prefetch" href="/assets/js/446.6c9682e4.js"><link rel="prefetch" href="/assets/js/447.594935b8.js"><link rel="prefetch" href="/assets/js/448.dbb8091e.js"><link rel="prefetch" href="/assets/js/449.b217eb50.js"><link rel="prefetch" href="/assets/js/45.3161e71b.js"><link rel="prefetch" href="/assets/js/450.fa92501a.js"><link rel="prefetch" href="/assets/js/451.2d8b4eee.js"><link rel="prefetch" href="/assets/js/452.c98d7422.js"><link rel="prefetch" href="/assets/js/453.04694e2d.js"><link rel="prefetch" href="/assets/js/454.cec8a98b.js"><link rel="prefetch" href="/assets/js/455.579f855d.js"><link rel="prefetch" href="/assets/js/456.a7c30066.js"><link rel="prefetch" href="/assets/js/457.43ed31da.js"><link rel="prefetch" href="/assets/js/458.f794f0a1.js"><link rel="prefetch" href="/assets/js/459.68d942de.js"><link rel="prefetch" href="/assets/js/46.0681e191.js"><link rel="prefetch" href="/assets/js/460.83cbad4c.js"><link rel="prefetch" href="/assets/js/461.b9746da9.js"><link rel="prefetch" href="/assets/js/462.899c56a4.js"><link rel="prefetch" href="/assets/js/463.68dcef9a.js"><link rel="prefetch" href="/assets/js/464.6e2036cb.js"><link rel="prefetch" href="/assets/js/465.f8dcd141.js"><link rel="prefetch" href="/assets/js/466.f56b92ba.js"><link rel="prefetch" href="/assets/js/467.6cb0e836.js"><link rel="prefetch" href="/assets/js/468.54b36b5c.js"><link rel="prefetch" href="/assets/js/469.22584acc.js"><link rel="prefetch" href="/assets/js/47.ee804674.js"><link rel="prefetch" href="/assets/js/470.6b1341a6.js"><link rel="prefetch" href="/assets/js/471.f118f37c.js"><link rel="prefetch" href="/assets/js/472.c14c7cff.js"><link rel="prefetch" href="/assets/js/473.2eced5ff.js"><link rel="prefetch" href="/assets/js/474.e862dd2c.js"><link rel="prefetch" href="/assets/js/475.d20d7571.js"><link rel="prefetch" href="/assets/js/476.6d6eb5c1.js"><link rel="prefetch" href="/assets/js/477.462c863b.js"><link rel="prefetch" href="/assets/js/478.5966d63a.js"><link rel="prefetch" href="/assets/js/479.1d61143e.js"><link rel="prefetch" href="/assets/js/48.dd5f7791.js"><link rel="prefetch" href="/assets/js/480.5c7d31af.js"><link rel="prefetch" href="/assets/js/481.339bb6ba.js"><link rel="prefetch" href="/assets/js/482.6a49b82c.js"><link rel="prefetch" href="/assets/js/483.cafa61f9.js"><link rel="prefetch" href="/assets/js/484.7a0c6929.js"><link rel="prefetch" href="/assets/js/485.2738a461.js"><link rel="prefetch" href="/assets/js/486.d1d63c62.js"><link rel="prefetch" href="/assets/js/487.4fa0483e.js"><link rel="prefetch" href="/assets/js/488.f999466f.js"><link rel="prefetch" href="/assets/js/489.74a36cb0.js"><link rel="prefetch" href="/assets/js/49.a22d6593.js"><link rel="prefetch" href="/assets/js/490.99a914b7.js"><link rel="prefetch" href="/assets/js/491.ccc50bb1.js"><link rel="prefetch" href="/assets/js/492.d8b7440e.js"><link rel="prefetch" href="/assets/js/493.71668939.js"><link rel="prefetch" href="/assets/js/494.7a34704e.js"><link rel="prefetch" href="/assets/js/495.aff82e82.js"><link rel="prefetch" href="/assets/js/496.0a14cd27.js"><link rel="prefetch" href="/assets/js/497.f5238133.js"><link rel="prefetch" href="/assets/js/498.3af5de99.js"><link rel="prefetch" href="/assets/js/499.6b1c93c2.js"><link rel="prefetch" href="/assets/js/5.5a730a22.js"><link rel="prefetch" href="/assets/js/50.f860099b.js"><link rel="prefetch" href="/assets/js/500.7473b06d.js"><link rel="prefetch" href="/assets/js/501.c4bccddf.js"><link rel="prefetch" href="/assets/js/502.5b8c3f06.js"><link rel="prefetch" href="/assets/js/503.b8f7bf0d.js"><link rel="prefetch" href="/assets/js/504.696bf6d4.js"><link rel="prefetch" href="/assets/js/505.5088c7bd.js"><link rel="prefetch" href="/assets/js/506.16a8ac89.js"><link rel="prefetch" href="/assets/js/507.b5c982b2.js"><link rel="prefetch" href="/assets/js/508.b6c5d31f.js"><link rel="prefetch" href="/assets/js/509.2a5e0126.js"><link rel="prefetch" href="/assets/js/51.e25bd41b.js"><link rel="prefetch" href="/assets/js/510.1b65a001.js"><link rel="prefetch" href="/assets/js/511.5044385e.js"><link rel="prefetch" href="/assets/js/512.3c3fdeed.js"><link rel="prefetch" href="/assets/js/513.f17f3f85.js"><link rel="prefetch" href="/assets/js/514.e59ac7a8.js"><link rel="prefetch" href="/assets/js/515.29ec0271.js"><link rel="prefetch" href="/assets/js/516.560e42ba.js"><link rel="prefetch" href="/assets/js/517.538a1d17.js"><link rel="prefetch" href="/assets/js/518.056afb54.js"><link rel="prefetch" href="/assets/js/519.553a3c8e.js"><link rel="prefetch" href="/assets/js/52.b3ba6c43.js"><link rel="prefetch" href="/assets/js/520.cd11b0f8.js"><link rel="prefetch" href="/assets/js/521.255c38b2.js"><link rel="prefetch" href="/assets/js/522.dbe96b70.js"><link rel="prefetch" href="/assets/js/523.8e5b5e18.js"><link rel="prefetch" href="/assets/js/524.861f5e2c.js"><link rel="prefetch" href="/assets/js/525.7a628e20.js"><link rel="prefetch" href="/assets/js/526.0a240bb1.js"><link rel="prefetch" href="/assets/js/527.bc44252a.js"><link rel="prefetch" href="/assets/js/528.51a7cb30.js"><link rel="prefetch" href="/assets/js/529.e6762c93.js"><link rel="prefetch" href="/assets/js/53.a994810f.js"><link rel="prefetch" href="/assets/js/530.12121596.js"><link rel="prefetch" href="/assets/js/531.732ca969.js"><link rel="prefetch" href="/assets/js/532.c383afe0.js"><link rel="prefetch" href="/assets/js/533.27009326.js"><link rel="prefetch" href="/assets/js/534.8fd97962.js"><link rel="prefetch" href="/assets/js/535.c49833b4.js"><link rel="prefetch" href="/assets/js/536.34b112ad.js"><link rel="prefetch" href="/assets/js/537.a418aaf5.js"><link rel="prefetch" href="/assets/js/538.d1e977c1.js"><link rel="prefetch" href="/assets/js/539.3585b5c1.js"><link rel="prefetch" href="/assets/js/54.1ec48dc5.js"><link rel="prefetch" href="/assets/js/540.80fc4611.js"><link rel="prefetch" href="/assets/js/541.38caa7c0.js"><link rel="prefetch" href="/assets/js/542.a82d8253.js"><link rel="prefetch" href="/assets/js/543.8f099428.js"><link rel="prefetch" href="/assets/js/544.41ab9212.js"><link rel="prefetch" href="/assets/js/545.345ae885.js"><link rel="prefetch" href="/assets/js/546.5433479f.js"><link rel="prefetch" href="/assets/js/547.1c1c2f1f.js"><link rel="prefetch" href="/assets/js/548.48a49205.js"><link rel="prefetch" href="/assets/js/549.c555576e.js"><link rel="prefetch" href="/assets/js/55.ba5908aa.js"><link rel="prefetch" href="/assets/js/550.48fa63e2.js"><link rel="prefetch" href="/assets/js/551.95fc12ad.js"><link rel="prefetch" href="/assets/js/552.5f0a8a1a.js"><link rel="prefetch" href="/assets/js/553.ecc73e37.js"><link rel="prefetch" href="/assets/js/554.17b88955.js"><link rel="prefetch" href="/assets/js/555.04d2a121.js"><link rel="prefetch" href="/assets/js/556.546c8322.js"><link rel="prefetch" href="/assets/js/557.84464789.js"><link rel="prefetch" href="/assets/js/558.99c701bf.js"><link rel="prefetch" href="/assets/js/559.4b6e99c0.js"><link rel="prefetch" href="/assets/js/56.fcf66dfb.js"><link rel="prefetch" href="/assets/js/560.cf769a23.js"><link rel="prefetch" href="/assets/js/561.7cf13ba6.js"><link rel="prefetch" href="/assets/js/562.88f1ab27.js"><link rel="prefetch" href="/assets/js/563.f5f8aaf4.js"><link rel="prefetch" href="/assets/js/564.894fc9ba.js"><link rel="prefetch" href="/assets/js/565.749cb379.js"><link rel="prefetch" href="/assets/js/566.4d0c2085.js"><link rel="prefetch" href="/assets/js/567.9337af2a.js"><link rel="prefetch" href="/assets/js/568.067e7dd1.js"><link rel="prefetch" href="/assets/js/569.cf6824da.js"><link rel="prefetch" href="/assets/js/57.47a3d63c.js"><link rel="prefetch" href="/assets/js/570.4d8757e7.js"><link rel="prefetch" href="/assets/js/571.6ed8716a.js"><link rel="prefetch" href="/assets/js/572.1a0bd6f4.js"><link rel="prefetch" href="/assets/js/573.8a19ef48.js"><link rel="prefetch" href="/assets/js/574.014c619f.js"><link rel="prefetch" href="/assets/js/575.ca1221fb.js"><link rel="prefetch" href="/assets/js/576.e51950a4.js"><link rel="prefetch" href="/assets/js/577.577165ae.js"><link rel="prefetch" href="/assets/js/578.6ebef582.js"><link rel="prefetch" href="/assets/js/579.f41f98b0.js"><link rel="prefetch" href="/assets/js/58.e3e74c9a.js"><link rel="prefetch" href="/assets/js/580.1271db2e.js"><link rel="prefetch" href="/assets/js/581.efeef161.js"><link rel="prefetch" href="/assets/js/582.ca878c09.js"><link rel="prefetch" href="/assets/js/583.c41b6a33.js"><link rel="prefetch" href="/assets/js/584.59806fbd.js"><link rel="prefetch" href="/assets/js/585.05a422e8.js"><link rel="prefetch" href="/assets/js/586.d17af92c.js"><link rel="prefetch" href="/assets/js/587.038d345c.js"><link rel="prefetch" href="/assets/js/588.697644f8.js"><link rel="prefetch" href="/assets/js/589.6f03bb77.js"><link rel="prefetch" href="/assets/js/59.bc479ead.js"><link rel="prefetch" href="/assets/js/590.65ae38e8.js"><link rel="prefetch" href="/assets/js/591.13d806d8.js"><link rel="prefetch" href="/assets/js/592.4a380fde.js"><link rel="prefetch" href="/assets/js/593.95706dec.js"><link rel="prefetch" href="/assets/js/594.487a07ec.js"><link rel="prefetch" href="/assets/js/595.b09ebed5.js"><link rel="prefetch" href="/assets/js/596.9f3d4c37.js"><link rel="prefetch" href="/assets/js/597.24a28c60.js"><link rel="prefetch" href="/assets/js/598.dea2f060.js"><link rel="prefetch" href="/assets/js/599.881f3080.js"><link rel="prefetch" href="/assets/js/6.d05ff7d1.js"><link rel="prefetch" href="/assets/js/60.538f7a8f.js"><link rel="prefetch" href="/assets/js/600.a1df3d21.js"><link rel="prefetch" href="/assets/js/601.8f86ab54.js"><link rel="prefetch" href="/assets/js/602.cbb98cef.js"><link rel="prefetch" href="/assets/js/603.f69ad197.js"><link rel="prefetch" href="/assets/js/604.ed947213.js"><link rel="prefetch" href="/assets/js/605.5d4408fa.js"><link rel="prefetch" href="/assets/js/606.1303dab1.js"><link rel="prefetch" href="/assets/js/607.651c81d7.js"><link rel="prefetch" href="/assets/js/608.5f805112.js"><link rel="prefetch" href="/assets/js/609.c9a567f6.js"><link rel="prefetch" href="/assets/js/61.cc65190a.js"><link rel="prefetch" href="/assets/js/610.b2a8426e.js"><link rel="prefetch" href="/assets/js/611.722ff656.js"><link rel="prefetch" href="/assets/js/612.d876f095.js"><link rel="prefetch" href="/assets/js/613.a353bf79.js"><link rel="prefetch" href="/assets/js/614.fa0b03dc.js"><link rel="prefetch" href="/assets/js/615.44df5525.js"><link rel="prefetch" href="/assets/js/616.8bb42251.js"><link rel="prefetch" href="/assets/js/617.1550fe9f.js"><link rel="prefetch" href="/assets/js/618.1247b611.js"><link rel="prefetch" href="/assets/js/619.8809b2ae.js"><link rel="prefetch" href="/assets/js/62.4ae1f431.js"><link rel="prefetch" href="/assets/js/620.cc4a3af3.js"><link rel="prefetch" href="/assets/js/621.414d1d68.js"><link rel="prefetch" href="/assets/js/622.dbcbfb64.js"><link rel="prefetch" href="/assets/js/623.48dc89ee.js"><link rel="prefetch" href="/assets/js/624.25c47110.js"><link rel="prefetch" href="/assets/js/625.ce0558b1.js"><link rel="prefetch" href="/assets/js/626.96dd94a0.js"><link rel="prefetch" href="/assets/js/627.d3854e8d.js"><link rel="prefetch" href="/assets/js/628.a3a5e2db.js"><link rel="prefetch" href="/assets/js/629.d2f08abf.js"><link rel="prefetch" href="/assets/js/63.49f2bbdc.js"><link rel="prefetch" href="/assets/js/630.b5600d09.js"><link rel="prefetch" href="/assets/js/631.ff9db242.js"><link rel="prefetch" href="/assets/js/632.d1647587.js"><link rel="prefetch" href="/assets/js/633.cea277e2.js"><link rel="prefetch" href="/assets/js/634.122af75b.js"><link rel="prefetch" href="/assets/js/635.7bea6d49.js"><link rel="prefetch" href="/assets/js/636.2d71947d.js"><link rel="prefetch" href="/assets/js/637.95ea8ecc.js"><link rel="prefetch" href="/assets/js/638.1e88f87f.js"><link rel="prefetch" href="/assets/js/639.08a794e6.js"><link rel="prefetch" href="/assets/js/64.2ce1d588.js"><link rel="prefetch" href="/assets/js/640.83817a84.js"><link rel="prefetch" href="/assets/js/641.8e0801d8.js"><link rel="prefetch" href="/assets/js/642.f1d5e10b.js"><link rel="prefetch" href="/assets/js/643.178e53f8.js"><link rel="prefetch" href="/assets/js/644.1de498c2.js"><link rel="prefetch" href="/assets/js/645.c3a019f8.js"><link rel="prefetch" href="/assets/js/646.9c393f2b.js"><link rel="prefetch" href="/assets/js/65.a5f22217.js"><link rel="prefetch" href="/assets/js/66.40ee9425.js"><link rel="prefetch" href="/assets/js/67.481ed7c8.js"><link rel="prefetch" href="/assets/js/68.74ca9240.js"><link rel="prefetch" href="/assets/js/69.7643a0cf.js"><link rel="prefetch" href="/assets/js/7.63385f53.js"><link rel="prefetch" href="/assets/js/70.9becc575.js"><link rel="prefetch" href="/assets/js/71.b0903874.js"><link rel="prefetch" href="/assets/js/72.6e7b692c.js"><link rel="prefetch" href="/assets/js/73.e67fabef.js"><link rel="prefetch" href="/assets/js/74.4c8c1379.js"><link rel="prefetch" href="/assets/js/75.7149308e.js"><link rel="prefetch" href="/assets/js/76.e0ce4016.js"><link rel="prefetch" href="/assets/js/77.c31105bc.js"><link rel="prefetch" href="/assets/js/78.73d3cfa1.js"><link rel="prefetch" href="/assets/js/79.4b3118ff.js"><link rel="prefetch" href="/assets/js/8.8908ac1d.js"><link rel="prefetch" href="/assets/js/80.8e295801.js"><link rel="prefetch" href="/assets/js/81.8ceca8c2.js"><link rel="prefetch" href="/assets/js/82.c871eba9.js"><link rel="prefetch" href="/assets/js/83.9683fd81.js"><link rel="prefetch" href="/assets/js/84.13d07b6b.js"><link rel="prefetch" href="/assets/js/85.3779601c.js"><link rel="prefetch" href="/assets/js/86.f64f6205.js"><link rel="prefetch" href="/assets/js/87.0260cfef.js"><link rel="prefetch" href="/assets/js/88.247a84f5.js"><link rel="prefetch" href="/assets/js/89.36161880.js"><link rel="prefetch" href="/assets/js/9.21757d31.js"><link rel="prefetch" href="/assets/js/90.20240bfa.js"><link rel="prefetch" href="/assets/js/91.2b3836a2.js"><link rel="prefetch" href="/assets/js/92.f744276b.js"><link rel="prefetch" href="/assets/js/93.0c552d4a.js"><link rel="prefetch" href="/assets/js/94.515113cf.js"><link rel="prefetch" href="/assets/js/95.ff6049bd.js"><link rel="prefetch" href="/assets/js/96.3b33cb4c.js"><link rel="prefetch" href="/assets/js/97.ff049c6f.js"><link rel="prefetch" href="/assets/js/98.078707ee.js"><link rel="prefetch" href="/assets/js/99.7a0ece60.js"><link rel="prefetch" href="/assets/js/vendors~docsearch.ac6383e3.js">
    <link rel="stylesheet" href="/assets/css/0.styles.f7fca28c.css">
  </head>
  <body>
    <div id="app" data-server-rendered="true"><div class="theme-container"><header class="navbar"><div class="sidebar-button"><svg xmlns="http://www.w3.org/2000/svg" aria-hidden="true" role="img" viewBox="0 0 448 512" class="icon"><path fill="currentColor" d="M436 124H12c-6.627 0-12-5.373-12-12V80c0-6.627 5.373-12 12-12h424c6.627 0 12 5.373 12 12v32c0 6.627-5.373 12-12 12zm0 160H12c-6.627 0-12-5.373-12-12v-32c0-6.627 5.373-12 12-12h424c6.627 0 12 5.373 12 12v32c0 6.627-5.373 12-12 12zm0 160H12c-6.627 0-12-5.373-12-12v-32c0-6.627 5.373-12 12-12h424c6.627 0 12 5.373 12 12v32c0 6.627-5.373 12-12 12z"></path></svg></div> <a href="/" class="home-link router-link-active"><img src="/img/logo.png" alt=" " class="logo"></a> <div class="links"><div class="search-box"><input aria-label="Search" autocomplete="off" spellcheck="false" value=""> <!----></div> <nav class="nav-links can-hide"><div class="nav-item"><div class="dropdown-wrapper"><a class="dropdown-title"><span class="title">Document</span> <span class="arrow right"></span></a> <ul class="nav-dropdown" style="display:none;"><li class="dropdown-item"><!----> <a href="/UserGuide/Master/QuickStart/QuickStart.html" class="nav-link">In progress</a></li><li class="dropdown-item"><!----> <a href="/UserGuide/V0.12.x/QuickStart/QuickStart.html" class="nav-link">V0.12.x</a></li><li class="dropdown-item"><!----> <a href="/UserGuide/V0.11.x/Get Started/QuickStart.html" class="nav-link">V0.11.x</a></li><li class="dropdown-item"><!----> <a href="/UserGuide/V0.10.x/Get Started/QuickStart.html" class="nav-link">V0.10.x</a></li><li class="dropdown-item"><!----> <a href="/UserGuide/V0.9.x/0-Get Started/1-QuickStart.html" class="nav-link">V0.9.x</a></li><li class="dropdown-item"><!----> <a href="/UserGuide/V0.8.x/0-Get Started/1-QuickStart.html" class="nav-link">V0.8.x</a></li></ul></div></div><div class="nav-item"><a href="/SystemDesign/Architecture/Architecture.html" class="nav-link">System design</a></div><div class="nav-item"><a href="/Download/" class="nav-link">Download</a></div><div class="nav-item"><div class="dropdown-wrapper"><a class="dropdown-title"><span class="title">Community</span> <span class="arrow right"></span></a> <ul class="nav-dropdown" style="display:none;"><li class="dropdown-item"><!----> <a href="https://cwiki.apache.org/confluence/display/iotdb" class="nav-link external">
  Wiki
  <!----></a></li><li class="dropdown-item"><!----> <a href="/Community/Community-Project Committers.html" class="nav-link">People</a></li><li class="dropdown-item"><!----> <a href="/Community/Community-Powered By.html" class="nav-link">Powered By</a></li><li class="dropdown-item"><!----> <a href="/Community/Materials.html" class="nav-link">Resources</a></li><li class="dropdown-item"><!----> <a href="/Community/Feedback.html" class="nav-link">Feedback</a></li></ul></div></div><div class="nav-item"><div class="dropdown-wrapper"><a class="dropdown-title"><span class="title">Development</span> <span class="arrow right"></span></a> <ul class="nav-dropdown" style="display:none;"><li class="dropdown-item"><!----> <a href="/Development/VoteRelease.html" class="nav-link">How to vote</a></li><li class="dropdown-item"><!----> <a href="/Development/HowToCommit.html" class="nav-link">How to Commit</a></li><li class="dropdown-item"><!----> <a href="/Development/Committer.html" class="nav-link">Become a Committer</a></li><li class="dropdown-item"><!----> <a href="/Development/ContributeGuide.html" class="nav-link">ContributeGuide</a></li><li class="dropdown-item"><!----> <a href="/Development/format-changelist.html" class="nav-link">Changelist of TsFile</a></li><li class="dropdown-item"><!----> <a href="/Development/rpc-changelist.html" class="nav-link">Changelist of RPC</a></li></ul></div></div><div class="nav-item"><div class="dropdown-wrapper"><a class="dropdown-title"><span class="title">Blog</span> <span class="arrow right"></span></a> <ul class="nav-dropdown" style="display:none;"><li class="dropdown-item"><!----> <a href="/Blog/Index.html" class="nav-link">Overview</a></li><li class="dropdown-item"><!----> <a href="/Blog/Release0_93.html" class="nav-link">Some Notes on Release 0.9.3 and upcoming 0.10.0</a></li></ul></div></div><div class="nav-item"><div class="dropdown-wrapper"><a class="dropdown-title"><span class="title">ASF</span> <span class="arrow right"></span></a> <ul class="nav-dropdown" style="display:none;"><li class="dropdown-item"><!----> <a href="http://www.apache.org/" class="nav-link external">
  Foundation
  <!----></a></li><li class="dropdown-item"><!----> <a href="http://www.apache.org/licenses/" class="nav-link external">
  License
  <!----></a></li><li class="dropdown-item"><!----> <a href="http://www.apache.org/security/" class="nav-link external">
  Security
  <!----></a></li><li class="dropdown-item"><!----> <a href="http://www.apache.org/foundation/sponsorship.html" class="nav-link external">
  Sponsorship
  <!----></a></li><li class="dropdown-item"><!----> <a href="http://www.apache.org/foundation/thanks.html" class="nav-link external">
  Thanks
  <!----></a></li><li class="dropdown-item"><!----> <a href="http://www.apache.org/events/current-event" class="nav-link external">
  Current Events
  <!----></a></li></ul></div></div><div class="nav-item"><div class="dropdown-wrapper"><a class="dropdown-title"><span class="title">Languages</span> <span class="arrow right"></span></a> <ul class="nav-dropdown" style="display:none;"><li class="dropdown-item"><!----> <a href="/UserGuide/V0.12.x/IoTDB-SQL-Language/DML-Data-Manipulation-Language.html" aria-current="page" class="nav-link router-link-exact-active router-link-active">English</a></li><li class="dropdown-item"><!----> <a href="/zh/UserGuide/V0.12.x/IoTDB-SQL-Language/DML-Data-Manipulation-Language.html" class="nav-link">简体中文</a></li></ul></div></div> <a href="https://github.com/apache/iotdb.git" target="_blank" rel="noopener noreferrer" class="repo-link">
    gitHub
    <span><svg xmlns="http://www.w3.org/2000/svg" aria-hidden="true" focusable="false" x="0px" y="0px" viewBox="0 0 100 100" width="15" height="15" class="icon outbound"><path fill="currentColor" d="M18.8,85.1h56l0,0c2.2,0,4-1.8,4-4v-32h-8v28h-48v-48h28v-8h-32l0,0c-2.2,0-4,1.8-4,4v56C14.8,83.3,16.6,85.1,18.8,85.1z"></path> <polygon fill="currentColor" points="45.7,48.7 51.3,54.3 77.2,28.5 77.2,37.2 85.2,37.2 85.2,14.9 62.8,14.9 62.8,22.9 71.5,22.9"></polygon></svg> <span class="sr-only">(opens new window)</span></span></a></nav></div></header> <div class="sidebar-mask"></div> <aside class="sidebar"><nav class="nav-links"><div class="nav-item"><div class="dropdown-wrapper"><a class="dropdown-title"><span class="title">Document</span> <span class="arrow right"></span></a> <ul class="nav-dropdown" style="display:none;"><li class="dropdown-item"><!----> <a href="/UserGuide/Master/QuickStart/QuickStart.html" class="nav-link">In progress</a></li><li class="dropdown-item"><!----> <a href="/UserGuide/V0.12.x/QuickStart/QuickStart.html" class="nav-link">V0.12.x</a></li><li class="dropdown-item"><!----> <a href="/UserGuide/V0.11.x/Get Started/QuickStart.html" class="nav-link">V0.11.x</a></li><li class="dropdown-item"><!----> <a href="/UserGuide/V0.10.x/Get Started/QuickStart.html" class="nav-link">V0.10.x</a></li><li class="dropdown-item"><!----> <a href="/UserGuide/V0.9.x/0-Get Started/1-QuickStart.html" class="nav-link">V0.9.x</a></li><li class="dropdown-item"><!----> <a href="/UserGuide/V0.8.x/0-Get Started/1-QuickStart.html" class="nav-link">V0.8.x</a></li></ul></div></div><div class="nav-item"><a href="/SystemDesign/Architecture/Architecture.html" class="nav-link">System design</a></div><div class="nav-item"><a href="/Download/" class="nav-link">Download</a></div><div class="nav-item"><div class="dropdown-wrapper"><a class="dropdown-title"><span class="title">Community</span> <span class="arrow right"></span></a> <ul class="nav-dropdown" style="display:none;"><li class="dropdown-item"><!----> <a href="https://cwiki.apache.org/confluence/display/iotdb" class="nav-link external">
  Wiki
  <!----></a></li><li class="dropdown-item"><!----> <a href="/Community/Community-Project Committers.html" class="nav-link">People</a></li><li class="dropdown-item"><!----> <a href="/Community/Community-Powered By.html" class="nav-link">Powered By</a></li><li class="dropdown-item"><!----> <a href="/Community/Materials.html" class="nav-link">Resources</a></li><li class="dropdown-item"><!----> <a href="/Community/Feedback.html" class="nav-link">Feedback</a></li></ul></div></div><div class="nav-item"><div class="dropdown-wrapper"><a class="dropdown-title"><span class="title">Development</span> <span class="arrow right"></span></a> <ul class="nav-dropdown" style="display:none;"><li class="dropdown-item"><!----> <a href="/Development/VoteRelease.html" class="nav-link">How to vote</a></li><li class="dropdown-item"><!----> <a href="/Development/HowToCommit.html" class="nav-link">How to Commit</a></li><li class="dropdown-item"><!----> <a href="/Development/Committer.html" class="nav-link">Become a Committer</a></li><li class="dropdown-item"><!----> <a href="/Development/ContributeGuide.html" class="nav-link">ContributeGuide</a></li><li class="dropdown-item"><!----> <a href="/Development/format-changelist.html" class="nav-link">Changelist of TsFile</a></li><li class="dropdown-item"><!----> <a href="/Development/rpc-changelist.html" class="nav-link">Changelist of RPC</a></li></ul></div></div><div class="nav-item"><div class="dropdown-wrapper"><a class="dropdown-title"><span class="title">Blog</span> <span class="arrow right"></span></a> <ul class="nav-dropdown" style="display:none;"><li class="dropdown-item"><!----> <a href="/Blog/Index.html" class="nav-link">Overview</a></li><li class="dropdown-item"><!----> <a href="/Blog/Release0_93.html" class="nav-link">Some Notes on Release 0.9.3 and upcoming 0.10.0</a></li></ul></div></div><div class="nav-item"><div class="dropdown-wrapper"><a class="dropdown-title"><span class="title">ASF</span> <span class="arrow right"></span></a> <ul class="nav-dropdown" style="display:none;"><li class="dropdown-item"><!----> <a href="http://www.apache.org/" class="nav-link external">
  Foundation
  <!----></a></li><li class="dropdown-item"><!----> <a href="http://www.apache.org/licenses/" class="nav-link external">
  License
  <!----></a></li><li class="dropdown-item"><!----> <a href="http://www.apache.org/security/" class="nav-link external">
  Security
  <!----></a></li><li class="dropdown-item"><!----> <a href="http://www.apache.org/foundation/sponsorship.html" class="nav-link external">
  Sponsorship
  <!----></a></li><li class="dropdown-item"><!----> <a href="http://www.apache.org/foundation/thanks.html" class="nav-link external">
  Thanks
  <!----></a></li><li class="dropdown-item"><!----> <a href="http://www.apache.org/events/current-event" class="nav-link external">
  Current Events
  <!----></a></li></ul></div></div><div class="nav-item"><div class="dropdown-wrapper"><a class="dropdown-title"><span class="title">Languages</span> <span class="arrow right"></span></a> <ul class="nav-dropdown" style="display:none;"><li class="dropdown-item"><!----> <a href="/UserGuide/V0.12.x/IoTDB-SQL-Language/DML-Data-Manipulation-Language.html" aria-current="page" class="nav-link router-link-exact-active router-link-active">English</a></li><li class="dropdown-item"><!----> <a href="/zh/UserGuide/V0.12.x/IoTDB-SQL-Language/DML-Data-Manipulation-Language.html" class="nav-link">简体中文</a></li></ul></div></div> <a href="https://github.com/apache/iotdb.git" target="_blank" rel="noopener noreferrer" class="repo-link">
    gitHub
    <span><svg xmlns="http://www.w3.org/2000/svg" aria-hidden="true" focusable="false" x="0px" y="0px" viewBox="0 0 100 100" width="15" height="15" class="icon outbound"><path fill="currentColor" d="M18.8,85.1h56l0,0c2.2,0,4-1.8,4-4v-32h-8v28h-48v-48h28v-8h-32l0,0c-2.2,0-4,1.8-4,4v56C14.8,83.3,16.6,85.1,18.8,85.1z"></path> <polygon fill="currentColor" points="45.7,48.7 51.3,54.3 77.2,28.5 77.2,37.2 85.2,37.2 85.2,14.9 62.8,14.9 62.8,22.9 71.5,22.9"></polygon></svg> <span class="sr-only">(opens new window)</span></span></a></nav>  <ul class="sidebar-links"><li><section class="sidebar-group depth-0"><p class="sidebar-heading"><span>IoTDB User Guide (V0.12.x)</span> <!----></p> <!----></section></li><li><section class="sidebar-group collapsable depth-0"><p class="sidebar-heading"><span>IoTDB Introduction</span> <span class="arrow right"></span></p> <!----></section></li><li><section class="sidebar-group collapsable depth-0"><p class="sidebar-heading"><span>Quick Start</span> <span class="arrow right"></span></p> <!----></section></li><li><section class="sidebar-group collapsable depth-0"><p class="sidebar-heading"><span>Data Concept</span> <span class="arrow right"></span></p> <!----></section></li><li><section class="sidebar-group collapsable depth-0"><p class="sidebar-heading"><span>CLI</span> <span class="arrow right"></span></p> <!----></section></li><li><section class="sidebar-group collapsable depth-0"><p class="sidebar-heading"><span>Administration Management</span> <span class="arrow right"></span></p> <!----></section></li><li><section class="sidebar-group collapsable depth-0"><p class="sidebar-heading open"><span>IoTDB-SQL Language</span> <span class="arrow down"></span></p> <ul class="sidebar-links sidebar-group-items"><li><a href="/UserGuide/V0.12.x/IoTDB-SQL-Language/DDL-Data-Definition-Language.html" class="sidebar-link">DDL (Data Definition Language)</a></li><li><a href="/UserGuide/V0.12.x/IoTDB-SQL-Language/DML-Data-Manipulation-Language.html" aria-current="page" class="active sidebar-link">DML (Data Manipulation Language)</a></li><li><a href="/UserGuide/V0.12.x/IoTDB-SQL-Language/Maintenance-Command.html" class="sidebar-link">Maintenance Command</a></li></ul></section></li><li><section class="sidebar-group collapsable depth-0"><p class="sidebar-heading"><span>API</span> <span class="arrow right"></span></p> <!----></section></li><li><section class="sidebar-group collapsable depth-0"><p class="sidebar-heading"><span>UDF</span> <span class="arrow right"></span></p> <!----></section></li><li><section class="sidebar-group collapsable depth-0"><p class="sidebar-heading"><span>Communication Service Protocol</span> <span class="arrow right"></span></p> <!----></section></li><li><section class="sidebar-group collapsable depth-0"><p class="sidebar-heading"><span>System Tools</span> <span class="arrow right"></span></p> <!----></section></li><li><section class="sidebar-group collapsable depth-0"><p class="sidebar-heading"><span>Collaboration of Edge and Cloud</span> <span class="arrow right"></span></p> <!----></section></li><li><section class="sidebar-group collapsable depth-0"><p class="sidebar-heading"><span>Ecosystem Integration</span> <span class="arrow right"></span></p> <!----></section></li><li><section class="sidebar-group collapsable depth-0"><p class="sidebar-heading"><span>Cluster Setup</span> <span class="arrow right"></span></p> <!----></section></li><li><section class="sidebar-group collapsable depth-0"><p class="sidebar-heading"><span>FAQ</span> <span class="arrow right"></span></p> <!----></section></li><li><section class="sidebar-group collapsable depth-0"><p class="sidebar-heading"><span>Appendix</span> <span class="arrow right"></span></p> <!----></section></li><li><section class="sidebar-group collapsable depth-0"><p class="sidebar-heading"><span>Comparison with TSDBs</span> <span class="arrow right"></span></p> <!----></section></li></ul> </aside> <main class="page"> <div class="content content__default"><h1 id="dml-data-manipulation-language"><a href="#dml-data-manipulation-language" class="header-anchor">#</a> DML (Data Manipulation Language)</h1> <h2 id="insert"><a href="#insert" class="header-anchor">#</a> INSERT</h2> <h3 id="insert-real-time-data"><a href="#insert-real-time-data" class="header-anchor">#</a> Insert Real-time Data</h3> <p>IoTDB provides users with a variety of ways to insert real-time data, such as directly inputting <a href="/UserGuide/V0.12.x/Appendix/SQL-Reference.html">INSERT SQL statement</a> in <a href="/UserGuide/V0.12.x/CLI/Command-Line-Interface.html">Client/Shell tools</a>, or using <a href="/UserGuide/V0.12.x/API/Programming-JDBC.html">Java JDBC</a> to perform single or batch execution of <a href="/UserGuide/V0.12.x/Appendix/SQL-Reference.html">INSERT SQL statement</a>.</p> <p>This section mainly introduces the use of <a href="/UserGuide/V0.12.x/Appendix/SQL-Reference.html">INSERT SQL statement</a> for real-time data import in the scenario.</p> <h4 id="use-of-insert-statements"><a href="#use-of-insert-statements" class="header-anchor">#</a> Use of INSERT Statements</h4> <p>The <a href="/UserGuide/V0.12.x/Appendix/SQL-Reference.html">INSERT SQL statement</a> statement is used to insert data into one or more specified timeseries created. For each point of data inserted, it consists of a <a href="/UserGuide/V0.12.x/Data-Concept/Data-Model-and-Terminology.html">timestamp</a> and a sensor acquisition value (see <a href="/UserGuide/V0.12.x/Data-Concept/Data-Type.html">Data Type</a>).</p> <p>In the scenario of this section, take two timeseries <code>root.ln.wf02.wt02.status</code> and <code>root.ln.wf02.wt02.hardware</code> as an example, and their data types are BOOLEAN and TEXT, respectively.</p> <p>The sample code for single column data insertion is as follows:</p> <div class="language- line-numbers-mode"><pre class="language-text"><code>IoTDB &gt; insert into root.ln.wf02.wt02(timestamp,status) values(1,true)
IoTDB &gt; insert into root.ln.wf02.wt02(timestamp,hardware) values(1, &quot;v1&quot;)
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br><span class="line-number">2</span><br></div></div><p>The above example code inserts the long integer timestamp and the value &quot;true&quot; into the timeseries <code>root.ln.wf02.wt02.status</code> and inserts the long integer timestamp and the value &quot;v1&quot; into the timeseries <code>root.ln.wf02.wt02.hardware</code>. When the execution is successful, cost time is shown to indicate that the data insertion has been completed.</p> <blockquote><p>Note: In IoTDB, TEXT type data can be represented by single and double quotation marks. The insertion statement above uses double quotation marks for TEXT type data. The following example will use single quotation marks for TEXT type data.</p></blockquote> <p>The INSERT statement can also support the insertion of multi-column data at the same time point.  The sample code of  inserting the values of the two timeseries at the same time point '2' is as follows:</p> <div class="language- line-numbers-mode"><pre class="language-text"><code>IoTDB &gt; insert into root.ln.wf02.wt02(timestamp, status, hardware) VALUES (2, false, 'v2')
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br></div></div><p>After inserting the data, we can simply query the inserted data using the SELECT statement:</p> <div class="language- line-numbers-mode"><pre class="language-text"><code>IoTDB &gt; select * from root.ln.wf02 where time &lt; 3
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br></div></div><p>The result is shown below. The query result shows that the insertion statements of single column and multi column data are performed correctly.</p> <div class="language- line-numbers-mode"><pre class="language-text"><code>+-----------------------------+--------------------------+------------------------+
|                         Time|root.ln.wf02.wt02.hardware|root.ln.wf02.wt02.status|
+-----------------------------+--------------------------+------------------------+
|1970-01-01T08:00:00.001+08:00|                        v1|                    true|
|1970-01-01T08:00:00.002+08:00|                        v2|                   false|
+-----------------------------+--------------------------+------------------------+
Total line number = 2
It costs 0.170s
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br><span class="line-number">2</span><br><span class="line-number">3</span><br><span class="line-number">4</span><br><span class="line-number">5</span><br><span class="line-number">6</span><br><span class="line-number">7</span><br><span class="line-number">8</span><br></div></div><h2 id="select"><a href="#select" class="header-anchor">#</a> SELECT</h2> <h3 id="time-slice-query"><a href="#time-slice-query" class="header-anchor">#</a> Time Slice Query</h3> <p>This chapter mainly introduces the relevant examples of time slice query using IoTDB SELECT statements. Detailed SQL syntax and usage specifications can be found in <a href="/UserGuide/V0.12.x/Appendix/SQL-Reference.html">SQL Documentation</a>. You can also use the <a href="/UserGuide/V0.12.x/API/Programming-JDBC.html">Java JDBC</a> standard interface to execute related queries.</p> <h4 id="select-a-column-of-data-based-on-a-time-interval"><a href="#select-a-column-of-data-based-on-a-time-interval" class="header-anchor">#</a> Select a Column of Data Based on a Time Interval</h4> <p>The SQL statement is:</p> <div class="language- line-numbers-mode"><pre class="language-text"><code>select temperature from root.ln.wf01.wt01 where time &lt; 2017-11-01T00:08:00.000
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br></div></div><p>which means:</p> <p>The selected device is ln group wf01 plant wt01 device; the selected timeseries is the temperature sensor (temperature). The SQL statement requires that all temperature sensor values before the time point of &quot;2017-11-01T00:08:00.000&quot; be selected.</p> <p>The execution result of this SQL statement is as follows:</p> <div class="language- line-numbers-mode"><pre class="language-text"><code>+-----------------------------+-----------------------------+
|                         Time|root.ln.wf01.wt01.temperature|
+-----------------------------+-----------------------------+
|2017-11-01T00:00:00.000+08:00|                        25.96|
|2017-11-01T00:01:00.000+08:00|                        24.36|
|2017-11-01T00:02:00.000+08:00|                        20.09|
|2017-11-01T00:03:00.000+08:00|                        20.18|
|2017-11-01T00:04:00.000+08:00|                        21.13|
|2017-11-01T00:05:00.000+08:00|                        22.72|
|2017-11-01T00:06:00.000+08:00|                        20.71|
|2017-11-01T00:07:00.000+08:00|                        21.45|
+-----------------------------+-----------------------------+
Total line number = 8
It costs 0.026s
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br><span class="line-number">2</span><br><span class="line-number">3</span><br><span class="line-number">4</span><br><span class="line-number">5</span><br><span class="line-number">6</span><br><span class="line-number">7</span><br><span class="line-number">8</span><br><span class="line-number">9</span><br><span class="line-number">10</span><br><span class="line-number">11</span><br><span class="line-number">12</span><br><span class="line-number">13</span><br><span class="line-number">14</span><br></div></div><h4 id="select-multiple-columns-of-data-based-on-a-time-interval"><a href="#select-multiple-columns-of-data-based-on-a-time-interval" class="header-anchor">#</a> Select Multiple Columns of Data Based on a Time Interval</h4> <p>The SQL statement is:</p> <div class="language- line-numbers-mode"><pre class="language-text"><code>select status, temperature from root.ln.wf01.wt01 where time &gt; 2017-11-01T00:05:00.000 and time &lt; 2017-11-01T00:12:00.000;
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br></div></div><p>which means:</p> <p>The selected device is ln group wf01 plant wt01 device; the selected timeseries is &quot;status&quot; and &quot;temperature&quot;. The SQL statement requires that the status and temperature sensor values between the time point of &quot;2017-11-01T00:05:00.000&quot; and &quot;2017-11-01T00:12:00.000&quot; be selected.</p> <p>The execution result of this SQL statement is as follows:</p> <div class="language- line-numbers-mode"><pre class="language-text"><code>+-----------------------------+------------------------+-----------------------------+
|                         Time|root.ln.wf01.wt01.status|root.ln.wf01.wt01.temperature|
+-----------------------------+------------------------+-----------------------------+
|2017-11-01T00:06:00.000+08:00|                   false|                        20.71|
|2017-11-01T00:07:00.000+08:00|                   false|                        21.45|
|2017-11-01T00:08:00.000+08:00|                   false|                        22.58|
|2017-11-01T00:09:00.000+08:00|                   false|                        20.98|
|2017-11-01T00:10:00.000+08:00|                    true|                        25.52|
|2017-11-01T00:11:00.000+08:00|                   false|                        22.91|
+-----------------------------+------------------------+-----------------------------+
Total line number = 6
It costs 0.018s
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br><span class="line-number">2</span><br><span class="line-number">3</span><br><span class="line-number">4</span><br><span class="line-number">5</span><br><span class="line-number">6</span><br><span class="line-number">7</span><br><span class="line-number">8</span><br><span class="line-number">9</span><br><span class="line-number">10</span><br><span class="line-number">11</span><br><span class="line-number">12</span><br></div></div><h4 id="select-multiple-columns-of-data-for-the-same-device-according-to-multiple-time-intervals"><a href="#select-multiple-columns-of-data-for-the-same-device-according-to-multiple-time-intervals" class="header-anchor">#</a> Select Multiple Columns of Data for the Same Device According to Multiple Time Intervals</h4> <p>IoTDB supports specifying multiple time interval conditions in a query. Users can combine time interval conditions at will according to their needs. For example, the SQL statement is:</p> <div class="language- line-numbers-mode"><pre class="language-text"><code>select status,temperature from root.ln.wf01.wt01 where (time &gt; 2017-11-01T00:05:00.000 and time &lt; 2017-11-01T00:12:00.000) or (time &gt;= 2017-11-01T16:35:00.000 and time &lt;= 2017-11-01T16:37:00.000);
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br></div></div><p>which means:</p> <p>The selected device is ln group wf01 plant wt01 device; the selected timeseries is &quot;status&quot; and &quot;temperature&quot;; the statement specifies two different time intervals, namely &quot;2017-11-01T00:05:00.000 to 2017-11-01T00:12:00.000&quot; and &quot;2017-11-01T16:35:00.000 to 2017-11-01T16:37:00.000&quot;. The SQL statement requires that the values of selected timeseries satisfying any time interval be selected.</p> <p>The execution result of this SQL statement is as follows:</p> <div class="language- line-numbers-mode"><pre class="language-text"><code>+-----------------------------+------------------------+-----------------------------+
|                         Time|root.ln.wf01.wt01.status|root.ln.wf01.wt01.temperature|
+-----------------------------+------------------------+-----------------------------+
|2017-11-01T00:06:00.000+08:00|                   false|                        20.71|
|2017-11-01T00:07:00.000+08:00|                   false|                        21.45|
|2017-11-01T00:08:00.000+08:00|                   false|                        22.58|
|2017-11-01T00:09:00.000+08:00|                   false|                        20.98|
|2017-11-01T00:10:00.000+08:00|                    true|                        25.52|
|2017-11-01T00:11:00.000+08:00|                   false|                        22.91|
|2017-11-01T16:35:00.000+08:00|                    true|                        23.44|
|2017-11-01T16:36:00.000+08:00|                   false|                        21.98|
|2017-11-01T16:37:00.000+08:00|                   false|                        21.93|
+-----------------------------+------------------------+-----------------------------+
Total line number = 9
It costs 0.018s
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br><span class="line-number">2</span><br><span class="line-number">3</span><br><span class="line-number">4</span><br><span class="line-number">5</span><br><span class="line-number">6</span><br><span class="line-number">7</span><br><span class="line-number">8</span><br><span class="line-number">9</span><br><span class="line-number">10</span><br><span class="line-number">11</span><br><span class="line-number">12</span><br><span class="line-number">13</span><br><span class="line-number">14</span><br><span class="line-number">15</span><br></div></div><h4 id="choose-multiple-columns-of-data-for-different-devices-according-to-multiple-time-intervals"><a href="#choose-multiple-columns-of-data-for-different-devices-according-to-multiple-time-intervals" class="header-anchor">#</a> Choose Multiple Columns of Data for Different Devices According to Multiple Time Intervals</h4> <p>The system supports the selection of data in any column in a query, i.e., the selected columns can come from different devices. For example, the SQL statement is:</p> <div class="language- line-numbers-mode"><pre class="language-text"><code>select wf01.wt01.status,wf02.wt02.hardware from root.ln where (time &gt; 2017-11-01T00:05:00.000 and time &lt; 2017-11-01T00:12:00.000) or (time &gt;= 2017-11-01T16:35:00.000 and time &lt;= 2017-11-01T16:37:00.000);
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br></div></div><p>which means:</p> <p>The selected timeseries are &quot;the power supply status of ln group wf01 plant wt01 device&quot; and &quot;the hardware version of ln group wf02 plant wt02 device&quot;; the statement specifies two different time intervals, namely &quot;2017-11-01T00:05:00.000 to 2017-11-01T00:12:00.000&quot; and &quot;2017-11-01T16:35:00.000 to 2017-11-01T16:37:00.000&quot;. The SQL statement requires that the values of selected timeseries satisfying any time interval be selected.</p> <p>The execution result of this SQL statement is as follows:</p> <div class="language- line-numbers-mode"><pre class="language-text"><code>+-----------------------------+------------------------+--------------------------+
|                         Time|root.ln.wf01.wt01.status|root.ln.wf02.wt02.hardware|
+-----------------------------+------------------------+--------------------------+
|2017-11-01T00:06:00.000+08:00|                   false|                        v1|
|2017-11-01T00:07:00.000+08:00|                   false|                        v1|
|2017-11-01T00:08:00.000+08:00|                   false|                        v1|
|2017-11-01T00:09:00.000+08:00|                   false|                        v1|
|2017-11-01T00:10:00.000+08:00|                    true|                        v2|
|2017-11-01T00:11:00.000+08:00|                   false|                        v1|
|2017-11-01T16:35:00.000+08:00|                    true|                        v2|
|2017-11-01T16:36:00.000+08:00|                   false|                        v1|
|2017-11-01T16:37:00.000+08:00|                   false|                        v1|
+-----------------------------+------------------------+--------------------------+
Total line number = 9
It costs 0.014s
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br><span class="line-number">2</span><br><span class="line-number">3</span><br><span class="line-number">4</span><br><span class="line-number">5</span><br><span class="line-number">6</span><br><span class="line-number">7</span><br><span class="line-number">8</span><br><span class="line-number">9</span><br><span class="line-number">10</span><br><span class="line-number">11</span><br><span class="line-number">12</span><br><span class="line-number">13</span><br><span class="line-number">14</span><br><span class="line-number">15</span><br></div></div><h4 id="order-by-time-query"><a href="#order-by-time-query" class="header-anchor">#</a> Order By Time Query</h4> <p>IoTDB supports the 'order by time' statement since 0.11, it's used to display results in descending order by time.
For example, the SQL statement is:</p> <div class="language-sql line-numbers-mode"><pre class="language-sql"><code><span class="token keyword">select</span> <span class="token operator">*</span> <span class="token keyword">from</span> root<span class="token punctuation">.</span>ln <span class="token keyword">where</span> <span class="token keyword">time</span> <span class="token operator">&gt;</span> <span class="token number">1</span> <span class="token keyword">order</span> <span class="token keyword">by</span> <span class="token keyword">time</span> <span class="token keyword">desc</span> <span class="token keyword">limit</span> <span class="token number">10</span><span class="token punctuation">;</span>
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br></div></div><p>The execution result of this SQL statement is as follows:</p> <div class="language- line-numbers-mode"><pre class="language-text"><code>+-----------------------------+--------------------------+------------------------+-----------------------------+------------------------+
|                         Time|root.ln.wf02.wt02.hardware|root.ln.wf02.wt02.status|root.ln.wf01.wt01.temperature|root.ln.wf01.wt01.status|
+-----------------------------+--------------------------+------------------------+-----------------------------+------------------------+
|2017-11-07T23:59:00.000+08:00|                        v1|                   false|                        21.07|                   false|
|2017-11-07T23:58:00.000+08:00|                        v1|                   false|                        22.93|                   false|
|2017-11-07T23:57:00.000+08:00|                        v2|                    true|                        24.39|                    true|
|2017-11-07T23:56:00.000+08:00|                        v2|                    true|                        24.44|                    true|
|2017-11-07T23:55:00.000+08:00|                        v2|                    true|                         25.9|                    true|
|2017-11-07T23:54:00.000+08:00|                        v1|                   false|                        22.52|                   false|
|2017-11-07T23:53:00.000+08:00|                        v2|                    true|                        24.58|                    true|
|2017-11-07T23:52:00.000+08:00|                        v1|                   false|                        20.18|                   false|
|2017-11-07T23:51:00.000+08:00|                        v1|                   false|                        22.24|                   false|
|2017-11-07T23:50:00.000+08:00|                        v2|                    true|                         23.7|                    true|
+-----------------------------+--------------------------+------------------------+-----------------------------+------------------------+
Total line number = 10
It costs 0.016s
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br><span class="line-number">2</span><br><span class="line-number">3</span><br><span class="line-number">4</span><br><span class="line-number">5</span><br><span class="line-number">6</span><br><span class="line-number">7</span><br><span class="line-number">8</span><br><span class="line-number">9</span><br><span class="line-number">10</span><br><span class="line-number">11</span><br><span class="line-number">12</span><br><span class="line-number">13</span><br><span class="line-number">14</span><br><span class="line-number">15</span><br><span class="line-number">16</span><br></div></div><h3 id="time-series-generating-functions"><a href="#time-series-generating-functions" class="header-anchor">#</a> Time Series Generating Functions</h3> <p>The time series generating function takes several time series as input and outputs one time series. Unlike the aggregation function, the result set of the time series generating function has a timestamp column.</p> <p>All time series generating functions can accept * as input.</p> <p>IoTDB supports hybrid queries of time series generating function queries and raw data queries.</p> <h4 id="mathematical-functions"><a href="#mathematical-functions" class="header-anchor">#</a> Mathematical Functions</h4> <p>Currently IoTDB supports the following mathematical functions. The behavior of these mathematical functions is consistent with the behavior of these functions in the Java Math standard library.</p> <table><thead><tr><th>Function Name</th> <th>Allowed Input Series Data Types</th> <th>Output Series Data Type</th> <th>Corresponding Implementation in the Java Standard Library</th></tr></thead> <tbody><tr><td>SIN</td> <td>INT32 / INT64 / FLOAT / DOUBLE</td> <td>DOUBLE</td> <td>Math#sin(double)</td></tr> <tr><td>COS</td> <td>INT32 / INT64 / FLOAT / DOUBLE</td> <td>DOUBLE</td> <td>Math#cos(double)</td></tr> <tr><td>TAN</td> <td>INT32 / INT64 / FLOAT / DOUBLE</td> <td>DOUBLE</td> <td>Math#tan(double)</td></tr> <tr><td>ASIN</td> <td>INT32 / INT64 / FLOAT / DOUBLE</td> <td>DOUBLE</td> <td>Math#asin(double)</td></tr> <tr><td>ACOS</td> <td>INT32 / INT64 / FLOAT / DOUBLE</td> <td>DOUBLE</td> <td>Math#acos(double)</td></tr> <tr><td>ATAN</td> <td>INT32 / INT64 / FLOAT / DOUBLE</td> <td>DOUBLE</td> <td>Math#atan(double)</td></tr> <tr><td>DEGREES</td> <td>INT32 / INT64 / FLOAT / DOUBLE</td> <td>DOUBLE</td> <td>Math#toDegrees(double)</td></tr> <tr><td>RADIANS</td> <td>INT32 / INT64 / FLOAT / DOUBLE</td> <td>DOUBLE</td> <td>Math#toRadians(double)</td></tr> <tr><td>ABS</td> <td>INT32 / INT64 / FLOAT / DOUBLE</td> <td>Same type as the input series</td> <td>Math#abs(int) / Math#abs(long) /Math#abs(float) /Math#abs(double)</td></tr> <tr><td>SIGN</td> <td>INT32 / INT64 / FLOAT / DOUBLE</td> <td>DOUBLE</td> <td>Math#signum(double)</td></tr> <tr><td>CEIL</td> <td>INT32 / INT64 / FLOAT / DOUBLE</td> <td>DOUBLE</td> <td>Math#ceil(double)</td></tr> <tr><td>FLOOR</td> <td>INT32 / INT64 / FLOAT / DOUBLE</td> <td>DOUBLE</td> <td>Math#floor(double)</td></tr> <tr><td>ROUND</td> <td>INT32 / INT64 / FLOAT / DOUBLE</td> <td>DOUBLE</td> <td>Math#rint(double)</td></tr> <tr><td>EXP</td> <td>INT32 / INT64 / FLOAT / DOUBLE</td> <td>DOUBLE</td> <td>Math#exp(double)</td></tr> <tr><td>LN</td> <td>INT32 / INT64 / FLOAT / DOUBLE</td> <td>DOUBLE</td> <td>Math#log(double)</td></tr> <tr><td>LOG10</td> <td>INT32 / INT64 / FLOAT / DOUBLE</td> <td>DOUBLE</td> <td>Math#log10(double)</td></tr> <tr><td>SQRT</td> <td>INT32 / INT64 / FLOAT / DOUBLE</td> <td>DOUBLE</td> <td>Math#sqrt(double)</td></tr></tbody></table> <p>Example:</p> <div class="language-sql line-numbers-mode"><pre class="language-sql"><code><span class="token keyword">select</span> s1<span class="token punctuation">,</span> sin<span class="token punctuation">(</span>s1<span class="token punctuation">)</span><span class="token punctuation">,</span> cos<span class="token punctuation">(</span>s1<span class="token punctuation">)</span><span class="token punctuation">,</span> tan<span class="token punctuation">(</span>s1<span class="token punctuation">)</span> <span class="token keyword">from</span> root<span class="token punctuation">.</span>sg1<span class="token punctuation">.</span>d1 <span class="token keyword">limit</span> <span class="token number">5</span> <span class="token keyword">offset</span> <span class="token number">1000</span><span class="token punctuation">;</span>
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br></div></div><p>Result:</p> <div class="language- line-numbers-mode"><pre class="language-text"><code>+-----------------------------+-------------------+-------------------+--------------------+-------------------+
|                         Time|     root.sg1.d1.s1|sin(root.sg1.d1.s1)| cos(root.sg1.d1.s1)|tan(root.sg1.d1.s1)|
+-----------------------------+-------------------+-------------------+--------------------+-------------------+
|2020-12-10T17:11:49.037+08:00|7360723084922759782| 0.8133527237573284|  0.5817708713544664| 1.3980636773094157|
|2020-12-10T17:11:49.038+08:00|4377791063319964531|-0.8938962705202537|  0.4482738644511651| -1.994085181866842|
|2020-12-10T17:11:49.039+08:00|7972485567734642915| 0.9627757585308978|-0.27030138509681073|-3.5618602479083545|
|2020-12-10T17:11:49.040+08:00|2508858212791964081|-0.6073417341629443| -0.7944406950452296| 0.7644897069734913|
|2020-12-10T17:11:49.041+08:00|2817297431185141819|-0.8419358900502509| -0.5395775727782725| 1.5603611649667768|
+-----------------------------+-------------------+-------------------+--------------------+-------------------+
Total line number = 5
It costs 0.008s
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br><span class="line-number">2</span><br><span class="line-number">3</span><br><span class="line-number">4</span><br><span class="line-number">5</span><br><span class="line-number">6</span><br><span class="line-number">7</span><br><span class="line-number">8</span><br><span class="line-number">9</span><br><span class="line-number">10</span><br><span class="line-number">11</span><br></div></div><h4 id="string-processing-functions"><a href="#string-processing-functions" class="header-anchor">#</a> String Processing Functions</h4> <p>Currently IoTDB supports the following string processing functions:</p> <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>STRING_CONTAINS</td> <td>TEXT</td> <td><code>s</code>: the sequence to search for</td> <td>BOOLEAN</td> <td>Determine whether <code>s</code> is in the string</td></tr> <tr><td>STRING_MATCHES</td> <td>TEXT</td> <td><code>regex</code>: the regular expression to which the string is to be matched</td> <td>BOOLEAN</td> <td>Determine whether the string can be matched by <code>regex</code></td></tr></tbody></table> <p>Example：</p> <div class="language-sql line-numbers-mode"><pre class="language-sql"><code><span class="token keyword">select</span> s1<span class="token punctuation">,</span> string_contains<span class="token punctuation">(</span>s1<span class="token punctuation">,</span> <span class="token string">&quot;s&quot;</span><span class="token operator">=</span><span class="token string">&quot;warn&quot;</span><span class="token punctuation">)</span><span class="token punctuation">,</span> string_matches<span class="token punctuation">(</span>s1<span class="token punctuation">,</span> <span class="token string">&quot;regex&quot;</span><span class="token operator">=</span><span class="token string">&quot;[^\\s]+37229&quot;</span><span class="token punctuation">)</span> <span class="token keyword">from</span> root<span class="token punctuation">.</span>sg1<span class="token punctuation">.</span>d4<span class="token punctuation">;</span>
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br></div></div><p>Result：</p> <div class="language- line-numbers-mode"><pre class="language-text"><code>+-----------------------------+--------------+-------------------------------------------+------------------------------------------------------+
|                         Time|root.sg1.d4.s1|string_contains(root.sg1.d4.s1, &quot;s&quot;=&quot;warn&quot;)|string_matches(root.sg1.d4.s1, &quot;regex&quot;=&quot;[^\\s]+37229&quot;)|
+-----------------------------+--------------+-------------------------------------------+------------------------------------------------------+
|1970-01-01T08:00:00.001+08:00|    warn:-8721|                                       true|                                                 false|
|1970-01-01T08:00:00.002+08:00|  error:-37229|                                      false|                                                  true|
|1970-01-01T08:00:00.003+08:00|     warn:1731|                                       true|                                                 false|
+-----------------------------+--------------+-------------------------------------------+------------------------------------------------------+
Total line number = 3
It costs 0.007s
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br><span class="line-number">2</span><br><span class="line-number">3</span><br><span class="line-number">4</span><br><span class="line-number">5</span><br><span class="line-number">6</span><br><span class="line-number">7</span><br><span class="line-number">8</span><br><span class="line-number">9</span><br></div></div><h4 id="selector-functions"><a href="#selector-functions" class="header-anchor">#</a> Selector Functions</h4> <p>Currently IoTDB supports the following selector functions:</p> <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>TOP_K</td> <td>INT32 / INT64 / FLOAT / DOUBLE / TEXT</td> <td><code>k</code>: the maximum number of selected data points, must be greater than 0 and less than or equal to 1000</td> <td>Same type as the input series</td> <td>Returns <code>k</code> data points with the largest values in a time series.</td></tr> <tr><td>BOTTOM_K</td> <td>INT32 / INT64 / FLOAT / DOUBLE / TEXT</td> <td><code>k</code>: the maximum number of selected data points, must be greater than 0 and less than or equal to 1000</td> <td>Same type as the input series</td> <td>Returns <code>k</code> data points with the smallest values in a time series.</td></tr></tbody></table> <p>Example：</p> <div class="language-sql line-numbers-mode"><pre class="language-sql"><code><span class="token keyword">select</span> s1<span class="token punctuation">,</span> top_k<span class="token punctuation">(</span>s1<span class="token punctuation">,</span> <span class="token string">&quot;k&quot;</span><span class="token operator">=</span><span class="token string">&quot;2&quot;</span><span class="token punctuation">)</span><span class="token punctuation">,</span> bottom_k<span class="token punctuation">(</span>s1<span class="token punctuation">,</span> <span class="token string">&quot;k&quot;</span><span class="token operator">=</span><span class="token string">&quot;2&quot;</span><span class="token punctuation">)</span> <span class="token keyword">from</span> root<span class="token punctuation">.</span>sg1<span class="token punctuation">.</span>d2 <span class="token keyword">where</span> <span class="token keyword">time</span> <span class="token operator">&gt;</span> <span class="token number">2020</span><span class="token operator">-</span><span class="token number">12</span><span class="token operator">-</span><span class="token number">10</span>T20:<span class="token number">36</span>:<span class="token number">15.530</span><span class="token operator">+</span><span class="token number">08</span>:<span class="token number">00</span><span class="token punctuation">;</span>
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br></div></div><p>Result：</p> <div class="language- line-numbers-mode"><pre class="language-text"><code>+-----------------------------+--------------------+------------------------------+---------------------------------+
|                         Time|      root.sg1.d2.s1|top_k(root.sg1.d2.s1, &quot;k&quot;=&quot;2&quot;)|bottom_k(root.sg1.d2.s1, &quot;k&quot;=&quot;2&quot;)|
+-----------------------------+--------------------+------------------------------+---------------------------------+
|2020-12-10T20:36:15.531+08:00| 1531604122307244742|           1531604122307244742|                             null|
|2020-12-10T20:36:15.532+08:00|-7426070874923281101|                          null|                             null|
|2020-12-10T20:36:15.533+08:00|-7162825364312197604|          -7162825364312197604|                             null|
|2020-12-10T20:36:15.534+08:00|-8581625725655917595|                          null|             -8581625725655917595|
|2020-12-10T20:36:15.535+08:00|-7667364751255535391|                          null|             -7667364751255535391|
+-----------------------------+--------------------+------------------------------+---------------------------------+
Total line number = 5
It costs 0.006s
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br><span class="line-number">2</span><br><span class="line-number">3</span><br><span class="line-number">4</span><br><span class="line-number">5</span><br><span class="line-number">6</span><br><span class="line-number">7</span><br><span class="line-number">8</span><br><span class="line-number">9</span><br><span class="line-number">10</span><br><span class="line-number">11</span><br></div></div><h4 id="variation-trend-calculation-functions"><a href="#variation-trend-calculation-functions" class="header-anchor">#</a> Variation Trend Calculation Functions</h4> <p>Currently IoTDB supports the following variation trend calculation functions:</p> <table><thead><tr><th>Function Name</th> <th>Allowed Input Series Data Types</th> <th>Output Series Data Type</th> <th>Description</th></tr></thead> <tbody><tr><td>TIME_DIFFERENCE</td> <td>INT32 / INT64 / FLOAT / DOUBLE / BOOLEAN / TEXT</td> <td>INT64</td> <td>Calculates the difference between the time stamp of a data point and the time stamp of the previous data point. There is no corresponding output for the first data point.</td></tr> <tr><td>DIFFERENCE</td> <td>INT32 / INT64 / FLOAT / DOUBLE</td> <td>Same type as the input series</td> <td>Calculates the difference between the value of a data point and the value of the previous data point. There is no corresponding output for the first data point.</td></tr> <tr><td>NON_NEGATIVE_DIFFERENCE</td> <td>INT32 / INT64 / FLOAT / DOUBLE</td> <td>Same type as the input series</td> <td>Calculates the absolute value of the difference between the value of a data point and the value of the previous data point. There is no corresponding output for the first data point.</td></tr> <tr><td>DERIVATIVE</td> <td>INT32 / INT64 / FLOAT / DOUBLE</td> <td>DOUBLE</td> <td>Calculates the rate of change of a data point compared to the previous data point, the result is equals to DIFFERENCE / TIME_DIFFERENCE. There is no corresponding output for the first data point.</td></tr> <tr><td>NON_NEGATIVE_DERIVATIVE</td> <td>INT32 / INT64 / FLOAT / DOUBLE</td> <td>DOUBLE</td> <td>Calculates the absolute value of the rate of change of a data point compared to the previous data point, the result is equals to NON_NEGATIVE_DIFFERENCE / TIME_DIFFERENCE. There is no corresponding output for the first data point.</td></tr></tbody></table> <p>Example:</p> <div class="language-sql line-numbers-mode"><pre class="language-sql"><code><span class="token keyword">select</span> s1<span class="token punctuation">,</span> time_difference<span class="token punctuation">(</span>s1<span class="token punctuation">)</span><span class="token punctuation">,</span> difference<span class="token punctuation">(</span>s1<span class="token punctuation">)</span><span class="token punctuation">,</span> non_negative_difference<span class="token punctuation">(</span>s1<span class="token punctuation">)</span><span class="token punctuation">,</span> derivative<span class="token punctuation">(</span>s1<span class="token punctuation">)</span><span class="token punctuation">,</span> non_negative_derivative<span class="token punctuation">(</span>s1<span class="token punctuation">)</span> <span class="token keyword">from</span> root<span class="token punctuation">.</span>sg1<span class="token punctuation">.</span>d1 <span class="token keyword">limit</span> <span class="token number">5</span> <span class="token keyword">offset</span> <span class="token number">1000</span><span class="token punctuation">;</span> 
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br></div></div><p>Result:</p> <div class="language- line-numbers-mode"><pre class="language-text"><code>+-----------------------------+-------------------+-------------------------------+--------------------------+---------------------------------------+--------------------------+---------------------------------------+
|                         Time|     root.sg1.d1.s1|time_difference(root.sg1.d1.s1)|difference(root.sg1.d1.s1)|non_negative_difference(root.sg1.d1.s1)|derivative(root.sg1.d1.s1)|non_negative_derivative(root.sg1.d1.s1)|
+-----------------------------+-------------------+-------------------------------+--------------------------+---------------------------------------+--------------------------+---------------------------------------+
|2020-12-10T17:11:49.037+08:00|7360723084922759782|                              1|      -8431715764844238876|                    8431715764844238876|    -8.4317157648442388E18|                  8.4317157648442388E18|
|2020-12-10T17:11:49.038+08:00|4377791063319964531|                              1|      -2982932021602795251|                    2982932021602795251|     -2.982932021602795E18|                   2.982932021602795E18|
|2020-12-10T17:11:49.039+08:00|7972485567734642915|                              1|       3594694504414678384|                    3594694504414678384|     3.5946945044146785E18|                  3.5946945044146785E18|
|2020-12-10T17:11:49.040+08:00|2508858212791964081|                              1|      -5463627354942678834|                    5463627354942678834|     -5.463627354942679E18|                   5.463627354942679E18|
|2020-12-10T17:11:49.041+08:00|2817297431185141819|                              1|        308439218393177738|                     308439218393177738|     3.0843921839317773E17|                  3.0843921839317773E17|
+-----------------------------+-------------------+-------------------------------+--------------------------+---------------------------------------+--------------------------+---------------------------------------+
Total line number = 5
It costs 0.014s
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br><span class="line-number">2</span><br><span class="line-number">3</span><br><span class="line-number">4</span><br><span class="line-number">5</span><br><span class="line-number">6</span><br><span class="line-number">7</span><br><span class="line-number">8</span><br><span class="line-number">9</span><br><span class="line-number">10</span><br><span class="line-number">11</span><br></div></div><h4 id="user-defined-timeseries-generating-functions"><a href="#user-defined-timeseries-generating-functions" class="header-anchor">#</a> User Defined Timeseries Generating Functions</h4> <p>Please refer to <a href="/UserGuide/V0.12.x/UDF/UDF-User-Defined-Function.html">UDF (User Defined Function)</a>.</p> <h3 id="aggregate-query"><a href="#aggregate-query" class="header-anchor">#</a> Aggregate Query</h3> <p>This section mainly introduces the related examples of aggregate query.</p> <h4 id="count-points"><a href="#count-points" class="header-anchor">#</a> Count Points</h4> <div class="language- line-numbers-mode"><pre class="language-text"><code>select count(status) from root.ln.wf01.wt01;
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br></div></div><p>Result:</p> <div class="language- line-numbers-mode"><pre class="language-text"><code>+-------------------------------+
|count(root.ln.wf01.wt01.status)|
+-------------------------------+
|                          10080|
+-------------------------------+
Total line number = 1
It costs 0.016s
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br><span class="line-number">2</span><br><span class="line-number">3</span><br><span class="line-number">4</span><br><span class="line-number">5</span><br><span class="line-number">6</span><br><span class="line-number">7</span><br></div></div><h5 id="aggregation-by-level"><a href="#aggregation-by-level" class="header-anchor">#</a> Aggregation By Level</h5> <p><strong>Aggregation by level statement</strong> is used for aggregating upon specific hierarchical level of timeseries path.
For all timeseries paths, by convention, &quot;level=0&quot; represents <em>root</em> level.
That is, to tally the points of any measurements under &quot;root.ln&quot;, the level should be set to 1.</p> <p>For example, there are multiple series under &quot;root.ln.wf01&quot;, such as &quot;root.ln.wf01.wt01.status&quot;,&quot;root.ln.wf01.wt02.status&quot;,&quot;root.ln.wf01.wt03.status&quot;.
To count the number of &quot;status&quot; points of all these series, use query:</p> <div class="language- line-numbers-mode"><pre class="language-text"><code>select count(status) from root.ln.wf01.* group by level=2
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br></div></div><p>Result:</p> <div class="language- line-numbers-mode"><pre class="language-text"><code>+----------------------------+
|COUNT(root.ln.wf01.*.status)|
+----------------------------+
|                       10080|
+----------------------------+
Total line number = 1
It costs 0.003s
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br><span class="line-number">2</span><br><span class="line-number">3</span><br><span class="line-number">4</span><br><span class="line-number">5</span><br><span class="line-number">6</span><br><span class="line-number">7</span><br></div></div><p>Suppose we add another two timeseries, &quot;root.ln.wf01.wt01.temperature&quot; and &quot;root.ln.wf02.wt01.temperature&quot;.
To query the count and the sum of &quot;temperature&quot; under path &quot;root.ln.<em>.</em>&quot;,
aggregating on level=2, use following statement:</p> <div class="language- line-numbers-mode"><pre class="language-text"><code>select count(temperature), sum(temperature) from root.ln.*.* group by level=2
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br></div></div><p>Result：</p> <div class="language- line-numbers-mode"><pre class="language-text"><code>+---------------------------------+---------------------------------+-------------------------------+-------------------------------+
|count(root.ln.wf02.*.temperature)|count(root.ln.wf01.*.temperature)|sum(root.ln.wf02.*.temperature)|sum(root.ln.wf01.*.temperature)|
+---------------------------------+---------------------------------+-------------------------------+-------------------------------+
|                                8|                                4|                          228.0|              91.83000183105469|
+---------------------------------+---------------------------------+-------------------------------+-------------------------------+
Total line number = 1
It costs 0.013s
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br><span class="line-number">2</span><br><span class="line-number">3</span><br><span class="line-number">4</span><br><span class="line-number">5</span><br><span class="line-number">6</span><br><span class="line-number">7</span><br></div></div><p>To query the count and the sum of path &quot;root.ln.*.*.temperature&quot; aggregating on &quot;root.ln&quot; level,
simply set level=1</p> <div class="language- line-numbers-mode"><pre class="language-text"><code>select count(temperature), sum(temperature) from root.ln.*.* group by level=1
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br></div></div><p>Result：</p> <div class="language- line-numbers-mode"><pre class="language-text"><code>+------------------------------+----------------------------+
|count(root.ln.*.*.temperature)|sum(root.ln.*.*.temperature)|
+------------------------------+----------------------------+
|                            12|           319.8300018310547|
+------------------------------+----------------------------+
Total line number = 1
It costs 0.013s
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br><span class="line-number">2</span><br><span class="line-number">3</span><br><span class="line-number">4</span><br><span class="line-number">5</span><br><span class="line-number">6</span><br><span class="line-number">7</span><br></div></div><p>All supported aggregation functions are: count, sum, avg, last_value, first_value, min_time, max_time, min_value, max_value.
When using four aggregations: sum, avg, min_value and max_value, please make sure all the aggregated series have exactly the same data type.
Otherwise, it will generate a syntax error.</p> <h3 id="down-frequency-aggregate-query"><a href="#down-frequency-aggregate-query" class="header-anchor">#</a> Down-Frequency Aggregate Query</h3> <p>This section mainly introduces the related examples of down-frequency aggregation query,
using the <a href="/UserGuide/V0.12.x/Appendix/SQL-Reference.html">GROUP BY clause</a>,
which is used to partition the result set according to the user's given partitioning conditions and aggregate the partitioned result set.
IoTDB supports partitioning result sets according to time interval and customized sliding step which should not be smaller than the time interval and defaults to equal the time interval if not set. And by default results are sorted by time in ascending order.
You can also use the <a href="/UserGuide/V0.12.x/API/Programming-Native-API.html">Java JDBC</a> standard interface to execute related queries.</p> <p>The GROUP BY statement provides users with three types of specified parameters:</p> <ul><li>Parameter 1: The display window on the time axis</li> <li>Parameter 2: Time interval for dividing the time axis(should be positive)</li> <li>Parameter 3: Time sliding step (optional and should not be smaller than the time interval and defaults to equal the time interval if not set)</li></ul> <p>The actual meanings of the three types of parameters are shown in Figure 5.2 below.
Among them, the parameter 3 is optional.
There are three typical examples of frequency reduction aggregation:
parameter 3 not specified,
parameter 3 specified,
and value filtering conditions specified.</p> <center><img src="https://user-images.githubusercontent.com/16079446/69109512-f808bc80-0ab2-11ea-9e4d-b2b2f58fb474.png" style="width:100%;max-width:800px;max-height:600px;margin-left:auto;margin-right:auto;display:block;"></center> <p><strong>Figure 5.2 The actual meanings of the three types of parameters</strong></p> <h4 id="down-frequency-aggregate-query-without-specifying-the-sliding-step-length"><a href="#down-frequency-aggregate-query-without-specifying-the-sliding-step-length" class="header-anchor">#</a> Down-Frequency Aggregate Query without Specifying the Sliding Step Length</h4> <p>The SQL statement is:</p> <div class="language- line-numbers-mode"><pre class="language-text"><code>select count(status), max_value(temperature) from root.ln.wf01.wt01 group by ([2017-11-01T00:00:00, 2017-11-07T23:00:00),1d);
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br></div></div><p>which means:</p> <p>Since the sliding step length is not specified, the GROUP BY statement by default set the sliding step the same as the time interval which is <code>1d</code>.</p> <p>The fist parameter of the GROUP BY statement above is the display window parameter, which determines the final display range is [2017-11-01T00:00:00, 2017-11-07T23:00:00).</p> <p>The second parameter of the GROUP BY statement above is the time interval for dividing the time axis. Taking this parameter (1d) as time interval and startTime of the display window as the dividing origin, the time axis is divided into several continuous intervals, which are [0,1d), [1d, 2d), [2d, 3d), etc.</p> <p>Then the system will use the time and value filtering condition in the WHERE clause and the first parameter of the GROUP BY statement as the data filtering condition to obtain the data satisfying the filtering condition (which in this case is the data in the range of [2017-11-01T00:00:00, 2017-11-07 T23:00:00]), and map these data to the previously segmented time axis (in this case there are mapped data in every 1-day period from 2017-11-01T00:00:00 to 2017-11-07T23:00:00:00).</p> <p>Since there is data for each time period in the result range to be displayed, the execution result of the SQL statement is shown below:</p> <div class="language- line-numbers-mode"><pre class="language-text"><code>+-----------------------------+-------------------------------+----------------------------------------+
|                         Time|count(root.ln.wf01.wt01.status)|max_value(root.ln.wf01.wt01.temperature)|
+-----------------------------+-------------------------------+----------------------------------------+
|2017-11-01T00:00:00.000+08:00|                           1440|                                    26.0|
|2017-11-02T00:00:00.000+08:00|                           1440|                                    26.0|
|2017-11-03T00:00:00.000+08:00|                           1440|                                   25.99|
|2017-11-04T00:00:00.000+08:00|                           1440|                                    26.0|
|2017-11-05T00:00:00.000+08:00|                           1440|                                    26.0|
|2017-11-06T00:00:00.000+08:00|                           1440|                                   25.99|
|2017-11-07T00:00:00.000+08:00|                           1380|                                    26.0|
+-----------------------------+-------------------------------+----------------------------------------+
Total line number = 7
It costs 0.024s
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br><span class="line-number">2</span><br><span class="line-number">3</span><br><span class="line-number">4</span><br><span class="line-number">5</span><br><span class="line-number">6</span><br><span class="line-number">7</span><br><span class="line-number">8</span><br><span class="line-number">9</span><br><span class="line-number">10</span><br><span class="line-number">11</span><br><span class="line-number">12</span><br><span class="line-number">13</span><br></div></div><h4 id="down-frequency-aggregate-query-specifying-the-sliding-step-length"><a href="#down-frequency-aggregate-query-specifying-the-sliding-step-length" class="header-anchor">#</a> Down-Frequency Aggregate Query Specifying the Sliding Step Length</h4> <p>The SQL statement is:</p> <div class="language- line-numbers-mode"><pre class="language-text"><code>select count(status), max_value(temperature) from root.ln.wf01.wt01 group by ([2017-11-01 00:00:00, 2017-11-07 23:00:00), 3h, 1d);
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br></div></div><p>which means:</p> <p>Since the user specifies the sliding step parameter as 1d, the GROUP BY statement will move the time interval <code>1 day</code> long instead of <code>3 hours</code> as default.</p> <p>That means we want to fetch all the data of 00:00:00 to 02:59:59 every day from 2017-11-01 to 2017-11-07.</p> <p>The first parameter of the GROUP BY statement above is the display window parameter, which determines the final display range is [2017-11-01T00:00:00, 2017-11-07T23:00:00).</p> <p>The second parameter of the GROUP BY statement above is the time interval for dividing the time axis. Taking this parameter (3h) as time interval and the startTime of the display window as the dividing origin, the time axis is divided into several continuous intervals, which are [2017-11-01T00:00:00, 2017-11-01T03:00:00), [2017-11-02T00:00:00, 2017-11-02T03:00:00), [2017-11-03T00:00:00, 2017-11-03T03:00:00), etc.</p> <p>The third parameter of the GROUP BY statement above is the sliding step for each time interval moving.</p> <p>Then the system will use the time and value filtering condition in the WHERE clause and the first parameter of the GROUP BY statement as the data filtering condition to obtain the data satisfying the filtering condition (which in this case is the data in the range of [2017-11-01T00:00:00, 2017-11-07T23:00:00]), and map these data to the previously segmented time axis (in this case there are mapped data in every 3-hour period for each day from 2017-11-01T00:00:00 to 2017-11-07T23:00:00:00).</p> <p>Since there is data for each time period in the result range to be displayed, the execution result of the SQL statement is shown below:</p> <div class="language- line-numbers-mode"><pre class="language-text"><code>+-----------------------------+-------------------------------+----------------------------------------+
|                         Time|count(root.ln.wf01.wt01.status)|max_value(root.ln.wf01.wt01.temperature)|
+-----------------------------+-------------------------------+----------------------------------------+
|2017-11-01T00:00:00.000+08:00|                            180|                                   25.98|
|2017-11-02T00:00:00.000+08:00|                            180|                                   25.98|
|2017-11-03T00:00:00.000+08:00|                            180|                                   25.96|
|2017-11-04T00:00:00.000+08:00|                            180|                                   25.96|
|2017-11-05T00:00:00.000+08:00|                            180|                                    26.0|
|2017-11-06T00:00:00.000+08:00|                            180|                                   25.85|
|2017-11-07T00:00:00.000+08:00|                            180|                                   25.99|
+-----------------------------+-------------------------------+----------------------------------------+
Total line number = 7
It costs 0.006s
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br><span class="line-number">2</span><br><span class="line-number">3</span><br><span class="line-number">4</span><br><span class="line-number">5</span><br><span class="line-number">6</span><br><span class="line-number">7</span><br><span class="line-number">8</span><br><span class="line-number">9</span><br><span class="line-number">10</span><br><span class="line-number">11</span><br><span class="line-number">12</span><br><span class="line-number">13</span><br></div></div><h4 id="down-frequency-aggregate-query-by-natural-month"><a href="#down-frequency-aggregate-query-by-natural-month" class="header-anchor">#</a> Down-Frequency Aggregate Query by Natural Month</h4> <p>The SQL statement is:</p> <div class="language- line-numbers-mode"><pre class="language-text"><code>select count(status) from root.ln.wf01.wt01 group by([2017-11-01T00:00:00, 2019-11-07T23:00:00), 1mo, 2mo);
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br></div></div><p>which means:</p> <p>Since the user specifies the sliding step parameter as <code>2mo</code>, the GROUP BY statement will move the time interval <code>2 months</code> long instead of <code>1 month</code> as default.</p> <p>The first parameter of the GROUP BY statement above is the display window parameter, which determines the final display range is [2017-11-01T00:00:00, 2019-11-07T23:00:00).</p> <p>The start time is 2017-11-01T00:00:00. The sliding step will increment monthly based on the start date, and the 1st day of the month will be used as the time interval's start time.</p> <p>The second parameter of the GROUP BY statement above is the time interval for dividing the time axis. Taking this parameter (1mo) as time interval and the startTime of the display window as the dividing origin, the time axis is divided into several continuous intervals, which are [2017-11-01T00:00:00, 2017-12-01T00:00:00), [2018-02-01T00:00:00, 2018-03-01T00:00:00), [2018-05-03T00:00:00, 2018-06-01T00:00:00)), etc.</p> <p>The third parameter of the GROUP BY statement above is the sliding step for each time interval moving.</p> <p>Then the system will use the time and value filtering condition in the WHERE clause and the first parameter of the GROUP BY statement as the data filtering condition to obtain the data satisfying the filtering condition (which in this case is the data in the range of (2017-11-01T00:00:00, 2019-11-07T23:00:00], and map these data to the previously segmented time axis (in this case there are mapped data of the first month in every two month period from 2017-11-01T00:00:00 to 2019-11-07T23:00:00).</p> <p>The SQL execution result is:</p> <div class="language- line-numbers-mode"><pre class="language-text"><code>+-----------------------------+-------------------------------+
|                         Time|count(root.ln.wf01.wt01.status)|
+-----------------------------+-------------------------------+
|2017-11-01T00:00:00.000+08:00|                            259|
|2018-01-01T00:00:00.000+08:00|                            250|
|2018-03-01T00:00:00.000+08:00|                            259|
|2018-05-01T00:00:00.000+08:00|                            251|
|2018-07-01T00:00:00.000+08:00|                            242|
|2018-09-01T00:00:00.000+08:00|                            225|
|2018-11-01T00:00:00.000+08:00|                            216|
|2019-01-01T00:00:00.000+08:00|                            207|
|2019-03-01T00:00:00.000+08:00|                            216|
|2019-05-01T00:00:00.000+08:00|                            207|
|2019-07-01T00:00:00.000+08:00|                            199|
|2019-09-01T00:00:00.000+08:00|                            181|
|2019-11-01T00:00:00.000+08:00|                             60|
+-----------------------------+-------------------------------+
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br><span class="line-number">2</span><br><span class="line-number">3</span><br><span class="line-number">4</span><br><span class="line-number">5</span><br><span class="line-number">6</span><br><span class="line-number">7</span><br><span class="line-number">8</span><br><span class="line-number">9</span><br><span class="line-number">10</span><br><span class="line-number">11</span><br><span class="line-number">12</span><br><span class="line-number">13</span><br><span class="line-number">14</span><br><span class="line-number">15</span><br><span class="line-number">16</span><br><span class="line-number">17</span><br></div></div><p>The SQL statement is:</p> <div class="language- line-numbers-mode"><pre class="language-text"><code>select count(status) from root.ln.wf01.wt01 group by([2017-10-31T00:00:00, 2019-11-07T23:00:00), 1mo, 2mo);
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br></div></div><p>which means:</p> <p>Since the user specifies the sliding step parameter as <code>2mo</code>, the GROUP BY statement will move the time interval <code>2 months</code> long instead of <code>1 month</code> as default.</p> <p>The first parameter of the GROUP BY statement above is the display window parameter, which determines the final display range is [2017-10-31T00:00:00, 2019-11-07T23:00:00).</p> <p>Different from the previous example, the start time is set to 2017-10-31T00:00:00.  The sliding step will increment monthly based on the start date, and the 31st day of the month meaning the last day of the month will be used as the time interval's start time. If the start time is set to the 30th date, the sliding step will use the 30th or the last day of the month.</p> <p>The start time is 2017-10-31T00:00:00. The sliding step will increment monthly based on the start time, and the 1st day of the month will be used as the time interval's start time.</p> <p>The second parameter of the GROUP BY statement above is the time interval for dividing the time axis. Taking this parameter (1mo) as time interval and the startTime of the display window as the dividing origin, the time axis is divided into several continuous intervals, which are [2017-10-31T00:00:00, 2017-11-31T00:00:00), [2018-02-31T00:00:00, 2018-03-31T00:00:00), [2018-05-31T00:00:00, 2018-06-31T00:00:00), etc.</p> <p>The third parameter of the GROUP BY statement above is the sliding step for each time interval moving.</p> <p>Then the system will use the time and value filtering condition in the WHERE clause and the first parameter of the GROUP BY statement as the data filtering condition to obtain the data satisfying the filtering condition (which in this case is the data in the range of [2017-10-31T00:00:00, 2019-11-07T23:00:00) and map these data to the previously segmented time axis (in this case there are mapped data of the first month in every two month period from 2017-10-31T00:00:00 to 2019-11-07T23:00:00).</p> <p>The SQL execution result is:</p> <div class="language- line-numbers-mode"><pre class="language-text"><code>+-----------------------------+-------------------------------+
|                         Time|count(root.ln.wf01.wt01.status)|
+-----------------------------+-------------------------------+
|2017-10-31T00:00:00.000+08:00|                            251|
|2017-12-31T00:00:00.000+08:00|                            250|
|2018-02-28T00:00:00.000+08:00|                            259|
|2018-04-30T00:00:00.000+08:00|                            250|
|2018-06-30T00:00:00.000+08:00|                            242|
|2018-08-31T00:00:00.000+08:00|                            225|
|2018-10-31T00:00:00.000+08:00|                            216|
|2018-12-31T00:00:00.000+08:00|                            208|
|2019-02-28T00:00:00.000+08:00|                            216|
|2019-04-30T00:00:00.000+08:00|                            208|
|2019-06-30T00:00:00.000+08:00|                            199|
|2019-08-31T00:00:00.000+08:00|                            181|
|2019-10-31T00:00:00.000+08:00|                             69|
+-----------------------------+-------------------------------+
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br><span class="line-number">2</span><br><span class="line-number">3</span><br><span class="line-number">4</span><br><span class="line-number">5</span><br><span class="line-number">6</span><br><span class="line-number">7</span><br><span class="line-number">8</span><br><span class="line-number">9</span><br><span class="line-number">10</span><br><span class="line-number">11</span><br><span class="line-number">12</span><br><span class="line-number">13</span><br><span class="line-number">14</span><br><span class="line-number">15</span><br><span class="line-number">16</span><br><span class="line-number">17</span><br></div></div><h4 id="left-open-and-right-close-range"><a href="#left-open-and-right-close-range" class="header-anchor">#</a> Left Open And Right Close Range</h4> <p>The SQL statement is:</p> <div class="language- line-numbers-mode"><pre class="language-text"><code>select count(status) from root.ln.wf01.wt01 group by ((2017-11-01T00:00:00, 2017-11-07T23:00:00],1d);
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br></div></div><p>In this sql, the time interval is left open and right close, so we won't include the value of timestamp 2017-11-01T00:00:00 and instead we will include the value of timestamp 2017-11-07T23:00:00.</p> <p>We will get the result like following:</p> <div class="language- line-numbers-mode"><pre class="language-text"><code>+-----------------------------+-------------------------------+
|                         Time|count(root.ln.wf01.wt01.status)|
+-----------------------------+-------------------------------+
|2017-11-02T00:00:00.000+08:00|                           1440|
|2017-11-03T00:00:00.000+08:00|                           1440|
|2017-11-04T00:00:00.000+08:00|                           1440|
|2017-11-05T00:00:00.000+08:00|                           1440|
|2017-11-06T00:00:00.000+08:00|                           1440|
|2017-11-07T00:00:00.000+08:00|                           1440|
|2017-11-07T23:00:00.000+08:00|                           1380|
+-----------------------------+-------------------------------+
Total line number = 7
It costs 0.004s
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br><span class="line-number">2</span><br><span class="line-number">3</span><br><span class="line-number">4</span><br><span class="line-number">5</span><br><span class="line-number">6</span><br><span class="line-number">7</span><br><span class="line-number">8</span><br><span class="line-number">9</span><br><span class="line-number">10</span><br><span class="line-number">11</span><br><span class="line-number">12</span><br><span class="line-number">13</span><br></div></div><h4 id="down-frequency-aggregate-query-with-level-clause"><a href="#down-frequency-aggregate-query-with-level-clause" class="header-anchor">#</a> Down-Frequency Aggregate Query with Level Clause</h4> <p>Level could be defined to show count the number of points of each node at the given level in current Metadata Tree.</p> <p>This could be used to query the number of points under each device.</p> <p>The SQL statement is:</p> <p>Get down-frequency aggregate query by level.</p> <div class="language- line-numbers-mode"><pre class="language-text"><code>select count(status) from root.ln.wf01.wt01 group by ((2017-11-01T00:00:00, 2017-11-07T23:00:00],1d), level=1;
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br></div></div><p>Result:</p> <div class="language- line-numbers-mode"><pre class="language-text"><code>+-----------------------------+-------------------------+
|                         Time|COUNT(root.ln.*.*.status)|
+-----------------------------+-------------------------+
|2017-11-02T00:00:00.000+08:00|                     1440|
|2017-11-03T00:00:00.000+08:00|                     1440|
|2017-11-04T00:00:00.000+08:00|                     1440|
|2017-11-05T00:00:00.000+08:00|                     1440|
|2017-11-06T00:00:00.000+08:00|                     1440|
|2017-11-07T00:00:00.000+08:00|                     1440|
|2017-11-07T23:00:00.000+08:00|                     1380|
+-----------------------------+-------------------------+
Total line number = 7
It costs 0.006s
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br><span class="line-number">2</span><br><span class="line-number">3</span><br><span class="line-number">4</span><br><span class="line-number">5</span><br><span class="line-number">6</span><br><span class="line-number">7</span><br><span class="line-number">8</span><br><span class="line-number">9</span><br><span class="line-number">10</span><br><span class="line-number">11</span><br><span class="line-number">12</span><br><span class="line-number">13</span><br></div></div><p>Down-frequency aggregate query with sliding step and by level.</p> <div class="language- line-numbers-mode"><pre class="language-text"><code>select count(status) from root.ln.wf01.wt01 group by ([2017-11-01 00:00:00, 2017-11-07 23:00:00), 3h, 1d), level=1;
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br></div></div><p>Result:</p> <div class="language- line-numbers-mode"><pre class="language-text"><code>+-----------------------------+-------------------------+
|                         Time|COUNT(root.ln.*.*.status)|
+-----------------------------+-------------------------+
|2017-11-01T00:00:00.000+08:00|                      180|
|2017-11-02T00:00:00.000+08:00|                      180|
|2017-11-03T00:00:00.000+08:00|                      180|
|2017-11-04T00:00:00.000+08:00|                      180|
|2017-11-05T00:00:00.000+08:00|                      180|
|2017-11-06T00:00:00.000+08:00|                      180|
|2017-11-07T00:00:00.000+08:00|                      180|
+-----------------------------+-------------------------+
Total line number = 7
It costs 0.004s
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br><span class="line-number">2</span><br><span class="line-number">3</span><br><span class="line-number">4</span><br><span class="line-number">5</span><br><span class="line-number">6</span><br><span class="line-number">7</span><br><span class="line-number">8</span><br><span class="line-number">9</span><br><span class="line-number">10</span><br><span class="line-number">11</span><br><span class="line-number">12</span><br><span class="line-number">13</span><br></div></div><h4 id="down-frequency-aggregate-query-with-fill-clause"><a href="#down-frequency-aggregate-query-with-fill-clause" class="header-anchor">#</a> Down-Frequency Aggregate Query with Fill Clause</h4> <p>In group by fill, sliding step is not supported in group by clause</p> <p>Now, only last_value aggregation function is supported in group by fill.</p> <p>Linear fill is not supported in group by fill.</p> <h5 id="difference-between-previousuntillast-and-previous"><a href="#difference-between-previousuntillast-and-previous" class="header-anchor">#</a> Difference Between PREVIOUSUNTILLAST And PREVIOUS</h5> <ul><li>PREVIOUS will fill any null value as long as there exist value is not null before it.</li> <li>PREVIOUSUNTILLAST won't fill the result whose time is after the last time of that time series.</li></ul> <p>first, we check value root.ln.wf01.wt01.temperature when time after 2017-11-07T23:50:00.</p> <div class="language- line-numbers-mode"><pre class="language-text"><code>IoTDB&gt; SELECT temperature FROM root.ln.wf01.wt01 where time &gt;= 2017-11-07T23:50:00
+-----------------------------+-----------------------------+
|                         Time|root.ln.wf01.wt01.temperature|
+-----------------------------+-----------------------------+
|2017-11-07T23:50:00.000+08:00|                         23.7|
|2017-11-07T23:51:00.000+08:00|                        22.24|
|2017-11-07T23:52:00.000+08:00|                        20.18|
|2017-11-07T23:53:00.000+08:00|                        24.58|
|2017-11-07T23:54:00.000+08:00|                        22.52|
|2017-11-07T23:55:00.000+08:00|                         25.9|
|2017-11-07T23:56:00.000+08:00|                        24.44|
|2017-11-07T23:57:00.000+08:00|                        24.39|
|2017-11-07T23:58:00.000+08:00|                        22.93|
|2017-11-07T23:59:00.000+08:00|                        21.07|
+-----------------------------+-----------------------------+
Total line number = 10
It costs 0.002s
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br><span class="line-number">2</span><br><span class="line-number">3</span><br><span class="line-number">4</span><br><span class="line-number">5</span><br><span class="line-number">6</span><br><span class="line-number">7</span><br><span class="line-number">8</span><br><span class="line-number">9</span><br><span class="line-number">10</span><br><span class="line-number">11</span><br><span class="line-number">12</span><br><span class="line-number">13</span><br><span class="line-number">14</span><br><span class="line-number">15</span><br><span class="line-number">16</span><br><span class="line-number">17</span><br></div></div><p>we will find the last time and value of root.ln.wf01.wt01.temperature are 2017-11-07T23:59:00 and 21.07 respectively.</p> <p>Then execute SQL statements:</p> <div class="language- line-numbers-mode"><pre class="language-text"><code>SELECT last_value(temperature) FROM root.ln.wf01.wt01 GROUP BY([2017-11-07T23:50:00, 2017-11-08T00:01:00),1m) FILL (float[PREVIOUSUNTILLAST]);
SELECT last_value(temperature) FROM root.ln.wf01.wt01 GROUP BY([2017-11-07T23:50:00, 2017-11-08T00:01:00),1m) FILL (float[PREVIOUS]);
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br><span class="line-number">2</span><br></div></div><p>result:</p> <div class="language- line-numbers-mode"><pre class="language-text"><code>+-----------------------------+-----------------------------------------+
|                         Time|last_value(root.ln.wf01.wt01.temperature)|
+-----------------------------+-----------------------------------------+
|2017-11-07T23:50:00.000+08:00|                                     23.7|
|2017-11-07T23:51:00.000+08:00|                                    22.24|
|2017-11-07T23:52:00.000+08:00|                                    20.18|
|2017-11-07T23:53:00.000+08:00|                                    24.58|
|2017-11-07T23:54:00.000+08:00|                                    22.52|
|2017-11-07T23:55:00.000+08:00|                                     25.9|
|2017-11-07T23:56:00.000+08:00|                                    24.44|
|2017-11-07T23:57:00.000+08:00|                                    24.39|
|2017-11-07T23:58:00.000+08:00|                                    22.93|
|2017-11-07T23:59:00.000+08:00|                                    21.07|
|2017-11-08T00:00:00.000+08:00|                                     null|
+-----------------------------+-----------------------------------------+
Total line number = 11
It costs 0.005s

+-----------------------------+-----------------------------------------+
|                         Time|last_value(root.ln.wf01.wt01.temperature)|
+-----------------------------+-----------------------------------------+
|2017-11-07T23:50:00.000+08:00|                                     23.7|
|2017-11-07T23:51:00.000+08:00|                                    22.24|
|2017-11-07T23:52:00.000+08:00|                                    20.18|
|2017-11-07T23:53:00.000+08:00|                                    24.58|
|2017-11-07T23:54:00.000+08:00|                                    22.52|
|2017-11-07T23:55:00.000+08:00|                                     25.9|
|2017-11-07T23:56:00.000+08:00|                                    24.44|
|2017-11-07T23:57:00.000+08:00|                                    24.39|
|2017-11-07T23:58:00.000+08:00|                                    22.93|
|2017-11-07T23:59:00.000+08:00|                                    21.07|
|2017-11-08T00:00:00.000+08:00|                                    21.07|
+-----------------------------+-----------------------------------------+
Total line number = 11
It costs 0.006s
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br><span class="line-number">2</span><br><span class="line-number">3</span><br><span class="line-number">4</span><br><span class="line-number">5</span><br><span class="line-number">6</span><br><span class="line-number">7</span><br><span class="line-number">8</span><br><span class="line-number">9</span><br><span class="line-number">10</span><br><span class="line-number">11</span><br><span class="line-number">12</span><br><span class="line-number">13</span><br><span class="line-number">14</span><br><span class="line-number">15</span><br><span class="line-number">16</span><br><span class="line-number">17</span><br><span class="line-number">18</span><br><span class="line-number">19</span><br><span class="line-number">20</span><br><span class="line-number">21</span><br><span class="line-number">22</span><br><span class="line-number">23</span><br><span class="line-number">24</span><br><span class="line-number">25</span><br><span class="line-number">26</span><br><span class="line-number">27</span><br><span class="line-number">28</span><br><span class="line-number">29</span><br><span class="line-number">30</span><br><span class="line-number">31</span><br><span class="line-number">32</span><br><span class="line-number">33</span><br><span class="line-number">34</span><br><span class="line-number">35</span><br></div></div><p>which means:</p> <p>using PREVIOUSUNTILLAST won't fill time after 2017-11-07T23:59.</p> <h3 id="last-point-query"><a href="#last-point-query" class="header-anchor">#</a> Last point Query</h3> <p>In scenarios when IoT devices updates data in a fast manner, users are more interested in the most recent point of IoT devices.</p> <p>The Last point query is to return the most recent data point of the given timeseries in a three column format.</p> <p>The SQL statement is defined as:</p> <div class="language- line-numbers-mode"><pre class="language-text"><code>select last &lt;Path&gt; [COMMA &lt;Path&gt;]* from &lt; PrefixPath &gt; [COMMA &lt; PrefixPath &gt;]* &lt;WhereClause&gt;
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br></div></div><p>which means: Query and return the last data points of timeseries prefixPath.path.</p> <p>Only time filter with '&gt;' or '&gt;=' is supported in &lt;WhereClause&gt;. Any other filters given in the &lt;WhereClause&gt; will give an exception.</p> <p>The result will be returned in a three column table format.</p> <div class="language- line-numbers-mode"><pre class="language-text"><code>| Time | Path | Value |
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br></div></div><p>Example 1: get the last point of root.ln.wf01.wt01.status:</p> <div class="language- line-numbers-mode"><pre class="language-text"><code>IoTDB&gt; select last status from root.ln.wf01.wt01
+-----------------------------+------------------------+-----+
|                         Time|              timeseries|value|
+-----------------------------+------------------------+-----+
|2017-11-07T23:59:00.000+08:00|root.ln.wf01.wt01.status|false|
+-----------------------------+------------------------+-----+
Total line number = 1
It costs 0.000s
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br><span class="line-number">2</span><br><span class="line-number">3</span><br><span class="line-number">4</span><br><span class="line-number">5</span><br><span class="line-number">6</span><br><span class="line-number">7</span><br><span class="line-number">8</span><br></div></div><p>Example 2: get the last status and temperature points of root.ln.wf01.wt01,
whose timestamp larger or equal to 2017-11-07T23:50:00。</p> <div class="language- line-numbers-mode"><pre class="language-text"><code>IoTDB&gt; select last status, temperature from root.ln.wf01.wt01 where time &gt;= 2017-11-07T23:50:00
+-----------------------------+-----------------------------+---------+
|                         Time|                   timeseries|    value|
+-----------------------------+-----------------------------+---------+
|2017-11-07T23:59:00.000+08:00|     root.ln.wf01.wt01.status|    false|
|2017-11-07T23:59:00.000+08:00|root.ln.wf01.wt01.temperature|21.067368|
+-----------------------------+-----------------------------+---------+
Total line number = 2
It costs 0.002s
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br><span class="line-number">2</span><br><span class="line-number">3</span><br><span class="line-number">4</span><br><span class="line-number">5</span><br><span class="line-number">6</span><br><span class="line-number">7</span><br><span class="line-number">8</span><br><span class="line-number">9</span><br></div></div><h3 id="automated-fill"><a href="#automated-fill" class="header-anchor">#</a> Automated Fill</h3> <p>In the actual use of IoTDB, when doing the query operation of timeseries, situations where the value is null at some time points may appear, which will obstruct the further analysis by users. In order to better reflect the degree of data change, users expect missing values to be automatically filled. Therefore, the IoTDB system introduces the function of Automated Fill.</p> <p>Automated fill function refers to filling empty values according to the user's specified method and effective time range when performing timeseries queries for single or multiple columns. If the queried point's value is not null, the fill function will not work.</p> <blockquote><p>Note: In the current version, IoTDB provides users with two methods: Previous and Linear. The previous method fills blanks with previous value. The linear method fills blanks through linear fitting. And the fill function can only be used when performing point-in-time queries.</p></blockquote> <h4 id="fill-function"><a href="#fill-function" class="header-anchor">#</a> Fill Function</h4> <ul><li>Previous Function</li></ul> <p>When the value of the queried timestamp is null, the value of the previous timestamp is used to fill the blank. The formalized previous method is as follows (see Section 7.1.3.6 for detailed syntax):</p> <div class="language- line-numbers-mode"><pre class="language-text"><code>select &lt;path&gt; from &lt;prefixPath&gt; where time = &lt;T&gt; fill(&lt;data_type&gt;[previous, &lt;before_range&gt;], …)
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br></div></div><p>Detailed descriptions of all parameters are given in Table 3-4.</p> <center>**Table 3-4 Previous fill paramter list**
<table><thead><tr><th style="text-align:left;">Parameter name (case insensitive)</th> <th style="text-align:left;">Interpretation</th></tr></thead> <tbody><tr><td style="text-align:left;">path, prefixPath</td> <td style="text-align:left;">query path; mandatory field</td></tr> <tr><td style="text-align:left;">T</td> <td style="text-align:left;">query timestamp (only one can be specified); mandatory field</td></tr> <tr><td style="text-align:left;">data_type</td> <td style="text-align:left;">the type of data used by the fill method. Optional values are int32, int64, float, double, boolean, text; optional field</td></tr> <tr><td style="text-align:left;">before_range</td> <td style="text-align:left;">represents the valid time range of the previous method. The previous method works when there are values in the [T-before_range, T] range. When before_range is not specified, before_range takes the default value default_fill_interval; -1 represents infinit; optional field</td></tr></tbody></table></center> <p>Here we give an example of filling null values using the previous method. The SQL statement is as follows:</p> <div class="language- line-numbers-mode"><pre class="language-text"><code>select temperature from root.sgcc.wf03.wt01 where time = 2017-11-01T16:37:50.000 fill(float[previous, 1s]) 
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br></div></div><p>which means:</p> <p>Because the timeseries root.sgcc.wf03.wt01.temperature is null at 2017-11-01T16:37:50.000, the system uses the previous timestamp 2017-11-01T16:37:00.000 (and the timestamp is in the [2017-11-01T16:36:50.000, 2017-11-01T16:37:50.000] time range) for fill and display.</p> <p>On the <a href="https://github.com/thulab/iotdb/files/4438687/OtherMaterial-Sample.Data.txt" target="_blank" rel="noopener noreferrer">sample data<span><svg xmlns="http://www.w3.org/2000/svg" aria-hidden="true" focusable="false" x="0px" y="0px" viewBox="0 0 100 100" width="15" height="15" class="icon outbound"><path fill="currentColor" d="M18.8,85.1h56l0,0c2.2,0,4-1.8,4-4v-32h-8v28h-48v-48h28v-8h-32l0,0c-2.2,0-4,1.8-4,4v56C14.8,83.3,16.6,85.1,18.8,85.1z"></path> <polygon fill="currentColor" points="45.7,48.7 51.3,54.3 77.2,28.5 77.2,37.2 85.2,37.2 85.2,14.9 62.8,14.9 62.8,22.9 71.5,22.9"></polygon></svg> <span class="sr-only">(opens new window)</span></span></a>, the execution result of this statement is shown below:</p> <div class="language- line-numbers-mode"><pre class="language-text"><code>+-----------------------------+-------------------------------+
|                         Time|root.sgcc.wf03.wt01.temperature|
+-----------------------------+-------------------------------+
|2017-11-01T16:37:50.000+08:00|                          21.93|
+-----------------------------+-------------------------------+
Total line number = 1
It costs 0.016s
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br><span class="line-number">2</span><br><span class="line-number">3</span><br><span class="line-number">4</span><br><span class="line-number">5</span><br><span class="line-number">6</span><br><span class="line-number">7</span><br></div></div><p>It is worth noting that if there is no value in the specified valid time range, the system will not fill the null value, as shown below:</p> <div class="language- line-numbers-mode"><pre class="language-text"><code>IoTDB&gt; select temperature from root.sgcc.wf03.wt01 where time = 2017-11-01T16:37:50.000 fill(float[previous, 1s]) 
+-----------------------------+-------------------------------+
|                         Time|root.sgcc.wf03.wt01.temperature|
+-----------------------------+-------------------------------+
|2017-11-01T16:37:50.000+08:00|                           null|
+-----------------------------+-------------------------------+
Total line number = 1
It costs 0.004s
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br><span class="line-number">2</span><br><span class="line-number">3</span><br><span class="line-number">4</span><br><span class="line-number">5</span><br><span class="line-number">6</span><br><span class="line-number">7</span><br><span class="line-number">8</span><br></div></div><ul><li>Linear Method</li></ul> <p>When the value of the queried timestamp is null, the value of the previous and the next timestamp is used to fill the blank. The formalized linear method is as follows:</p> <div class="language- line-numbers-mode"><pre class="language-text"><code>select &lt;path&gt; from &lt;prefixPath&gt; where time = &lt;T&gt; fill(&lt;data_type&gt;[linear, &lt;before_range&gt;, &lt;after_range&gt;]…)
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br></div></div><p>Detailed descriptions of all parameters are given in Table 3-5.</p> <center>**Table 3-5 Linear fill paramter list**
<table><thead><tr><th style="text-align:left;">Parameter name (case insensitive)</th> <th style="text-align:left;">Interpretation</th></tr></thead> <tbody><tr><td style="text-align:left;">path, prefixPath</td> <td style="text-align:left;">query path; mandatory field</td></tr> <tr><td style="text-align:left;">T</td> <td style="text-align:left;">query timestamp (only one can be specified); mandatory field</td></tr> <tr><td style="text-align:left;">data_type</td> <td style="text-align:left;">the type of data used by the fill method. Optional values are int32, int64, float, double, boolean, text; optional field</td></tr> <tr><td style="text-align:left;">before_range, after_range</td> <td style="text-align:left;">represents the valid time range of the linear method. The previous method works when there are values in the [T-before_range, T+after_range] range. When before_range and after_range are not explicitly specified, default_fill_interval is used. -1 represents infinity; optional field</td></tr></tbody></table></center> <p><strong>Note</strong> if the timeseries has a valid value at query timestamp T, this value will be used as the linear fill value.
Otherwise, if there is no valid fill value in either range [T-before_range，T] or [T, T + after_range], linear fill method will return null.</p> <p>Here we give an example of filling null values using the linear method. The SQL statement is as follows:</p> <div class="language- line-numbers-mode"><pre class="language-text"><code>select temperature from root.sgcc.wf03.wt01 where time = 2017-11-01T16:37:50.000 fill(float [linear, 1m, 1m])
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br></div></div><p>which means:</p> <p>Because the timeseries root.sgcc.wf03.wt01.temperature is null at 2017-11-01T16:37:50.000, the system uses the previous timestamp 2017-11-01T16:37:00.000 (and the timestamp is in the [2017-11-01T16:36:50.000, 2017-11-01T16:37:50.000] time range) and its value 21.927326, the next timestamp 2017-11-01T16:38:00.000 (and the timestamp is in the [2017-11-01T16:37:50.000, 2017-11-01T16:38:50.000] time range) and its value 25.311783 to perform linear fitting calculation: 21.927326 + (25.311783-21.927326)/60s * 50s = 24.747707</p> <p>On the <a href="https://github.com/thulab/iotdb/files/4438687/OtherMaterial-Sample.Data.txt" target="_blank" rel="noopener noreferrer">sample data<span><svg xmlns="http://www.w3.org/2000/svg" aria-hidden="true" focusable="false" x="0px" y="0px" viewBox="0 0 100 100" width="15" height="15" class="icon outbound"><path fill="currentColor" d="M18.8,85.1h56l0,0c2.2,0,4-1.8,4-4v-32h-8v28h-48v-48h28v-8h-32l0,0c-2.2,0-4,1.8-4,4v56C14.8,83.3,16.6,85.1,18.8,85.1z"></path> <polygon fill="currentColor" points="45.7,48.7 51.3,54.3 77.2,28.5 77.2,37.2 85.2,37.2 85.2,14.9 62.8,14.9 62.8,22.9 71.5,22.9"></polygon></svg> <span class="sr-only">(opens new window)</span></span></a>, the execution result of this statement is shown below:</p> <div class="language- line-numbers-mode"><pre class="language-text"><code>+-----------------------------+-------------------------------+
|                         Time|root.sgcc.wf03.wt01.temperature|
+-----------------------------+-------------------------------+
|2017-11-01T16:37:50.000+08:00|                      24.746666|
+-----------------------------+-------------------------------+
Total line number = 1
It costs 0.017s
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br><span class="line-number">2</span><br><span class="line-number">3</span><br><span class="line-number">4</span><br><span class="line-number">5</span><br><span class="line-number">6</span><br><span class="line-number">7</span><br></div></div><h4 id="correspondence-between-data-type-and-fill-method"><a href="#correspondence-between-data-type-and-fill-method" class="header-anchor">#</a> Correspondence between Data Type and Fill Method</h4> <p>Data types and the supported fill methods are shown in Table 3-6.</p> <center>**Table 3-6 Data types and the supported fill methods**
<table><thead><tr><th style="text-align:left;">Data Type</th> <th style="text-align:left;">Supported Fill Methods</th></tr></thead> <tbody><tr><td style="text-align:left;">boolean</td> <td style="text-align:left;">previous</td></tr> <tr><td style="text-align:left;">int32</td> <td style="text-align:left;">previous, linear</td></tr> <tr><td style="text-align:left;">int64</td> <td style="text-align:left;">previous, linear</td></tr> <tr><td style="text-align:left;">float</td> <td style="text-align:left;">previous, linear</td></tr> <tr><td style="text-align:left;">double</td> <td style="text-align:left;">previous, linear</td></tr> <tr><td style="text-align:left;">text</td> <td style="text-align:left;">previous</td></tr></tbody></table></center> <p>When the fill method is not specified, each data type bears its own default fill methods and parameters. The corresponding relationship is shown in Table 3-7.</p> <center>**Table 3-7 Default fill methods and parameters for various data types**
<table><thead><tr><th style="text-align:left;">Data Type</th> <th style="text-align:left;">Default Fill Methods and Parameters</th></tr></thead> <tbody><tr><td style="text-align:left;">boolean</td> <td style="text-align:left;">previous, 600000</td></tr> <tr><td style="text-align:left;">int32</td> <td style="text-align:left;">previous, 600000</td></tr> <tr><td style="text-align:left;">int64</td> <td style="text-align:left;">previous, 600000</td></tr> <tr><td style="text-align:left;">float</td> <td style="text-align:left;">previous, 600000</td></tr> <tr><td style="text-align:left;">double</td> <td style="text-align:left;">previous, 600000</td></tr> <tr><td style="text-align:left;">text</td> <td style="text-align:left;">previous, 600000</td></tr></tbody></table></center> <blockquote><p>Note: In version 0.7.0, at least one fill method should be specified in the Fill statement.</p></blockquote> <h3 id="row-and-column-control-over-query-results"><a href="#row-and-column-control-over-query-results" class="header-anchor">#</a> Row and Column Control over Query Results</h3> <p>IoTDB provides <a href="/UserGuide/V0.12.x/Appendix/SQL-Reference.html">LIMIT/SLIMIT</a> clause and <a href="/UserGuide/V0.12.x/Appendix/SQL-Reference.html">OFFSET/SOFFSET</a>
clause in order to make users have more control over query results.
The use of LIMIT and SLIMIT clauses allows users to control the number of rows and columns of query results,
and the use of OFFSET and SOFSET clauses allows users to set the starting position of the results for display.</p> <p>Note that the LIMIT and OFFSET are not supported in group by query.</p> <p>This chapter mainly introduces related examples of row and column control of query results. You can also use the <a href="/UserGuide/V0.12.x/API/Programming-JDBC.html">Java JDBC</a> standard interface to execute queries.</p> <h4 id="row-control-over-query-results"><a href="#row-control-over-query-results" class="header-anchor">#</a> Row Control over Query Results</h4> <p>By using LIMIT and OFFSET clauses, users control the query results in a row-related manner. We demonstrate how to use LIMIT and OFFSET clauses through the following examples.</p> <ul><li>Example 1: basic LIMIT clause</li></ul> <p>The SQL statement is:</p> <div class="language- line-numbers-mode"><pre class="language-text"><code>select status, temperature from root.ln.wf01.wt01 limit 10
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br></div></div><p>which means:</p> <p>The selected device is ln group wf01 plant wt01 device; the selected timeseries is &quot;status&quot; and &quot;temperature&quot;. The SQL statement requires the first 10 rows of the query result.</p> <p>The result is shown below:</p> <div class="language- line-numbers-mode"><pre class="language-text"><code>+-----------------------------+------------------------+-----------------------------+
|                         Time|root.ln.wf01.wt01.status|root.ln.wf01.wt01.temperature|
+-----------------------------+------------------------+-----------------------------+
|2017-11-01T00:00:00.000+08:00|                    true|                        25.96|
|2017-11-01T00:01:00.000+08:00|                    true|                        24.36|
|2017-11-01T00:02:00.000+08:00|                   false|                        20.09|
|2017-11-01T00:03:00.000+08:00|                   false|                        20.18|
|2017-11-01T00:04:00.000+08:00|                   false|                        21.13|
|2017-11-01T00:05:00.000+08:00|                   false|                        22.72|
|2017-11-01T00:06:00.000+08:00|                   false|                        20.71|
|2017-11-01T00:07:00.000+08:00|                   false|                        21.45|
|2017-11-01T00:08:00.000+08:00|                   false|                        22.58|
|2017-11-01T00:09:00.000+08:00|                   false|                        20.98|
+-----------------------------+------------------------+-----------------------------+
Total line number = 10
It costs 0.000s
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br><span class="line-number">2</span><br><span class="line-number">3</span><br><span class="line-number">4</span><br><span class="line-number">5</span><br><span class="line-number">6</span><br><span class="line-number">7</span><br><span class="line-number">8</span><br><span class="line-number">9</span><br><span class="line-number">10</span><br><span class="line-number">11</span><br><span class="line-number">12</span><br><span class="line-number">13</span><br><span class="line-number">14</span><br><span class="line-number">15</span><br><span class="line-number">16</span><br></div></div><ul><li>Example 2: LIMIT clause with OFFSET</li></ul> <p>The SQL statement is:</p> <div class="language- line-numbers-mode"><pre class="language-text"><code>select status, temperature from root.ln.wf01.wt01 limit 5 offset 3
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br></div></div><p>which means:</p> <p>The selected device is ln group wf01 plant wt01 device; the selected timeseries is &quot;status&quot; and &quot;temperature&quot;. The SQL statement requires rows 3 to 7 of the query result be returned (with the first row numbered as row 0).</p> <p>The result is shown below:</p> <div class="language- line-numbers-mode"><pre class="language-text"><code>+-----------------------------+------------------------+-----------------------------+
|                         Time|root.ln.wf01.wt01.status|root.ln.wf01.wt01.temperature|
+-----------------------------+------------------------+-----------------------------+
|2017-11-01T00:03:00.000+08:00|                   false|                        20.18|
|2017-11-01T00:04:00.000+08:00|                   false|                        21.13|
|2017-11-01T00:05:00.000+08:00|                   false|                        22.72|
|2017-11-01T00:06:00.000+08:00|                   false|                        20.71|
|2017-11-01T00:07:00.000+08:00|                   false|                        21.45|
+-----------------------------+------------------------+-----------------------------+
Total line number = 5
It costs 0.342s
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br><span class="line-number">2</span><br><span class="line-number">3</span><br><span class="line-number">4</span><br><span class="line-number">5</span><br><span class="line-number">6</span><br><span class="line-number">7</span><br><span class="line-number">8</span><br><span class="line-number">9</span><br><span class="line-number">10</span><br><span class="line-number">11</span><br></div></div><ul><li>Example 3: LIMIT clause combined with WHERE clause</li></ul> <p>The SQL statement is:</p> <div class="language- line-numbers-mode"><pre class="language-text"><code>select status,temperature from root.ln.wf01.wt01 where time &gt; 2017-11-01T00:05:00.000 and time&lt; 2017-11-01T00:12:00.000 limit 2 offset 3
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br></div></div><p>which means:</p> <p>The selected device is ln group wf01 plant wt01 device; the selected timeseries is &quot;status&quot; and &quot;temperature&quot;. The SQL statement requires rows 3 to 4 of  the status and temperature sensor values between the time point of &quot;2017-11-01T00:05:00.000&quot; and &quot;2017-11-01T00:12:00.000&quot; (with the first row numbered as row 0).</p> <p>The result is shown below:</p> <div class="language- line-numbers-mode"><pre class="language-text"><code>+-----------------------------+------------------------+-----------------------------+
|                         Time|root.ln.wf01.wt01.status|root.ln.wf01.wt01.temperature|
+-----------------------------+------------------------+-----------------------------+
|2017-11-01T00:03:00.000+08:00|                   false|                        20.18|
|2017-11-01T00:04:00.000+08:00|                   false|                        21.13|
|2017-11-01T00:05:00.000+08:00|                   false|                        22.72|
|2017-11-01T00:06:00.000+08:00|                   false|                        20.71|
|2017-11-01T00:07:00.000+08:00|                   false|                        21.45|
+-----------------------------+------------------------+-----------------------------+
Total line number = 5
It costs 0.000s
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br><span class="line-number">2</span><br><span class="line-number">3</span><br><span class="line-number">4</span><br><span class="line-number">5</span><br><span class="line-number">6</span><br><span class="line-number">7</span><br><span class="line-number">8</span><br><span class="line-number">9</span><br><span class="line-number">10</span><br><span class="line-number">11</span><br></div></div><ul><li>Example 4: LIMIT clause combined with GROUP BY clause</li></ul> <p>The SQL statement is:</p> <div class="language- line-numbers-mode"><pre class="language-text"><code>select count(status), max_value(temperature) from root.ln.wf01.wt01 group by ([2017-11-01T00:00:00, 2017-11-07T23:00:00),1d) limit 5 offset 3
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br></div></div><p>which means:</p> <p>The SQL statement clause requires rows 3 to 7 of the query result be returned (with the first row numbered as row 0).</p> <p>The result is shown below:</p> <div class="language- line-numbers-mode"><pre class="language-text"><code>+-----------------------------+-------------------------------+----------------------------------------+
|                         Time|count(root.ln.wf01.wt01.status)|max_value(root.ln.wf01.wt01.temperature)|
+-----------------------------+-------------------------------+----------------------------------------+
|2017-11-04T00:00:00.000+08:00|                           1440|                                    26.0|
|2017-11-05T00:00:00.000+08:00|                           1440|                                    26.0|
|2017-11-06T00:00:00.000+08:00|                           1440|                                   25.99|
|2017-11-07T00:00:00.000+08:00|                           1380|                                    26.0|
+-----------------------------+-------------------------------+----------------------------------------+
Total line number = 4
It costs 0.016s
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br><span class="line-number">2</span><br><span class="line-number">3</span><br><span class="line-number">4</span><br><span class="line-number">5</span><br><span class="line-number">6</span><br><span class="line-number">7</span><br><span class="line-number">8</span><br><span class="line-number">9</span><br><span class="line-number">10</span><br></div></div><p>It is worth noting that because the current FILL clause can only fill in the missing value of timeseries at a certain time point, that is to say, the execution result of FILL clause is exactly one line, so LIMIT and OFFSET are not expected to be used in combination with FILL clause, otherwise errors will be prompted. For example, executing the following SQL statement:</p> <div class="language- line-numbers-mode"><pre class="language-text"><code>select temperature from root.sgcc.wf03.wt01 where time = 2017-11-01T16:37:50.000 fill(float[previous, 1m]) limit 10
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br></div></div><p>The SQL statement will not be executed and the corresponding error prompt is given as follows:</p> <div class="language- line-numbers-mode"><pre class="language-text"><code>Msg: 401: line 1:107 mismatched input 'limit' expecting {&lt;EOF&gt;, SLIMIT, SOFFSET, GROUP, DISABLE, ALIGN}
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br></div></div><h4 id="column-control-over-query-results"><a href="#column-control-over-query-results" class="header-anchor">#</a> Column Control over Query Results</h4> <p>By using SLIMIT and SOFFSET clauses, users can control the query results in a column-related manner. We will demonstrate how to use SLIMIT and SOFFSET clauses through the following examples.</p> <ul><li>Example 1: basic SLIMIT clause</li></ul> <p>The SQL statement is:</p> <div class="language- line-numbers-mode"><pre class="language-text"><code>select * from root.ln.wf01.wt01 where time &gt; 2017-11-01T00:05:00.000 and time &lt; 2017-11-01T00:12:00.000 slimit 1
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br></div></div><p>which means:</p> <p>The selected device is ln group wf01 plant wt01 device; the selected timeseries is the first column under this device, i.e., the power supply status. The SQL statement requires the status sensor values between the time point of &quot;2017-11-01T00:05:00.000&quot; and &quot;2017-11-01T00:12:00.000&quot; be selected.</p> <p>The result is shown below:</p> <div class="language- line-numbers-mode"><pre class="language-text"><code>+-----------------------------+-----------------------------+
|                         Time|root.ln.wf01.wt01.temperature|
+-----------------------------+-----------------------------+
|2017-11-01T00:06:00.000+08:00|                        20.71|
|2017-11-01T00:07:00.000+08:00|                        21.45|
|2017-11-01T00:08:00.000+08:00|                        22.58|
|2017-11-01T00:09:00.000+08:00|                        20.98|
|2017-11-01T00:10:00.000+08:00|                        25.52|
|2017-11-01T00:11:00.000+08:00|                        22.91|
+-----------------------------+-----------------------------+
Total line number = 6
It costs 0.000s
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br><span class="line-number">2</span><br><span class="line-number">3</span><br><span class="line-number">4</span><br><span class="line-number">5</span><br><span class="line-number">6</span><br><span class="line-number">7</span><br><span class="line-number">8</span><br><span class="line-number">9</span><br><span class="line-number">10</span><br><span class="line-number">11</span><br><span class="line-number">12</span><br></div></div><ul><li>Example 2: SLIMIT clause with SOFFSET</li></ul> <p>The SQL statement is:</p> <div class="language- line-numbers-mode"><pre class="language-text"><code>select * from root.ln.wf01.wt01 where time &gt; 2017-11-01T00:05:00.000 and time &lt; 2017-11-01T00:12:00.000 slimit 1 soffset 1
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br></div></div><p>which means:</p> <p>The selected device is ln group wf01 plant wt01 device; the selected timeseries is the second column under this device, i.e., the temperature. The SQL statement requires the temperature sensor values between the time point of &quot;2017-11-01T00:05:00.000&quot; and &quot;2017-11-01T00:12:00.000&quot; be selected.</p> <p>The result is shown below:</p> <div class="language- line-numbers-mode"><pre class="language-text"><code>+-----------------------------+------------------------+
|                         Time|root.ln.wf01.wt01.status|
+-----------------------------+------------------------+
|2017-11-01T00:06:00.000+08:00|                   false|
|2017-11-01T00:07:00.000+08:00|                   false|
|2017-11-01T00:08:00.000+08:00|                   false|
|2017-11-01T00:09:00.000+08:00|                   false|
|2017-11-01T00:10:00.000+08:00|                    true|
|2017-11-01T00:11:00.000+08:00|                   false|
+-----------------------------+------------------------+
Total line number = 6
It costs 0.003s
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br><span class="line-number">2</span><br><span class="line-number">3</span><br><span class="line-number">4</span><br><span class="line-number">5</span><br><span class="line-number">6</span><br><span class="line-number">7</span><br><span class="line-number">8</span><br><span class="line-number">9</span><br><span class="line-number">10</span><br><span class="line-number">11</span><br><span class="line-number">12</span><br></div></div><ul><li>Example 3: SLIMIT clause combined with GROUP BY clause</li></ul> <p>The SQL statement is:</p> <div class="language- line-numbers-mode"><pre class="language-text"><code>select max_value(*) from root.ln.wf01.wt01 group by ([2017-11-01T00:00:00, 2017-11-07T23:00:00),1d) slimit 1 soffset 1
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br></div></div><p>The result is shown below:</p> <div class="language- line-numbers-mode"><pre class="language-text"><code>+-----------------------------+-----------------------------------+
|                         Time|max_value(root.ln.wf01.wt01.status)|
+-----------------------------+-----------------------------------+
|2017-11-01T00:00:00.000+08:00|                               true|
|2017-11-02T00:00:00.000+08:00|                               true|
|2017-11-03T00:00:00.000+08:00|                               true|
|2017-11-04T00:00:00.000+08:00|                               true|
|2017-11-05T00:00:00.000+08:00|                               true|
|2017-11-06T00:00:00.000+08:00|                               true|
|2017-11-07T00:00:00.000+08:00|                               true|
+-----------------------------+-----------------------------------+
Total line number = 7
It costs 0.000s
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br><span class="line-number">2</span><br><span class="line-number">3</span><br><span class="line-number">4</span><br><span class="line-number">5</span><br><span class="line-number">6</span><br><span class="line-number">7</span><br><span class="line-number">8</span><br><span class="line-number">9</span><br><span class="line-number">10</span><br><span class="line-number">11</span><br><span class="line-number">12</span><br><span class="line-number">13</span><br></div></div><ul><li>Example 4: SLIMIT clause combined with FILL clause</li></ul> <p>The SQL statement is:</p> <div class="language- line-numbers-mode"><pre class="language-text"><code>select * from root.sgcc.wf03.wt01 where time = 2017-11-01T16:35:00 fill(float[previous, 1m]) slimit 1 soffset 1
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br></div></div><p>which means:</p> <p>The selected device is ln group wf01 plant wt01 device; the selected timeseries is the second column under this device, i.e., the temperature.</p> <p>The result is shown below:</p> <div class="language- line-numbers-mode"><pre class="language-text"><code>+-----------------------------+--------------------------+
|                         Time|root.sgcc.wf03.wt01.status|
+-----------------------------+--------------------------+
|2017-11-01T16:35:00.000+08:00|                      true|
+-----------------------------+--------------------------+
Total line number = 1
It costs 0.007s
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br><span class="line-number">2</span><br><span class="line-number">3</span><br><span class="line-number">4</span><br><span class="line-number">5</span><br><span class="line-number">6</span><br><span class="line-number">7</span><br></div></div><h4 id="row-and-column-control-over-query-results-2"><a href="#row-and-column-control-over-query-results-2" class="header-anchor">#</a> Row and Column Control over Query Results</h4> <p>In addition to row or column control over query results, IoTDB allows users to control both rows and columns of query results. Here is a complete example with both LIMIT clauses and SLIMIT clauses.</p> <p>The SQL statement is:</p> <div class="language- line-numbers-mode"><pre class="language-text"><code>select * from root.ln.wf01.wt01 limit 10 offset 100 slimit 2 soffset 0
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br></div></div><p>which means:</p> <p>The selected device is ln group wf01 plant wt01 device; the selected timeseries is columns 0 to 1 under this device (with the first column numbered as column 0). The SQL statement clause requires rows 100 to 109 of the query result be returned (with the first row numbered as row 0).</p> <p>The result is shown below:</p> <div class="language- line-numbers-mode"><pre class="language-text"><code>+-----------------------------+-----------------------------+------------------------+
|                         Time|root.ln.wf01.wt01.temperature|root.ln.wf01.wt01.status|
+-----------------------------+-----------------------------+------------------------+
|2017-11-01T01:40:00.000+08:00|                        21.19|                   false|
|2017-11-01T01:41:00.000+08:00|                        22.79|                   false|
|2017-11-01T01:42:00.000+08:00|                        22.98|                   false|
|2017-11-01T01:43:00.000+08:00|                        21.52|                   false|
|2017-11-01T01:44:00.000+08:00|                        23.45|                    true|
|2017-11-01T01:45:00.000+08:00|                        24.06|                    true|
|2017-11-01T01:46:00.000+08:00|                         22.6|                   false|
|2017-11-01T01:47:00.000+08:00|                        23.78|                    true|
|2017-11-01T01:48:00.000+08:00|                        24.72|                    true|
|2017-11-01T01:49:00.000+08:00|                        24.68|                    true|
+-----------------------------+-----------------------------+------------------------+
Total line number = 10
It costs 0.009s
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br><span class="line-number">2</span><br><span class="line-number">3</span><br><span class="line-number">4</span><br><span class="line-number">5</span><br><span class="line-number">6</span><br><span class="line-number">7</span><br><span class="line-number">8</span><br><span class="line-number">9</span><br><span class="line-number">10</span><br><span class="line-number">11</span><br><span class="line-number">12</span><br><span class="line-number">13</span><br><span class="line-number">14</span><br><span class="line-number">15</span><br><span class="line-number">16</span><br></div></div><h3 id="use-alias"><a href="#use-alias" class="header-anchor">#</a> Use Alias</h3> <p>Since the unique data model of IoTDB, lots of additional information like device will be carried before each sensor. Sometimes, we want to query just one specific device, then these prefix information show frequently will be redundant in this situation, influencing the analysis of result set. At this time, we can use <code>AS</code> function provided by IoTDB, assign an alias to time series selected in query.</p> <p>For example：</p> <div class="language- line-numbers-mode"><pre class="language-text"><code>select s1 as temperature, s2 as speed from root.ln.wf01.wt01;
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br></div></div><p>The result set is：</p> <table><thead><tr><th>Time</th> <th>temperature</th> <th>speed</th></tr></thead> <tbody><tr><td>...</td> <td>...</td> <td>...</td></tr></tbody></table> <h4 id="other-resultset-format"><a href="#other-resultset-format" class="header-anchor">#</a> Other ResultSet Format</h4> <p>In addition, IoTDB supports two other results set format: 'align by device' and 'disable align'.</p> <p>The 'align by device' indicates that the deviceId is considered as a column. Therefore, there are totally limited columns in the dataset.</p> <p>The SQL statement is:</p> <div class="language- line-numbers-mode"><pre class="language-text"><code>select * from root.ln.* where time &lt;= 2017-11-01T00:01:00 align by device
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br></div></div><p>The result shows below:</p> <div class="language- line-numbers-mode"><pre class="language-text"><code>+-----------------------------+-----------------+-----------+------+--------+
|                         Time|           Device|temperature|status|hardware|
+-----------------------------+-----------------+-----------+------+--------+
|2017-11-01T00:00:00.000+08:00|root.ln.wf01.wt01|      25.96|  true|    null|
|2017-11-01T00:01:00.000+08:00|root.ln.wf01.wt01|      24.36|  true|    null|
|1970-01-01T08:00:00.001+08:00|root.ln.wf02.wt02|       null|  true|      v1|
|1970-01-01T08:00:00.002+08:00|root.ln.wf02.wt02|       null| false|      v2|
|2017-11-01T00:00:00.000+08:00|root.ln.wf02.wt02|       null|  true|      v2|
|2017-11-01T00:01:00.000+08:00|root.ln.wf02.wt02|       null|  true|      v2|
+-----------------------------+-----------------+-----------+------+--------+
Total line number = 6
It costs 0.012s
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br><span class="line-number">2</span><br><span class="line-number">3</span><br><span class="line-number">4</span><br><span class="line-number">5</span><br><span class="line-number">6</span><br><span class="line-number">7</span><br><span class="line-number">8</span><br><span class="line-number">9</span><br><span class="line-number">10</span><br><span class="line-number">11</span><br><span class="line-number">12</span><br></div></div><p>For more syntax description, please read <a href="/UserGuide/V0.12.x/Appendix/SQL-Reference.html">SQL Reference</a>.</p> <p>The 'disable align' indicates that there are 2 columns for each time series in the result set. Disable Align Clause can only be used at the end of a query statement. Disable Align Clause cannot be used with Aggregation, Fill Statements, Group By or Group By Device Statements, but can with Limit Statements. The display principle of the result table is that only when the column (or row) has existing data will the column (or row) be shown, with nonexistent cells being empty.</p> <p>The SQL statement is:</p> <div class="language- line-numbers-mode"><pre class="language-text"><code>select * from root.ln.* where time &lt;= 2017-11-01T00:01:00 disable align
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br></div></div><p>The result shows below:</p> <div class="language- line-numbers-mode"><pre class="language-text"><code>+-----------------------------+--------------------------+-----------------------------+------------------------+-----------------------------+-----------------------------+-----------------------------+------------------------+
|                         Time|root.ln.wf02.wt02.hardware|                         Time|root.ln.wf02.wt02.status|                         Time|root.ln.wf01.wt01.temperature|                         Time|root.ln.wf01.wt01.status|
+-----------------------------+--------------------------+-----------------------------+------------------------+-----------------------------+-----------------------------+-----------------------------+------------------------+
|1970-01-01T08:00:00.001+08:00|                        v1|1970-01-01T08:00:00.001+08:00|                    true|2017-11-01T00:00:00.000+08:00|                        25.96|2017-11-01T00:00:00.000+08:00|                    true|
|1970-01-01T08:00:00.002+08:00|                        v2|1970-01-01T08:00:00.002+08:00|                   false|2017-11-01T00:01:00.000+08:00|                        24.36|2017-11-01T00:01:00.000+08:00|                    true|
|2017-11-01T00:00:00.000+08:00|                        v2|2017-11-01T00:00:00.000+08:00|                    true|                         null|                         null|                         null|                    null|
|2017-11-01T00:01:00.000+08:00|                        v2|2017-11-01T00:01:00.000+08:00|                    true|                         null|                         null|                         null|                    null|
+-----------------------------+--------------------------+-----------------------------+------------------------+-----------------------------+-----------------------------+-----------------------------+------------------------+
Total line number = 4
It costs 0.018s
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br><span class="line-number">2</span><br><span class="line-number">3</span><br><span class="line-number">4</span><br><span class="line-number">5</span><br><span class="line-number">6</span><br><span class="line-number">7</span><br><span class="line-number">8</span><br><span class="line-number">9</span><br><span class="line-number">10</span><br></div></div><p>For more syntax description, please read <a href="/UserGuide/V0.12.x/Appendix/SQL-Reference.html">SQL Reference</a>.</p> <h4 id="error-handling"><a href="#error-handling" class="header-anchor">#</a> Error Handling</h4> <p>If the parameter N/SN of LIMIT/SLIMIT exceeds the size of the result set, IoTDB returns all the results as expected. For example, the query result of the original SQL statement consists of six rows, and we select the first 100 rows through the LIMIT clause:</p> <div class="language- line-numbers-mode"><pre class="language-text"><code>select status,temperature from root.ln.wf01.wt01 where time &gt; 2017-11-01T00:05:00.000 and time &lt; 2017-11-01T00:12:00.000 limit 100
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br></div></div><p>The result is shown below:</p> <div class="language- line-numbers-mode"><pre class="language-text"><code>+-----------------------------+------------------------+-----------------------------+
|                         Time|root.ln.wf01.wt01.status|root.ln.wf01.wt01.temperature|
+-----------------------------+------------------------+-----------------------------+
|2017-11-01T00:06:00.000+08:00|                   false|                        20.71|
|2017-11-01T00:07:00.000+08:00|                   false|                        21.45|
|2017-11-01T00:08:00.000+08:00|                   false|                        22.58|
|2017-11-01T00:09:00.000+08:00|                   false|                        20.98|
|2017-11-01T00:10:00.000+08:00|                    true|                        25.52|
|2017-11-01T00:11:00.000+08:00|                   false|                        22.91|
+-----------------------------+------------------------+-----------------------------+
Total line number = 6
It costs 0.005s
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br><span class="line-number">2</span><br><span class="line-number">3</span><br><span class="line-number">4</span><br><span class="line-number">5</span><br><span class="line-number">6</span><br><span class="line-number">7</span><br><span class="line-number">8</span><br><span class="line-number">9</span><br><span class="line-number">10</span><br><span class="line-number">11</span><br><span class="line-number">12</span><br></div></div><p>If the parameter N/SN of LIMIT/SLIMIT clause exceeds the allowable maximum value (N/SN is of type int32), the system prompts errors. For example, executing the following SQL statement:</p> <div class="language- line-numbers-mode"><pre class="language-text"><code>select status,temperature from root.ln.wf01.wt01 where time &gt; 2017-11-01T00:05:00.000 and time &lt; 2017-11-01T00:12:00.000 limit 1234567890123456789
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br></div></div><p>The SQL statement will not be executed and the corresponding error prompt is given as follows:</p> <div class="language- line-numbers-mode"><pre class="language-text"><code>Msg: 303: check metadata error: Out of range. LIMIT &lt;N&gt;: N should be Int32.
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br></div></div><p>If the parameter N/SN of LIMIT/SLIMIT clause is not a positive intege, the system prompts errors. For example, executing the following SQL statement:</p> <div class="language- line-numbers-mode"><pre class="language-text"><code>select status,temperature from root.ln.wf01.wt01 where time &gt; 2017-11-01T00:05:00.000 and time &lt; 2017-11-01T00:12:00.000 limit 13.1
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br></div></div><p>The SQL statement will not be executed and the corresponding error prompt is given as follows:</p> <div class="language- line-numbers-mode"><pre class="language-text"><code>Msg: 401: line 1:129 mismatched input '.' expecting {&lt;EOF&gt;, SLIMIT, OFFSET, SOFFSET, GROUP, DISABLE, ALIGN}
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br></div></div><p>If the parameter OFFSET of LIMIT clause exceeds the size of the result set, IoTDB will return an empty result set. For example, executing the following SQL statement:</p> <div class="language- line-numbers-mode"><pre class="language-text"><code>select status,temperature from root.ln.wf01.wt01 where time &gt; 2017-11-01T00:05:00.000 and time &lt; 2017-11-01T00:12:00.000 limit 2 offset 6
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br></div></div><p>The result is shown below:</p> <div class="language- line-numbers-mode"><pre class="language-text"><code>+----+------------------------+-----------------------------+
|Time|root.ln.wf01.wt01.status|root.ln.wf01.wt01.temperature|
+----+------------------------+-----------------------------+
+----+------------------------+-----------------------------+
Empty set.
It costs 0.005s
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br><span class="line-number">2</span><br><span class="line-number">3</span><br><span class="line-number">4</span><br><span class="line-number">5</span><br><span class="line-number">6</span><br></div></div><p>If the parameter SOFFSET of SLIMIT clause is not smaller than the number of available timeseries, the system prompts errors. For example, executing the following SQL statement:</p> <div class="language- line-numbers-mode"><pre class="language-text"><code>select * from root.ln.wf01.wt01 where time &gt; 2017-11-01T00:05:00.000 and time &lt; 2017-11-01T00:12:00.000 slimit 1 soffset 2
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br></div></div><p>The SQL statement will not be executed and the corresponding error prompt is given as follows:</p> <div class="language- line-numbers-mode"><pre class="language-text"><code>Msg: 411: Meet error in query process: The value of SOFFSET (2) is equal to or exceeds the number of sequences (2) that can actually be returned.
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br></div></div><h2 id="delete"><a href="#delete" class="header-anchor">#</a> DELETE</h2> <p>Users can delete data that meet the deletion condition in the specified timeseries by using the <a href="/UserGuide/V0.12.x/Appendix/SQL-Reference.html">DELETE statement</a>. When deleting data, users can select one or more timeseries paths, prefix paths, or paths with star  to delete data within a certain time interval.</p> <p>In a JAVA programming environment, you can use the <a href="/UserGuide/V0.12.x/API/Programming-JDBC.html">Java JDBC</a> to execute single or batch UPDATE statements.</p> <h3 id="delete-single-timeseries"><a href="#delete-single-timeseries" class="header-anchor">#</a> Delete Single Timeseries</h3> <p>Taking ln Group as an example, there exists such a usage scenario:</p> <p>The wf02 plant's wt02 device has many segments of errors in its power supply status before 2017-11-01 16:26:00, and the data cannot be analyzed correctly. The erroneous data affected the correlation analysis with other devices. At this point, the data before this time point needs to be deleted. The SQL statement for this operation is</p> <div class="language- line-numbers-mode"><pre class="language-text"><code>delete from root.ln.wf02.wt02.status where time&lt;=2017-11-01T16:26:00;
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br></div></div><p>In case we hope to merely delete the data before 2017-11-01 16:26:00 in the year of 2017, The SQL statement is:</p> <div class="language- line-numbers-mode"><pre class="language-text"><code>delete from root.ln.wf02.wt02.status where time&gt;=2017-01-01T00:00:00 and time&lt;=2017-11-01T16:26:00;
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br></div></div><p>IoTDB supports to delete a range of timeseries points. Users can write SQL expressions as follows to specify the delete interval:</p> <div class="language- line-numbers-mode"><pre class="language-text"><code>delete from root.ln.wf02.wt02.status where time &lt; 10
delete from root.ln.wf02.wt02.status where time &lt;= 10
delete from root.ln.wf02.wt02.status where time &lt; 20 and time &gt; 10
delete from root.ln.wf02.wt02.status where time &lt;= 20 and time &gt;= 10
delete from root.ln.wf02.wt02.status where time &gt; 20
delete from root.ln.wf02.wt02.status where time &gt;= 20
delete from root.ln.wf02.wt02.status where time = 20
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br><span class="line-number">2</span><br><span class="line-number">3</span><br><span class="line-number">4</span><br><span class="line-number">5</span><br><span class="line-number">6</span><br><span class="line-number">7</span><br></div></div><p>Please pay attention that multiple intervals connected by &quot;OR&quot; expression are not supported in delete statement:</p> <div class="language- line-numbers-mode"><pre class="language-text"><code>delete from root.ln.wf02.wt02.status where time &gt; 4 or time &lt; 0
Msg: 303: Check metadata error: For delete statement, where clause can only contain atomic
expressions like : time &gt; XXX, time &lt;= XXX, or two atomic expressions connected by 'AND'
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br><span class="line-number">2</span><br><span class="line-number">3</span><br></div></div><p>If no &quot;where&quot; clause specified in a delete statement, all the data in a timeseries will be deleted.</p> <div class="language- line-numbers-mode"><pre class="language-text"><code>delete from root.ln.wf02.status
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br></div></div><h3 id="delete-multiple-timeseries"><a href="#delete-multiple-timeseries" class="header-anchor">#</a> Delete Multiple Timeseries</h3> <p>If both the power supply status and hardware version of the ln group wf02 plant wt02 device before 2017-11-01 16:26:00 need to be deleted, <a href="/UserGuide/V0.12.x/Data-Concept/Data-Model-and-Terminology.html">the prefix path with broader meaning or the path with star</a> can be used to delete the data. The SQL statement for this operation is:</p> <div class="language- line-numbers-mode"><pre class="language-text"><code>delete from root.ln.wf02.wt02 where time &lt;= 2017-11-01T16:26:00;
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br></div></div><p>or</p> <div class="language- line-numbers-mode"><pre class="language-text"><code>delete from root.ln.wf02.wt02.* where time &lt;= 2017-11-01T16:26:00;
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br></div></div><p>It should be noted that when the deleted path does not exist, IoTDB will give the corresponding error prompt as shown below:</p> <div class="language- line-numbers-mode"><pre class="language-text"><code>IoTDB&gt; delete from root.ln.wf03.wt02.status where time &lt; now()
Msg: TimeSeries does not exist and its data cannot be deleted
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br><span class="line-number">2</span><br></div></div><h2 id="delete-time-partition-experimental"><a href="#delete-time-partition-experimental" class="header-anchor">#</a> Delete Time Partition (experimental)</h2> <p>You may delete all data in a time partition of a storage group using the following grammar:</p> <div class="language- line-numbers-mode"><pre class="language-text"><code>DELETE PARTITION root.ln 0,1,2
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br></div></div><p>The <code>0,1,2</code> above is the id of the partition that is to be deleted, you can find it from the IoTDB
data folders or convert a timestamp manually to an id using <code>timestamp / partitionInterval</code> (flooring), and the <code>partitionInterval</code> should be in your config (if time-partitioning is
supported in your version).</p> <p>Please notice that this function is experimental and mainly for development, please use it with care.</p></div> <div class="page-nav"><p class="inner"><span class="prev">
        ←
        <a href="/UserGuide/V0.12.x/IoTDB-SQL-Language/DDL-Data-Definition-Language.html" class="prev">
          DDL (Data Definition Language)
        </a></span> <span class="next"><a href="/UserGuide/V0.12.x/IoTDB-SQL-Language/Maintenance-Command.html">
          Maintenance Command
        </a>
        →
      </span></p></div> <p style="text-align: center;">Copyright © 2021 The Apache Software Foundation.<br>
     Apache and the Apache feather logo are trademarks of The Apache Software Foundation</p> <p style="text-align: center; margin-top: 10px; color: #444">
    Contact us: Join QQ Group 659990460 | Add friend <i>tietouqiao</i> and be invited to Wechat Group<br>
    see <a href="https://github.com/apache/iotdb/issues/1995">Join the community</a> for more</p></main></div><div class="global-ui"></div></div>
    <script src="/assets/js/app.cd07c2fa.js" defer></script><script src="/assets/js/3.2a42f5e4.js" defer></script><script src="/assets/js/239.16e9e1fe.js" defer></script>
  </body>
</html>