<!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.9.7">
    <link rel="icon" href="/favicon.ico">
    <script async="true" src="https://www.googletagmanager.com/gtag/js?id=G-5MM3J6X84E"></script>
    <script>
          window.dataLayer = window.dataLayer || [];
          function gtag(){dataLayer.push(arguments);}
          gtag('js', new Date());
          gtag('config', 'G-5MM3J6X84E');</script>
    <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.ec12723d.css" as="style"><link rel="preload" href="/assets/js/app.b50138c2.js" as="script"><link rel="preload" href="/assets/js/3.c8384d0b.js" as="script"><link rel="preload" href="/assets/js/276.d8accd8d.js" as="script"><link rel="prefetch" href="/assets/js/10.54d4b62d.js"><link rel="prefetch" href="/assets/js/100.9ee5e815.js"><link rel="prefetch" href="/assets/js/101.247f3c8c.js"><link rel="prefetch" href="/assets/js/102.689f13c2.js"><link rel="prefetch" href="/assets/js/103.f385436b.js"><link rel="prefetch" href="/assets/js/104.ba3433b1.js"><link rel="prefetch" href="/assets/js/105.d32d33c2.js"><link rel="prefetch" href="/assets/js/106.48cd0f80.js"><link rel="prefetch" href="/assets/js/107.285a95ae.js"><link rel="prefetch" href="/assets/js/108.c41abc7f.js"><link rel="prefetch" href="/assets/js/109.8939c8b9.js"><link rel="prefetch" href="/assets/js/11.6822495c.js"><link rel="prefetch" href="/assets/js/110.eaaba716.js"><link rel="prefetch" href="/assets/js/111.fe5861ac.js"><link rel="prefetch" href="/assets/js/112.80af0380.js"><link rel="prefetch" href="/assets/js/113.821e2ec3.js"><link rel="prefetch" href="/assets/js/114.98d9a96e.js"><link rel="prefetch" href="/assets/js/115.4552f7dd.js"><link rel="prefetch" href="/assets/js/116.63d91ab3.js"><link rel="prefetch" href="/assets/js/117.5447b3cc.js"><link rel="prefetch" href="/assets/js/118.f40badef.js"><link rel="prefetch" href="/assets/js/119.b89d624b.js"><link rel="prefetch" href="/assets/js/12.8a5e982c.js"><link rel="prefetch" href="/assets/js/120.9ced553d.js"><link rel="prefetch" href="/assets/js/121.53880ae8.js"><link rel="prefetch" href="/assets/js/122.db980156.js"><link rel="prefetch" href="/assets/js/123.b2c251f7.js"><link rel="prefetch" href="/assets/js/124.f99b2675.js"><link rel="prefetch" href="/assets/js/125.e7a699a7.js"><link rel="prefetch" href="/assets/js/126.d95d93ec.js"><link rel="prefetch" href="/assets/js/127.f553bef7.js"><link rel="prefetch" href="/assets/js/128.10836b63.js"><link rel="prefetch" href="/assets/js/129.cb331dcc.js"><link rel="prefetch" href="/assets/js/13.df40e287.js"><link rel="prefetch" href="/assets/js/130.3e887cf0.js"><link rel="prefetch" href="/assets/js/131.4688eb45.js"><link rel="prefetch" href="/assets/js/132.57c0327b.js"><link rel="prefetch" href="/assets/js/133.126eedaa.js"><link rel="prefetch" href="/assets/js/134.21124960.js"><link rel="prefetch" href="/assets/js/135.831a7759.js"><link rel="prefetch" href="/assets/js/136.cbe5cdef.js"><link rel="prefetch" href="/assets/js/137.096371f3.js"><link rel="prefetch" href="/assets/js/138.f9c759df.js"><link rel="prefetch" href="/assets/js/139.aba5066b.js"><link rel="prefetch" href="/assets/js/14.fb4e8035.js"><link rel="prefetch" href="/assets/js/140.663f20e0.js"><link rel="prefetch" href="/assets/js/141.855c8f40.js"><link rel="prefetch" href="/assets/js/142.1bd2b426.js"><link rel="prefetch" href="/assets/js/143.ba7aed8b.js"><link rel="prefetch" href="/assets/js/144.251c3f56.js"><link rel="prefetch" href="/assets/js/145.a6b496d4.js"><link rel="prefetch" href="/assets/js/146.4638861a.js"><link rel="prefetch" href="/assets/js/147.473a9d0b.js"><link rel="prefetch" href="/assets/js/148.0174f889.js"><link rel="prefetch" href="/assets/js/149.8fd62a47.js"><link rel="prefetch" href="/assets/js/15.6c0fd5c9.js"><link rel="prefetch" href="/assets/js/150.bc30e806.js"><link rel="prefetch" href="/assets/js/151.4d769aa5.js"><link rel="prefetch" href="/assets/js/152.86681e4d.js"><link rel="prefetch" href="/assets/js/153.a94989f4.js"><link rel="prefetch" href="/assets/js/154.4f174bb8.js"><link rel="prefetch" href="/assets/js/155.490d1799.js"><link rel="prefetch" href="/assets/js/156.f75f85d2.js"><link rel="prefetch" href="/assets/js/157.4bbf489f.js"><link rel="prefetch" href="/assets/js/158.3bfa3695.js"><link rel="prefetch" href="/assets/js/159.5fd73c15.js"><link rel="prefetch" href="/assets/js/16.2873cd48.js"><link rel="prefetch" href="/assets/js/160.2c70c50d.js"><link rel="prefetch" href="/assets/js/161.ccde35ff.js"><link rel="prefetch" href="/assets/js/162.c1f22c8b.js"><link rel="prefetch" href="/assets/js/163.c19ee9cd.js"><link rel="prefetch" href="/assets/js/164.9d1843b5.js"><link rel="prefetch" href="/assets/js/165.72a91747.js"><link rel="prefetch" href="/assets/js/166.855e3267.js"><link rel="prefetch" href="/assets/js/167.257d8875.js"><link rel="prefetch" href="/assets/js/168.9d47073f.js"><link rel="prefetch" href="/assets/js/169.bb4611fb.js"><link rel="prefetch" href="/assets/js/17.e18d8f9a.js"><link rel="prefetch" href="/assets/js/170.ea22ca30.js"><link rel="prefetch" href="/assets/js/171.a4bfad03.js"><link rel="prefetch" href="/assets/js/172.3e8a4489.js"><link rel="prefetch" href="/assets/js/173.a504956a.js"><link rel="prefetch" href="/assets/js/174.cd60011a.js"><link rel="prefetch" href="/assets/js/175.c950ecc4.js"><link rel="prefetch" href="/assets/js/176.dae8b98d.js"><link rel="prefetch" href="/assets/js/177.4810fd6d.js"><link rel="prefetch" href="/assets/js/178.1fa88aad.js"><link rel="prefetch" href="/assets/js/179.9f697c5c.js"><link rel="prefetch" href="/assets/js/18.8c2382dd.js"><link rel="prefetch" href="/assets/js/180.4d28f81d.js"><link rel="prefetch" href="/assets/js/181.21e03f4a.js"><link rel="prefetch" href="/assets/js/182.c035e526.js"><link rel="prefetch" href="/assets/js/183.ca7accad.js"><link rel="prefetch" href="/assets/js/184.5a4f2cd1.js"><link rel="prefetch" href="/assets/js/185.c4c1c433.js"><link rel="prefetch" href="/assets/js/186.7f58e483.js"><link rel="prefetch" href="/assets/js/187.a1886fdf.js"><link rel="prefetch" href="/assets/js/188.b97d5e93.js"><link rel="prefetch" href="/assets/js/189.2a08e4b8.js"><link rel="prefetch" href="/assets/js/19.2c7c5f02.js"><link rel="prefetch" href="/assets/js/190.1a609937.js"><link rel="prefetch" href="/assets/js/191.54b47d43.js"><link rel="prefetch" href="/assets/js/192.7c610911.js"><link rel="prefetch" href="/assets/js/193.98f3ebeb.js"><link rel="prefetch" href="/assets/js/194.d071f954.js"><link rel="prefetch" href="/assets/js/195.88fb27d8.js"><link rel="prefetch" href="/assets/js/196.fcf75448.js"><link rel="prefetch" href="/assets/js/197.b24cfb87.js"><link rel="prefetch" href="/assets/js/198.023cc47d.js"><link rel="prefetch" href="/assets/js/199.91421b20.js"><link rel="prefetch" href="/assets/js/20.4e58980a.js"><link rel="prefetch" href="/assets/js/200.a27cbbfd.js"><link rel="prefetch" href="/assets/js/201.174ceff5.js"><link rel="prefetch" href="/assets/js/202.878bfdd3.js"><link rel="prefetch" href="/assets/js/203.f6d8ee50.js"><link rel="prefetch" href="/assets/js/204.a8d6d7f1.js"><link rel="prefetch" href="/assets/js/205.e055b15e.js"><link rel="prefetch" href="/assets/js/206.b5f6aa86.js"><link rel="prefetch" href="/assets/js/207.50a3108e.js"><link rel="prefetch" href="/assets/js/208.b80ccbca.js"><link rel="prefetch" href="/assets/js/209.32832223.js"><link rel="prefetch" href="/assets/js/21.90e2637f.js"><link rel="prefetch" href="/assets/js/210.0bad8463.js"><link rel="prefetch" href="/assets/js/211.1fb06ea5.js"><link rel="prefetch" href="/assets/js/212.ac157127.js"><link rel="prefetch" href="/assets/js/213.46a83982.js"><link rel="prefetch" href="/assets/js/214.0de2e526.js"><link rel="prefetch" href="/assets/js/215.8a3c1199.js"><link rel="prefetch" href="/assets/js/216.5a96b642.js"><link rel="prefetch" href="/assets/js/217.55ab9534.js"><link rel="prefetch" href="/assets/js/218.4f4f975c.js"><link rel="prefetch" href="/assets/js/219.477563e9.js"><link rel="prefetch" href="/assets/js/22.1458fea3.js"><link rel="prefetch" href="/assets/js/220.5716dbc0.js"><link rel="prefetch" href="/assets/js/221.41a504ca.js"><link rel="prefetch" href="/assets/js/222.42fdcad7.js"><link rel="prefetch" href="/assets/js/223.28165874.js"><link rel="prefetch" href="/assets/js/224.24e0b132.js"><link rel="prefetch" href="/assets/js/225.8c20442c.js"><link rel="prefetch" href="/assets/js/226.45f36185.js"><link rel="prefetch" href="/assets/js/227.0d8af83f.js"><link rel="prefetch" href="/assets/js/228.33650a4b.js"><link rel="prefetch" href="/assets/js/229.7f95de35.js"><link rel="prefetch" href="/assets/js/23.13e404e2.js"><link rel="prefetch" href="/assets/js/230.3a690e8f.js"><link rel="prefetch" href="/assets/js/231.d22445c1.js"><link rel="prefetch" href="/assets/js/232.9f184aec.js"><link rel="prefetch" href="/assets/js/233.99e988bd.js"><link rel="prefetch" href="/assets/js/234.14562693.js"><link rel="prefetch" href="/assets/js/235.0f60cf78.js"><link rel="prefetch" href="/assets/js/236.4fdc1862.js"><link rel="prefetch" href="/assets/js/237.2569d0b3.js"><link rel="prefetch" href="/assets/js/238.a8305b1f.js"><link rel="prefetch" href="/assets/js/239.d0b3e05e.js"><link rel="prefetch" href="/assets/js/24.4852a2d6.js"><link rel="prefetch" href="/assets/js/240.2f48571e.js"><link rel="prefetch" href="/assets/js/241.f568040a.js"><link rel="prefetch" href="/assets/js/242.5c04b7f2.js"><link rel="prefetch" href="/assets/js/243.40d56c7f.js"><link rel="prefetch" href="/assets/js/244.eb38b245.js"><link rel="prefetch" href="/assets/js/245.ddba7768.js"><link rel="prefetch" href="/assets/js/246.74aa3ad8.js"><link rel="prefetch" href="/assets/js/247.0a24543f.js"><link rel="prefetch" href="/assets/js/248.29e1fb3d.js"><link rel="prefetch" href="/assets/js/249.f3118773.js"><link rel="prefetch" href="/assets/js/25.a8de5aa1.js"><link rel="prefetch" href="/assets/js/250.4feefbb3.js"><link rel="prefetch" href="/assets/js/251.a97c1396.js"><link rel="prefetch" href="/assets/js/252.6712dc54.js"><link rel="prefetch" href="/assets/js/253.17de3c9b.js"><link rel="prefetch" href="/assets/js/254.77852a13.js"><link rel="prefetch" href="/assets/js/255.a1f2fffc.js"><link rel="prefetch" href="/assets/js/256.4fa2285c.js"><link rel="prefetch" href="/assets/js/257.3cc4b394.js"><link rel="prefetch" href="/assets/js/258.c550ae6d.js"><link rel="prefetch" href="/assets/js/259.9ba628fa.js"><link rel="prefetch" href="/assets/js/26.87d927d5.js"><link rel="prefetch" href="/assets/js/260.43ac8f0c.js"><link rel="prefetch" href="/assets/js/261.9c8eff49.js"><link rel="prefetch" href="/assets/js/262.f2fb1560.js"><link rel="prefetch" href="/assets/js/263.da609b60.js"><link rel="prefetch" href="/assets/js/264.0e560c77.js"><link rel="prefetch" href="/assets/js/265.c8d3a641.js"><link rel="prefetch" href="/assets/js/266.f020b5a4.js"><link rel="prefetch" href="/assets/js/267.3310d39e.js"><link rel="prefetch" href="/assets/js/268.1dab8c7a.js"><link rel="prefetch" href="/assets/js/269.1abb5d15.js"><link rel="prefetch" href="/assets/js/27.cee4ba47.js"><link rel="prefetch" href="/assets/js/270.83e2b221.js"><link rel="prefetch" href="/assets/js/271.cdb5994c.js"><link rel="prefetch" href="/assets/js/272.12e33674.js"><link rel="prefetch" href="/assets/js/273.47cac2b1.js"><link rel="prefetch" href="/assets/js/274.dae98df7.js"><link rel="prefetch" href="/assets/js/275.0e23895a.js"><link rel="prefetch" href="/assets/js/277.d1b684b5.js"><link rel="prefetch" href="/assets/js/278.60b060ba.js"><link rel="prefetch" href="/assets/js/279.50c2f14e.js"><link rel="prefetch" href="/assets/js/28.22eb7233.js"><link rel="prefetch" href="/assets/js/280.d054b828.js"><link rel="prefetch" href="/assets/js/281.6a1b0af7.js"><link rel="prefetch" href="/assets/js/282.0bc37b4f.js"><link rel="prefetch" href="/assets/js/283.2de4d449.js"><link rel="prefetch" href="/assets/js/284.7ec4bc7b.js"><link rel="prefetch" href="/assets/js/285.ee9acdaa.js"><link rel="prefetch" href="/assets/js/286.014b9458.js"><link rel="prefetch" href="/assets/js/287.6d5494dc.js"><link rel="prefetch" href="/assets/js/288.698a890e.js"><link rel="prefetch" href="/assets/js/289.2fcd56e0.js"><link rel="prefetch" href="/assets/js/29.d0a835c2.js"><link rel="prefetch" href="/assets/js/290.fac2d182.js"><link rel="prefetch" href="/assets/js/291.eb505c19.js"><link rel="prefetch" href="/assets/js/292.03aa0255.js"><link rel="prefetch" href="/assets/js/293.9cc740de.js"><link rel="prefetch" href="/assets/js/294.055e5c28.js"><link rel="prefetch" href="/assets/js/295.2c5797fd.js"><link rel="prefetch" href="/assets/js/296.134ce81a.js"><link rel="prefetch" href="/assets/js/297.a3af51ca.js"><link rel="prefetch" href="/assets/js/298.de9a936b.js"><link rel="prefetch" href="/assets/js/299.7650f336.js"><link rel="prefetch" href="/assets/js/30.19aa62af.js"><link rel="prefetch" href="/assets/js/300.dfa6a667.js"><link rel="prefetch" href="/assets/js/301.9e80bfa4.js"><link rel="prefetch" href="/assets/js/302.5f3a07a0.js"><link rel="prefetch" href="/assets/js/303.ebbeebe5.js"><link rel="prefetch" href="/assets/js/304.b8345160.js"><link rel="prefetch" href="/assets/js/305.76714e7f.js"><link rel="prefetch" href="/assets/js/306.5a581530.js"><link rel="prefetch" href="/assets/js/307.e769546c.js"><link rel="prefetch" href="/assets/js/308.2938acba.js"><link rel="prefetch" href="/assets/js/309.382ff2ce.js"><link rel="prefetch" href="/assets/js/31.f0637a85.js"><link rel="prefetch" href="/assets/js/310.b5d8ff1c.js"><link rel="prefetch" href="/assets/js/311.58502fba.js"><link rel="prefetch" href="/assets/js/312.3a8cc92f.js"><link rel="prefetch" href="/assets/js/313.aebeae89.js"><link rel="prefetch" href="/assets/js/314.f04efc57.js"><link rel="prefetch" href="/assets/js/315.fd3c394d.js"><link rel="prefetch" href="/assets/js/316.0876f14a.js"><link rel="prefetch" href="/assets/js/317.a0b79558.js"><link rel="prefetch" href="/assets/js/318.4293fb97.js"><link rel="prefetch" href="/assets/js/319.ec595e88.js"><link rel="prefetch" href="/assets/js/32.e65a244d.js"><link rel="prefetch" href="/assets/js/320.69bf0186.js"><link rel="prefetch" href="/assets/js/321.1ae32f0a.js"><link rel="prefetch" href="/assets/js/322.dc5c8519.js"><link rel="prefetch" href="/assets/js/323.4857c6bd.js"><link rel="prefetch" href="/assets/js/324.97d71b51.js"><link rel="prefetch" href="/assets/js/325.44daac9f.js"><link rel="prefetch" href="/assets/js/326.c5638b8b.js"><link rel="prefetch" href="/assets/js/327.9024940d.js"><link rel="prefetch" href="/assets/js/328.7e76f291.js"><link rel="prefetch" href="/assets/js/329.65a9f1b0.js"><link rel="prefetch" href="/assets/js/33.90366dab.js"><link rel="prefetch" href="/assets/js/330.78a1f197.js"><link rel="prefetch" href="/assets/js/331.1cccdefe.js"><link rel="prefetch" href="/assets/js/332.94edf4a2.js"><link rel="prefetch" href="/assets/js/333.8b6e11c0.js"><link rel="prefetch" href="/assets/js/334.0ae6f29e.js"><link rel="prefetch" href="/assets/js/335.27475a99.js"><link rel="prefetch" href="/assets/js/336.4bb88a3d.js"><link rel="prefetch" href="/assets/js/337.dc497405.js"><link rel="prefetch" href="/assets/js/338.0be01822.js"><link rel="prefetch" href="/assets/js/339.8ea3acb6.js"><link rel="prefetch" href="/assets/js/34.e08df9fb.js"><link rel="prefetch" href="/assets/js/340.751471a6.js"><link rel="prefetch" href="/assets/js/341.892cc4ad.js"><link rel="prefetch" href="/assets/js/342.a3b9944a.js"><link rel="prefetch" href="/assets/js/343.5c5853c1.js"><link rel="prefetch" href="/assets/js/344.d794c307.js"><link rel="prefetch" href="/assets/js/345.8fd9ab0c.js"><link rel="prefetch" href="/assets/js/346.01a0c12f.js"><link rel="prefetch" href="/assets/js/347.38271a9e.js"><link rel="prefetch" href="/assets/js/348.030a67c3.js"><link rel="prefetch" href="/assets/js/349.7a0eb903.js"><link rel="prefetch" href="/assets/js/35.3469233d.js"><link rel="prefetch" href="/assets/js/350.c0931977.js"><link rel="prefetch" href="/assets/js/351.eaab6e69.js"><link rel="prefetch" href="/assets/js/352.f20a54bd.js"><link rel="prefetch" href="/assets/js/353.fbe4609f.js"><link rel="prefetch" href="/assets/js/354.4a955e5a.js"><link rel="prefetch" href="/assets/js/355.62dc842e.js"><link rel="prefetch" href="/assets/js/356.449f4e5a.js"><link rel="prefetch" href="/assets/js/357.78c43e85.js"><link rel="prefetch" href="/assets/js/358.be04d1ac.js"><link rel="prefetch" href="/assets/js/359.793f86bf.js"><link rel="prefetch" href="/assets/js/36.f3281e77.js"><link rel="prefetch" href="/assets/js/360.f3957dd8.js"><link rel="prefetch" href="/assets/js/361.c1580dff.js"><link rel="prefetch" href="/assets/js/362.a58499de.js"><link rel="prefetch" href="/assets/js/363.66ca7fa9.js"><link rel="prefetch" href="/assets/js/364.0f353bb5.js"><link rel="prefetch" href="/assets/js/365.c75f28c8.js"><link rel="prefetch" href="/assets/js/366.280e3a87.js"><link rel="prefetch" href="/assets/js/367.54cc6ead.js"><link rel="prefetch" href="/assets/js/368.361af6be.js"><link rel="prefetch" href="/assets/js/369.244d7389.js"><link rel="prefetch" href="/assets/js/37.0d5e0417.js"><link rel="prefetch" href="/assets/js/370.8ccce4a5.js"><link rel="prefetch" href="/assets/js/371.d71f8d28.js"><link rel="prefetch" href="/assets/js/372.8a0b32ed.js"><link rel="prefetch" href="/assets/js/373.c0dea55a.js"><link rel="prefetch" href="/assets/js/374.338f33e1.js"><link rel="prefetch" href="/assets/js/375.2414e0fe.js"><link rel="prefetch" href="/assets/js/376.ec4b953f.js"><link rel="prefetch" href="/assets/js/377.bffdafa8.js"><link rel="prefetch" href="/assets/js/378.1190248c.js"><link rel="prefetch" href="/assets/js/379.1f41a5f6.js"><link rel="prefetch" href="/assets/js/38.a0c580e8.js"><link rel="prefetch" href="/assets/js/380.85ce301d.js"><link rel="prefetch" href="/assets/js/381.fcdc1c7d.js"><link rel="prefetch" href="/assets/js/382.a8c0b29b.js"><link rel="prefetch" href="/assets/js/383.af25db6e.js"><link rel="prefetch" href="/assets/js/384.96a6a902.js"><link rel="prefetch" href="/assets/js/385.1a46587a.js"><link rel="prefetch" href="/assets/js/386.6d937e06.js"><link rel="prefetch" href="/assets/js/387.0fba07d5.js"><link rel="prefetch" href="/assets/js/388.6e94f8b6.js"><link rel="prefetch" href="/assets/js/389.8e525a30.js"><link rel="prefetch" href="/assets/js/39.67659022.js"><link rel="prefetch" href="/assets/js/390.622b688e.js"><link rel="prefetch" href="/assets/js/391.49ce1fc4.js"><link rel="prefetch" href="/assets/js/392.eb04c5e0.js"><link rel="prefetch" href="/assets/js/393.abc51ca5.js"><link rel="prefetch" href="/assets/js/394.e0576055.js"><link rel="prefetch" href="/assets/js/395.58dbef29.js"><link rel="prefetch" href="/assets/js/396.2fb3450f.js"><link rel="prefetch" href="/assets/js/397.813386e8.js"><link rel="prefetch" href="/assets/js/398.8a26dbce.js"><link rel="prefetch" href="/assets/js/399.d9bedecb.js"><link rel="prefetch" href="/assets/js/4.d36f1b75.js"><link rel="prefetch" href="/assets/js/40.0ecc4770.js"><link rel="prefetch" href="/assets/js/400.20e9d3dc.js"><link rel="prefetch" href="/assets/js/401.ba014588.js"><link rel="prefetch" href="/assets/js/402.8981fbfd.js"><link rel="prefetch" href="/assets/js/403.d5c13dca.js"><link rel="prefetch" href="/assets/js/404.483204ac.js"><link rel="prefetch" href="/assets/js/405.970d4ad6.js"><link rel="prefetch" href="/assets/js/406.c4e068bb.js"><link rel="prefetch" href="/assets/js/407.c0451b7c.js"><link rel="prefetch" href="/assets/js/408.ee5acc9f.js"><link rel="prefetch" href="/assets/js/409.d95ff046.js"><link rel="prefetch" href="/assets/js/41.4f5d71cc.js"><link rel="prefetch" href="/assets/js/410.83ef9f67.js"><link rel="prefetch" href="/assets/js/411.2610103f.js"><link rel="prefetch" href="/assets/js/412.f7829c55.js"><link rel="prefetch" href="/assets/js/413.0fade426.js"><link rel="prefetch" href="/assets/js/414.63a99424.js"><link rel="prefetch" href="/assets/js/415.4934790e.js"><link rel="prefetch" href="/assets/js/416.3cd3d82f.js"><link rel="prefetch" href="/assets/js/417.66125de2.js"><link rel="prefetch" href="/assets/js/418.cd248e9a.js"><link rel="prefetch" href="/assets/js/419.795b57df.js"><link rel="prefetch" href="/assets/js/42.16929c0c.js"><link rel="prefetch" href="/assets/js/420.e44c1a28.js"><link rel="prefetch" href="/assets/js/421.d6110ce3.js"><link rel="prefetch" href="/assets/js/422.e5d813b5.js"><link rel="prefetch" href="/assets/js/423.7df7c271.js"><link rel="prefetch" href="/assets/js/424.38069a78.js"><link rel="prefetch" href="/assets/js/425.15362f4a.js"><link rel="prefetch" href="/assets/js/426.47cb9134.js"><link rel="prefetch" href="/assets/js/427.21a3e724.js"><link rel="prefetch" href="/assets/js/428.0832df5b.js"><link rel="prefetch" href="/assets/js/429.2743346f.js"><link rel="prefetch" href="/assets/js/43.a700504b.js"><link rel="prefetch" href="/assets/js/430.7e8119e6.js"><link rel="prefetch" href="/assets/js/431.e7f93739.js"><link rel="prefetch" href="/assets/js/432.92cdbfb4.js"><link rel="prefetch" href="/assets/js/433.8dfa5beb.js"><link rel="prefetch" href="/assets/js/434.30fd48bb.js"><link rel="prefetch" href="/assets/js/435.e7feb798.js"><link rel="prefetch" href="/assets/js/436.1675d1d1.js"><link rel="prefetch" href="/assets/js/437.f4b2acd5.js"><link rel="prefetch" href="/assets/js/438.b6a75c16.js"><link rel="prefetch" href="/assets/js/439.4adbc584.js"><link rel="prefetch" href="/assets/js/44.8e3d116d.js"><link rel="prefetch" href="/assets/js/440.6a4b2650.js"><link rel="prefetch" href="/assets/js/441.3fd8522c.js"><link rel="prefetch" href="/assets/js/442.2dea0780.js"><link rel="prefetch" href="/assets/js/443.c1893f0c.js"><link rel="prefetch" href="/assets/js/444.b4587c58.js"><link rel="prefetch" href="/assets/js/445.dc3ad557.js"><link rel="prefetch" href="/assets/js/446.17bbb80f.js"><link rel="prefetch" href="/assets/js/447.446d3d4e.js"><link rel="prefetch" href="/assets/js/448.8c919d47.js"><link rel="prefetch" href="/assets/js/449.32035dcb.js"><link rel="prefetch" href="/assets/js/45.c2f47b80.js"><link rel="prefetch" href="/assets/js/450.08d47c7f.js"><link rel="prefetch" href="/assets/js/451.dd8870a3.js"><link rel="prefetch" href="/assets/js/452.af5f30c2.js"><link rel="prefetch" href="/assets/js/453.6d8abda1.js"><link rel="prefetch" href="/assets/js/454.ce889cfd.js"><link rel="prefetch" href="/assets/js/455.465ffe7e.js"><link rel="prefetch" href="/assets/js/456.9844736f.js"><link rel="prefetch" href="/assets/js/457.f88a5b28.js"><link rel="prefetch" href="/assets/js/458.5d17a9f0.js"><link rel="prefetch" href="/assets/js/459.3b77f6c3.js"><link rel="prefetch" href="/assets/js/46.cdde7cab.js"><link rel="prefetch" href="/assets/js/460.8b63452f.js"><link rel="prefetch" href="/assets/js/461.ae76d97b.js"><link rel="prefetch" href="/assets/js/462.97064d36.js"><link rel="prefetch" href="/assets/js/463.368764a9.js"><link rel="prefetch" href="/assets/js/464.370274e9.js"><link rel="prefetch" href="/assets/js/465.08db717a.js"><link rel="prefetch" href="/assets/js/466.2937ee91.js"><link rel="prefetch" href="/assets/js/467.08489299.js"><link rel="prefetch" href="/assets/js/468.97248a91.js"><link rel="prefetch" href="/assets/js/469.bfce5b9a.js"><link rel="prefetch" href="/assets/js/47.6bd453c6.js"><link rel="prefetch" href="/assets/js/470.e173cc7b.js"><link rel="prefetch" href="/assets/js/471.eba4850c.js"><link rel="prefetch" href="/assets/js/472.640fae49.js"><link rel="prefetch" href="/assets/js/473.b55674b3.js"><link rel="prefetch" href="/assets/js/474.4a3b51f2.js"><link rel="prefetch" href="/assets/js/475.d328eaaf.js"><link rel="prefetch" href="/assets/js/476.368e3185.js"><link rel="prefetch" href="/assets/js/477.33e7b216.js"><link rel="prefetch" href="/assets/js/478.931ef2ec.js"><link rel="prefetch" href="/assets/js/479.38cd4cb4.js"><link rel="prefetch" href="/assets/js/48.2536cf0e.js"><link rel="prefetch" href="/assets/js/480.1c491a7f.js"><link rel="prefetch" href="/assets/js/481.c266db00.js"><link rel="prefetch" href="/assets/js/482.b709b637.js"><link rel="prefetch" href="/assets/js/483.73ce49fb.js"><link rel="prefetch" href="/assets/js/484.3852d4b8.js"><link rel="prefetch" href="/assets/js/485.2fdc2824.js"><link rel="prefetch" href="/assets/js/486.543895a2.js"><link rel="prefetch" href="/assets/js/487.67abde68.js"><link rel="prefetch" href="/assets/js/488.689859c5.js"><link rel="prefetch" href="/assets/js/489.f39af758.js"><link rel="prefetch" href="/assets/js/49.d885f906.js"><link rel="prefetch" href="/assets/js/490.166d4d19.js"><link rel="prefetch" href="/assets/js/491.704a92ab.js"><link rel="prefetch" href="/assets/js/492.b60f0611.js"><link rel="prefetch" href="/assets/js/493.7a7189a7.js"><link rel="prefetch" href="/assets/js/494.04bfca5d.js"><link rel="prefetch" href="/assets/js/495.4fcdc113.js"><link rel="prefetch" href="/assets/js/496.68fb923a.js"><link rel="prefetch" href="/assets/js/497.fb3df3f8.js"><link rel="prefetch" href="/assets/js/498.12e8ed9d.js"><link rel="prefetch" href="/assets/js/499.3aca4e19.js"><link rel="prefetch" href="/assets/js/5.3ba0c25b.js"><link rel="prefetch" href="/assets/js/50.9ce15669.js"><link rel="prefetch" href="/assets/js/500.6ddca69f.js"><link rel="prefetch" href="/assets/js/501.4898cc4e.js"><link rel="prefetch" href="/assets/js/502.a9f1b3cf.js"><link rel="prefetch" href="/assets/js/503.4affa726.js"><link rel="prefetch" href="/assets/js/504.f29974d2.js"><link rel="prefetch" href="/assets/js/505.dd0c3e73.js"><link rel="prefetch" href="/assets/js/506.6e06065f.js"><link rel="prefetch" href="/assets/js/507.c881ed29.js"><link rel="prefetch" href="/assets/js/508.017bdef8.js"><link rel="prefetch" href="/assets/js/509.c3d59ef2.js"><link rel="prefetch" href="/assets/js/51.8832b2c5.js"><link rel="prefetch" href="/assets/js/510.9b7f8661.js"><link rel="prefetch" href="/assets/js/511.1c7449c0.js"><link rel="prefetch" href="/assets/js/512.c08e0f28.js"><link rel="prefetch" href="/assets/js/513.52a9c4a9.js"><link rel="prefetch" href="/assets/js/514.f5b0e220.js"><link rel="prefetch" href="/assets/js/515.f4fd20bf.js"><link rel="prefetch" href="/assets/js/516.6b7e112f.js"><link rel="prefetch" href="/assets/js/517.67bc4304.js"><link rel="prefetch" href="/assets/js/518.fd2200e0.js"><link rel="prefetch" href="/assets/js/519.5699b842.js"><link rel="prefetch" href="/assets/js/52.04cb62ae.js"><link rel="prefetch" href="/assets/js/520.72ef6a6c.js"><link rel="prefetch" href="/assets/js/521.5b3d96bc.js"><link rel="prefetch" href="/assets/js/522.bfa44c11.js"><link rel="prefetch" href="/assets/js/523.7a18b56d.js"><link rel="prefetch" href="/assets/js/524.eb67d89f.js"><link rel="prefetch" href="/assets/js/525.c5464a81.js"><link rel="prefetch" href="/assets/js/526.43b6dfb4.js"><link rel="prefetch" href="/assets/js/527.b3e4bfaa.js"><link rel="prefetch" href="/assets/js/528.9f0a4faa.js"><link rel="prefetch" href="/assets/js/529.39e2fa61.js"><link rel="prefetch" href="/assets/js/53.8b373f6d.js"><link rel="prefetch" href="/assets/js/530.53170050.js"><link rel="prefetch" href="/assets/js/531.9b2a5954.js"><link rel="prefetch" href="/assets/js/532.42ff8963.js"><link rel="prefetch" href="/assets/js/533.383995e4.js"><link rel="prefetch" href="/assets/js/534.eefbb066.js"><link rel="prefetch" href="/assets/js/535.d6df0714.js"><link rel="prefetch" href="/assets/js/536.6ac85c7a.js"><link rel="prefetch" href="/assets/js/537.1341ca56.js"><link rel="prefetch" href="/assets/js/538.ea0f2c79.js"><link rel="prefetch" href="/assets/js/539.e868d92c.js"><link rel="prefetch" href="/assets/js/54.8699767b.js"><link rel="prefetch" href="/assets/js/540.b0ef8f49.js"><link rel="prefetch" href="/assets/js/541.af72c721.js"><link rel="prefetch" href="/assets/js/542.0bb657b5.js"><link rel="prefetch" href="/assets/js/543.4a2afee0.js"><link rel="prefetch" href="/assets/js/544.20d0448d.js"><link rel="prefetch" href="/assets/js/545.5da506f2.js"><link rel="prefetch" href="/assets/js/546.9e30d4cc.js"><link rel="prefetch" href="/assets/js/547.422452b4.js"><link rel="prefetch" href="/assets/js/548.92f2cf20.js"><link rel="prefetch" href="/assets/js/549.aa1a3011.js"><link rel="prefetch" href="/assets/js/55.bc30fa15.js"><link rel="prefetch" href="/assets/js/550.eb7d1086.js"><link rel="prefetch" href="/assets/js/551.c2bf0526.js"><link rel="prefetch" href="/assets/js/552.4840fb52.js"><link rel="prefetch" href="/assets/js/553.5b277e2e.js"><link rel="prefetch" href="/assets/js/554.e93e2a67.js"><link rel="prefetch" href="/assets/js/555.6eda9d85.js"><link rel="prefetch" href="/assets/js/556.b41fcd2b.js"><link rel="prefetch" href="/assets/js/557.f46b47e8.js"><link rel="prefetch" href="/assets/js/558.036bac00.js"><link rel="prefetch" href="/assets/js/559.68f6dd96.js"><link rel="prefetch" href="/assets/js/56.f11187db.js"><link rel="prefetch" href="/assets/js/560.826db279.js"><link rel="prefetch" href="/assets/js/561.7c5485ea.js"><link rel="prefetch" href="/assets/js/562.c5400f50.js"><link rel="prefetch" href="/assets/js/563.61d0598b.js"><link rel="prefetch" href="/assets/js/564.90e1c592.js"><link rel="prefetch" href="/assets/js/565.af7e5384.js"><link rel="prefetch" href="/assets/js/566.e7f7adea.js"><link rel="prefetch" href="/assets/js/567.23bbcac4.js"><link rel="prefetch" href="/assets/js/568.1e985a81.js"><link rel="prefetch" href="/assets/js/569.56181958.js"><link rel="prefetch" href="/assets/js/57.137df3e5.js"><link rel="prefetch" href="/assets/js/570.1e261a6a.js"><link rel="prefetch" href="/assets/js/571.c6a53765.js"><link rel="prefetch" href="/assets/js/572.767e2908.js"><link rel="prefetch" href="/assets/js/573.58d5db84.js"><link rel="prefetch" href="/assets/js/574.66a9f969.js"><link rel="prefetch" href="/assets/js/575.33821608.js"><link rel="prefetch" href="/assets/js/576.3f1ab7bc.js"><link rel="prefetch" href="/assets/js/577.8ddf9949.js"><link rel="prefetch" href="/assets/js/578.d192e021.js"><link rel="prefetch" href="/assets/js/579.a9858f3e.js"><link rel="prefetch" href="/assets/js/58.93c8cccb.js"><link rel="prefetch" href="/assets/js/580.a6da57ad.js"><link rel="prefetch" href="/assets/js/581.83da31b1.js"><link rel="prefetch" href="/assets/js/582.1b43bd75.js"><link rel="prefetch" href="/assets/js/583.fe97296b.js"><link rel="prefetch" href="/assets/js/584.599a8b85.js"><link rel="prefetch" href="/assets/js/585.07774e45.js"><link rel="prefetch" href="/assets/js/586.81ac71f0.js"><link rel="prefetch" href="/assets/js/587.5bccc2bf.js"><link rel="prefetch" href="/assets/js/588.30eb91c9.js"><link rel="prefetch" href="/assets/js/589.1a45d81a.js"><link rel="prefetch" href="/assets/js/59.a9de70e6.js"><link rel="prefetch" href="/assets/js/590.a9104ed3.js"><link rel="prefetch" href="/assets/js/591.88dd1661.js"><link rel="prefetch" href="/assets/js/592.a7192a67.js"><link rel="prefetch" href="/assets/js/593.fed12631.js"><link rel="prefetch" href="/assets/js/594.a722d2f6.js"><link rel="prefetch" href="/assets/js/595.738c1bd8.js"><link rel="prefetch" href="/assets/js/596.4020466d.js"><link rel="prefetch" href="/assets/js/597.56af5b4a.js"><link rel="prefetch" href="/assets/js/598.d930a30c.js"><link rel="prefetch" href="/assets/js/599.72beb78e.js"><link rel="prefetch" href="/assets/js/6.204aeb38.js"><link rel="prefetch" href="/assets/js/60.ad70bc67.js"><link rel="prefetch" href="/assets/js/600.fb169052.js"><link rel="prefetch" href="/assets/js/601.ff650b44.js"><link rel="prefetch" href="/assets/js/602.09b6a1a9.js"><link rel="prefetch" href="/assets/js/603.1f4fb6c8.js"><link rel="prefetch" href="/assets/js/604.cff31bfe.js"><link rel="prefetch" href="/assets/js/605.d4ade90d.js"><link rel="prefetch" href="/assets/js/606.a1f5329a.js"><link rel="prefetch" href="/assets/js/607.4fcc8601.js"><link rel="prefetch" href="/assets/js/608.0a707d87.js"><link rel="prefetch" href="/assets/js/609.06489fd9.js"><link rel="prefetch" href="/assets/js/61.9d6e7108.js"><link rel="prefetch" href="/assets/js/610.bf624dcf.js"><link rel="prefetch" href="/assets/js/611.fa123858.js"><link rel="prefetch" href="/assets/js/612.4a758ceb.js"><link rel="prefetch" href="/assets/js/613.344520a0.js"><link rel="prefetch" href="/assets/js/614.2b8481dc.js"><link rel="prefetch" href="/assets/js/615.8ef14671.js"><link rel="prefetch" href="/assets/js/616.ac69b81d.js"><link rel="prefetch" href="/assets/js/617.31957d7c.js"><link rel="prefetch" href="/assets/js/618.d14e30fa.js"><link rel="prefetch" href="/assets/js/619.931d3a23.js"><link rel="prefetch" href="/assets/js/62.856f67f6.js"><link rel="prefetch" href="/assets/js/620.a03e3be7.js"><link rel="prefetch" href="/assets/js/621.5c18f25c.js"><link rel="prefetch" href="/assets/js/622.1996f81c.js"><link rel="prefetch" href="/assets/js/623.d03837cf.js"><link rel="prefetch" href="/assets/js/624.954573da.js"><link rel="prefetch" href="/assets/js/625.5aadb044.js"><link rel="prefetch" href="/assets/js/626.f9927599.js"><link rel="prefetch" href="/assets/js/627.cef173ed.js"><link rel="prefetch" href="/assets/js/628.e1f9dbd9.js"><link rel="prefetch" href="/assets/js/629.56582018.js"><link rel="prefetch" href="/assets/js/63.786a6c19.js"><link rel="prefetch" href="/assets/js/630.be1cbbd3.js"><link rel="prefetch" href="/assets/js/631.fd9a7a31.js"><link rel="prefetch" href="/assets/js/632.2b820956.js"><link rel="prefetch" href="/assets/js/633.93b6d991.js"><link rel="prefetch" href="/assets/js/634.9df24709.js"><link rel="prefetch" href="/assets/js/635.30a0682a.js"><link rel="prefetch" href="/assets/js/636.2c0e1486.js"><link rel="prefetch" href="/assets/js/637.46646815.js"><link rel="prefetch" href="/assets/js/638.f8396b71.js"><link rel="prefetch" href="/assets/js/639.69c70db9.js"><link rel="prefetch" href="/assets/js/64.b437dff8.js"><link rel="prefetch" href="/assets/js/640.d26862b8.js"><link rel="prefetch" href="/assets/js/641.84920c69.js"><link rel="prefetch" href="/assets/js/642.5f1e5b72.js"><link rel="prefetch" href="/assets/js/643.ae6e68c0.js"><link rel="prefetch" href="/assets/js/644.83e349df.js"><link rel="prefetch" href="/assets/js/645.5a50508a.js"><link rel="prefetch" href="/assets/js/646.bca416e4.js"><link rel="prefetch" href="/assets/js/647.b4945441.js"><link rel="prefetch" href="/assets/js/648.2bfec0a5.js"><link rel="prefetch" href="/assets/js/649.71932b8f.js"><link rel="prefetch" href="/assets/js/65.a01b161a.js"><link rel="prefetch" href="/assets/js/650.51553adf.js"><link rel="prefetch" href="/assets/js/651.228de529.js"><link rel="prefetch" href="/assets/js/652.b51e5694.js"><link rel="prefetch" href="/assets/js/653.255b0306.js"><link rel="prefetch" href="/assets/js/654.c5e1a2b7.js"><link rel="prefetch" href="/assets/js/655.abcab299.js"><link rel="prefetch" href="/assets/js/656.3b59857f.js"><link rel="prefetch" href="/assets/js/657.8a667acc.js"><link rel="prefetch" href="/assets/js/658.e6c816b2.js"><link rel="prefetch" href="/assets/js/659.ab9ed7bd.js"><link rel="prefetch" href="/assets/js/66.23678b9e.js"><link rel="prefetch" href="/assets/js/660.d1dbf031.js"><link rel="prefetch" href="/assets/js/661.f4e99aca.js"><link rel="prefetch" href="/assets/js/662.b865d026.js"><link rel="prefetch" href="/assets/js/663.c84d8607.js"><link rel="prefetch" href="/assets/js/664.3c206c47.js"><link rel="prefetch" href="/assets/js/665.9d5ddb6c.js"><link rel="prefetch" href="/assets/js/666.c94f2945.js"><link rel="prefetch" href="/assets/js/667.583af958.js"><link rel="prefetch" href="/assets/js/668.4430b3b5.js"><link rel="prefetch" href="/assets/js/669.7a597abb.js"><link rel="prefetch" href="/assets/js/67.c741527b.js"><link rel="prefetch" href="/assets/js/670.7b1c54fc.js"><link rel="prefetch" href="/assets/js/671.b7823849.js"><link rel="prefetch" href="/assets/js/672.f5aa4af6.js"><link rel="prefetch" href="/assets/js/673.ccd48575.js"><link rel="prefetch" href="/assets/js/674.5e9bbf1c.js"><link rel="prefetch" href="/assets/js/675.d3d8a149.js"><link rel="prefetch" href="/assets/js/676.80e8660b.js"><link rel="prefetch" href="/assets/js/677.bb3d97ef.js"><link rel="prefetch" href="/assets/js/678.194abdf5.js"><link rel="prefetch" href="/assets/js/679.c6fa8d43.js"><link rel="prefetch" href="/assets/js/68.452b67cf.js"><link rel="prefetch" href="/assets/js/680.86daaa90.js"><link rel="prefetch" href="/assets/js/681.5aaf6971.js"><link rel="prefetch" href="/assets/js/682.f5e0cc99.js"><link rel="prefetch" href="/assets/js/683.9410c0c4.js"><link rel="prefetch" href="/assets/js/684.55ef82ea.js"><link rel="prefetch" href="/assets/js/685.6019db7c.js"><link rel="prefetch" href="/assets/js/686.c72a0a8c.js"><link rel="prefetch" href="/assets/js/687.9d3f5333.js"><link rel="prefetch" href="/assets/js/688.f335171b.js"><link rel="prefetch" href="/assets/js/689.f9f8377a.js"><link rel="prefetch" href="/assets/js/69.a475b883.js"><link rel="prefetch" href="/assets/js/690.57c5f803.js"><link rel="prefetch" href="/assets/js/691.87cca991.js"><link rel="prefetch" href="/assets/js/692.b6f976e7.js"><link rel="prefetch" href="/assets/js/693.441e2179.js"><link rel="prefetch" href="/assets/js/694.67f02fe2.js"><link rel="prefetch" href="/assets/js/695.ec441a48.js"><link rel="prefetch" href="/assets/js/696.774ff31b.js"><link rel="prefetch" href="/assets/js/697.ae165ecf.js"><link rel="prefetch" href="/assets/js/698.c511a261.js"><link rel="prefetch" href="/assets/js/699.11700f53.js"><link rel="prefetch" href="/assets/js/7.c348744b.js"><link rel="prefetch" href="/assets/js/70.b8de8c03.js"><link rel="prefetch" href="/assets/js/700.affa7c77.js"><link rel="prefetch" href="/assets/js/701.b9b64300.js"><link rel="prefetch" href="/assets/js/702.058f801a.js"><link rel="prefetch" href="/assets/js/703.e7273c49.js"><link rel="prefetch" href="/assets/js/704.c2f7875d.js"><link rel="prefetch" href="/assets/js/705.25b20b36.js"><link rel="prefetch" href="/assets/js/706.c71c9a37.js"><link rel="prefetch" href="/assets/js/707.490a5cf7.js"><link rel="prefetch" href="/assets/js/708.f88e2b8b.js"><link rel="prefetch" href="/assets/js/709.fec6fe62.js"><link rel="prefetch" href="/assets/js/71.96a6bf65.js"><link rel="prefetch" href="/assets/js/710.e4db1b40.js"><link rel="prefetch" href="/assets/js/711.2c131df9.js"><link rel="prefetch" href="/assets/js/712.c8acbd42.js"><link rel="prefetch" href="/assets/js/713.a78f88e8.js"><link rel="prefetch" href="/assets/js/714.6415b33e.js"><link rel="prefetch" href="/assets/js/715.3843bd5a.js"><link rel="prefetch" href="/assets/js/716.960f527a.js"><link rel="prefetch" href="/assets/js/717.d7094310.js"><link rel="prefetch" href="/assets/js/718.2164543b.js"><link rel="prefetch" href="/assets/js/719.af598f74.js"><link rel="prefetch" href="/assets/js/72.15c5307e.js"><link rel="prefetch" href="/assets/js/720.c1b0b2e3.js"><link rel="prefetch" href="/assets/js/721.3af5c2e4.js"><link rel="prefetch" href="/assets/js/722.d4c2292e.js"><link rel="prefetch" href="/assets/js/723.0014f4ce.js"><link rel="prefetch" href="/assets/js/724.85662bcd.js"><link rel="prefetch" href="/assets/js/725.85ab55f6.js"><link rel="prefetch" href="/assets/js/726.4b7dfd8f.js"><link rel="prefetch" href="/assets/js/727.f563b817.js"><link rel="prefetch" href="/assets/js/728.5efb634b.js"><link rel="prefetch" href="/assets/js/729.e08daed5.js"><link rel="prefetch" href="/assets/js/73.7eed98da.js"><link rel="prefetch" href="/assets/js/730.b43374d6.js"><link rel="prefetch" href="/assets/js/731.f241faa9.js"><link rel="prefetch" href="/assets/js/732.3cf36cfc.js"><link rel="prefetch" href="/assets/js/733.d57dfcea.js"><link rel="prefetch" href="/assets/js/734.def3c919.js"><link rel="prefetch" href="/assets/js/735.af33c0aa.js"><link rel="prefetch" href="/assets/js/736.826456b0.js"><link rel="prefetch" href="/assets/js/737.8af98a87.js"><link rel="prefetch" href="/assets/js/738.1a75adf9.js"><link rel="prefetch" href="/assets/js/739.26fc367d.js"><link rel="prefetch" href="/assets/js/74.a5d4a4c1.js"><link rel="prefetch" href="/assets/js/740.9dac8cc8.js"><link rel="prefetch" href="/assets/js/741.e055c5a7.js"><link rel="prefetch" href="/assets/js/742.4c3501b9.js"><link rel="prefetch" href="/assets/js/743.437f7e8b.js"><link rel="prefetch" href="/assets/js/744.b3da3664.js"><link rel="prefetch" href="/assets/js/745.38727b7f.js"><link rel="prefetch" href="/assets/js/746.b9dabc06.js"><link rel="prefetch" href="/assets/js/747.7272a7af.js"><link rel="prefetch" href="/assets/js/748.8fa5cf71.js"><link rel="prefetch" href="/assets/js/749.ff6aa6db.js"><link rel="prefetch" href="/assets/js/75.7d39aea5.js"><link rel="prefetch" href="/assets/js/750.fed88b50.js"><link rel="prefetch" href="/assets/js/751.15ea5fa9.js"><link rel="prefetch" href="/assets/js/752.3babc9eb.js"><link rel="prefetch" href="/assets/js/753.575a6d6a.js"><link rel="prefetch" href="/assets/js/754.a741a586.js"><link rel="prefetch" href="/assets/js/755.6c074646.js"><link rel="prefetch" href="/assets/js/756.fc41e384.js"><link rel="prefetch" href="/assets/js/757.6d072cd0.js"><link rel="prefetch" href="/assets/js/758.c6157ed3.js"><link rel="prefetch" href="/assets/js/759.059d00a3.js"><link rel="prefetch" href="/assets/js/76.d5475ef4.js"><link rel="prefetch" href="/assets/js/760.e0665123.js"><link rel="prefetch" href="/assets/js/761.1e2d2e09.js"><link rel="prefetch" href="/assets/js/762.36258157.js"><link rel="prefetch" href="/assets/js/763.aa1223b0.js"><link rel="prefetch" href="/assets/js/764.57a757ae.js"><link rel="prefetch" href="/assets/js/765.c1c3c6f6.js"><link rel="prefetch" href="/assets/js/766.8a88f1ae.js"><link rel="prefetch" href="/assets/js/767.8ed8d6a6.js"><link rel="prefetch" href="/assets/js/768.fb097d2e.js"><link rel="prefetch" href="/assets/js/769.ad8f689c.js"><link rel="prefetch" href="/assets/js/77.98264796.js"><link rel="prefetch" href="/assets/js/770.e8b4e0f0.js"><link rel="prefetch" href="/assets/js/771.c2e0d1a2.js"><link rel="prefetch" href="/assets/js/772.ead891a3.js"><link rel="prefetch" href="/assets/js/773.fc5e210d.js"><link rel="prefetch" href="/assets/js/774.524dabd4.js"><link rel="prefetch" href="/assets/js/775.74e50990.js"><link rel="prefetch" href="/assets/js/776.1f122480.js"><link rel="prefetch" href="/assets/js/777.933d5d87.js"><link rel="prefetch" href="/assets/js/778.1e030bdc.js"><link rel="prefetch" href="/assets/js/779.6a315a1d.js"><link rel="prefetch" href="/assets/js/78.f73d513b.js"><link rel="prefetch" href="/assets/js/780.275b733b.js"><link rel="prefetch" href="/assets/js/781.426e2ff6.js"><link rel="prefetch" href="/assets/js/782.8411de92.js"><link rel="prefetch" href="/assets/js/783.6dcf622b.js"><link rel="prefetch" href="/assets/js/784.bc816f7f.js"><link rel="prefetch" href="/assets/js/785.054019d9.js"><link rel="prefetch" href="/assets/js/786.985a3aec.js"><link rel="prefetch" href="/assets/js/787.8d175a71.js"><link rel="prefetch" href="/assets/js/788.bb072760.js"><link rel="prefetch" href="/assets/js/789.a9347f90.js"><link rel="prefetch" href="/assets/js/79.30f7cca0.js"><link rel="prefetch" href="/assets/js/790.77405856.js"><link rel="prefetch" href="/assets/js/791.41d7e347.js"><link rel="prefetch" href="/assets/js/792.4a903e73.js"><link rel="prefetch" href="/assets/js/793.7b37fc0d.js"><link rel="prefetch" href="/assets/js/794.a6b2ee35.js"><link rel="prefetch" href="/assets/js/795.e7e4491b.js"><link rel="prefetch" href="/assets/js/796.de5d5bdf.js"><link rel="prefetch" href="/assets/js/797.7d517d3f.js"><link rel="prefetch" href="/assets/js/798.1a3d96ed.js"><link rel="prefetch" href="/assets/js/799.5caded0a.js"><link rel="prefetch" href="/assets/js/8.d5679e1b.js"><link rel="prefetch" href="/assets/js/80.0af5040a.js"><link rel="prefetch" href="/assets/js/800.560fff5f.js"><link rel="prefetch" href="/assets/js/801.c31f4aed.js"><link rel="prefetch" href="/assets/js/802.090c731b.js"><link rel="prefetch" href="/assets/js/803.8f5819e1.js"><link rel="prefetch" href="/assets/js/804.6cf24595.js"><link rel="prefetch" href="/assets/js/805.896b29b3.js"><link rel="prefetch" href="/assets/js/806.94bced4f.js"><link rel="prefetch" href="/assets/js/807.96741645.js"><link rel="prefetch" href="/assets/js/808.a132a0a9.js"><link rel="prefetch" href="/assets/js/809.f1d17489.js"><link rel="prefetch" href="/assets/js/81.f4b9d93f.js"><link rel="prefetch" href="/assets/js/810.943bf22d.js"><link rel="prefetch" href="/assets/js/811.da9076c5.js"><link rel="prefetch" href="/assets/js/812.7c6d7fa8.js"><link rel="prefetch" href="/assets/js/813.069a00c3.js"><link rel="prefetch" href="/assets/js/814.a77493aa.js"><link rel="prefetch" href="/assets/js/815.4bcc9ce9.js"><link rel="prefetch" href="/assets/js/816.401f270f.js"><link rel="prefetch" href="/assets/js/817.5ef93023.js"><link rel="prefetch" href="/assets/js/818.626950ee.js"><link rel="prefetch" href="/assets/js/819.12ca8226.js"><link rel="prefetch" href="/assets/js/82.ac67beb9.js"><link rel="prefetch" href="/assets/js/820.f05d1281.js"><link rel="prefetch" href="/assets/js/821.9d4d6649.js"><link rel="prefetch" href="/assets/js/822.99b3a795.js"><link rel="prefetch" href="/assets/js/823.2cb4218a.js"><link rel="prefetch" href="/assets/js/824.62c9c363.js"><link rel="prefetch" href="/assets/js/825.e23b91a5.js"><link rel="prefetch" href="/assets/js/826.ec7484bc.js"><link rel="prefetch" href="/assets/js/827.6cfba0b8.js"><link rel="prefetch" href="/assets/js/828.6f23cd6a.js"><link rel="prefetch" href="/assets/js/829.48296824.js"><link rel="prefetch" href="/assets/js/83.fbadea1b.js"><link rel="prefetch" href="/assets/js/830.dbff13cc.js"><link rel="prefetch" href="/assets/js/831.95e1194b.js"><link rel="prefetch" href="/assets/js/832.9f4ae957.js"><link rel="prefetch" href="/assets/js/833.8fd62a39.js"><link rel="prefetch" href="/assets/js/834.ec73aa98.js"><link rel="prefetch" href="/assets/js/835.356f0464.js"><link rel="prefetch" href="/assets/js/836.525c7a8a.js"><link rel="prefetch" href="/assets/js/837.592d3558.js"><link rel="prefetch" href="/assets/js/838.e4f2abad.js"><link rel="prefetch" href="/assets/js/839.ff5c86f4.js"><link rel="prefetch" href="/assets/js/84.b156b13e.js"><link rel="prefetch" href="/assets/js/840.155bb130.js"><link rel="prefetch" href="/assets/js/841.75afc9e0.js"><link rel="prefetch" href="/assets/js/842.04b6ce24.js"><link rel="prefetch" href="/assets/js/843.3ec2cf2e.js"><link rel="prefetch" href="/assets/js/844.ffd121c2.js"><link rel="prefetch" href="/assets/js/845.ea81a834.js"><link rel="prefetch" href="/assets/js/846.078807dd.js"><link rel="prefetch" href="/assets/js/847.73f1fd82.js"><link rel="prefetch" href="/assets/js/848.b8f310bf.js"><link rel="prefetch" href="/assets/js/849.0c4a8f05.js"><link rel="prefetch" href="/assets/js/85.39af612d.js"><link rel="prefetch" href="/assets/js/850.6cc15607.js"><link rel="prefetch" href="/assets/js/851.5c5c8a1f.js"><link rel="prefetch" href="/assets/js/852.0daa11aa.js"><link rel="prefetch" href="/assets/js/853.0d97bbb9.js"><link rel="prefetch" href="/assets/js/854.681b1dab.js"><link rel="prefetch" href="/assets/js/855.a08861e9.js"><link rel="prefetch" href="/assets/js/856.6f95c55f.js"><link rel="prefetch" href="/assets/js/857.964325a8.js"><link rel="prefetch" href="/assets/js/858.0279767c.js"><link rel="prefetch" href="/assets/js/859.0c590ceb.js"><link rel="prefetch" href="/assets/js/86.ed5e07e9.js"><link rel="prefetch" href="/assets/js/860.0ab933bd.js"><link rel="prefetch" href="/assets/js/861.c6353af3.js"><link rel="prefetch" href="/assets/js/862.0e43b79e.js"><link rel="prefetch" href="/assets/js/863.894dba48.js"><link rel="prefetch" href="/assets/js/864.ba231da2.js"><link rel="prefetch" href="/assets/js/865.280c29d3.js"><link rel="prefetch" href="/assets/js/866.0bbc6d2f.js"><link rel="prefetch" href="/assets/js/867.8da18c41.js"><link rel="prefetch" href="/assets/js/868.1325b680.js"><link rel="prefetch" href="/assets/js/869.81bb2475.js"><link rel="prefetch" href="/assets/js/87.63aa5331.js"><link rel="prefetch" href="/assets/js/870.bf37af38.js"><link rel="prefetch" href="/assets/js/88.672e0f46.js"><link rel="prefetch" href="/assets/js/89.787f9168.js"><link rel="prefetch" href="/assets/js/9.2c280511.js"><link rel="prefetch" href="/assets/js/90.f1a381e8.js"><link rel="prefetch" href="/assets/js/91.c2519b5e.js"><link rel="prefetch" href="/assets/js/92.cf63f3f6.js"><link rel="prefetch" href="/assets/js/93.6d4724c3.js"><link rel="prefetch" href="/assets/js/94.030ecdcc.js"><link rel="prefetch" href="/assets/js/95.3617c24d.js"><link rel="prefetch" href="/assets/js/96.4187b406.js"><link rel="prefetch" href="/assets/js/97.0ee734ef.js"><link rel="prefetch" href="/assets/js/98.3d7e542e.js"><link rel="prefetch" href="/assets/js/99.9f6ba677.js"><link rel="prefetch" href="/assets/js/vendors~docsearch.51ef31dd.js">
    <link rel="stylesheet" href="/assets/css/0.styles.ec12723d.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">Documentation</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">latest</a></li><li class="dropdown-item"><!----> <a href="/UserGuide/V0.13.x/QuickStart/QuickStart.html" class="nav-link">v0.13.x</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="https://cwiki.apache.org/confluence/display/IOTDB/System+Design" class="nav-link external">
  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="/Community/About.html" class="nav-link">About</a></li><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/HowToJoin.html" class="nav-link">Become a Contributor</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/HowtoContributeCode.html" class="nav-link">How to Contribute Code</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">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.13.x/API/Programming-Java-Native-API.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.13.x/API/Programming-Java-Native-API.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">Documentation</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">latest</a></li><li class="dropdown-item"><!----> <a href="/UserGuide/V0.13.x/QuickStart/QuickStart.html" class="nav-link">v0.13.x</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="https://cwiki.apache.org/confluence/display/IOTDB/System+Design" class="nav-link external">
  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="/Community/About.html" class="nav-link">About</a></li><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/HowToJoin.html" class="nav-link">Become a Contributor</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/HowtoContributeCode.html" class="nav-link">How to Contribute Code</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">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.13.x/API/Programming-Java-Native-API.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.13.x/API/Programming-Java-Native-API.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 (latest)</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>Syntax Conventions</span> <span class="arrow right"></span></p> <!----></section></li><li><section class="sidebar-group collapsable depth-0"><p class="sidebar-heading open"><span>API</span> <span class="arrow down"></span></p> <ul class="sidebar-links sidebar-group-items"><li><a href="/UserGuide/V0.13.x/API/Programming-Java-Native-API.html" aria-current="page" class="active sidebar-link">Java Native API</a></li><li><a href="/UserGuide/V0.13.x/API/Programming-Python-Native-API.html" class="sidebar-link">Python Native API</a></li><li><a href="/UserGuide/V0.13.x/API/Programming-Cpp-Native-API.html" class="sidebar-link">C++ Native API</a></li><li><a href="/UserGuide/V0.13.x/API/Programming-Go-Native-API.html" class="sidebar-link">Go Native API</a></li><li><a href="/UserGuide/V0.13.x/API/Programming-JDBC.html" class="sidebar-link">JDBC (Not Recommend)</a></li><li><a href="/UserGuide/V0.13.x/API/Programming-MQTT.html" class="sidebar-link">MQTT</a></li><li><a href="/UserGuide/V0.13.x/API/RestService.html" class="sidebar-link">REST API</a></li><li><a href="/UserGuide/V0.13.x/API/Programming-TsFile-API.html" class="sidebar-link">TsFile API</a></li><li><a href="/UserGuide/V0.13.x/API/Status-Codes.html" class="sidebar-link">Status Codes</a></li></ul></section></li><li><section class="sidebar-group collapsable depth-0"><p class="sidebar-heading"><span>Operate Metadata</span> <span class="arrow right"></span></p> <!----></section></li><li><section class="sidebar-group collapsable depth-0"><p class="sidebar-heading"><span>Write and Delete Data</span> <span class="arrow right"></span></p> <!----></section></li><li><section class="sidebar-group collapsable depth-0"><p class="sidebar-heading"><span>Query Data</span> <span class="arrow right"></span></p> <!----></section></li><li><section class="sidebar-group collapsable depth-0"><p class="sidebar-heading"><span>Process Data</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"><span>Maintenance Tools</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>UDF Library</span> <span class="arrow right"></span></p> <!----></section></li><li><section class="sidebar-group collapsable depth-0"><p class="sidebar-heading"><span>Reference</span> <span class="arrow right"></span></p> <!----></section></li></ul> </aside> <main class="page"> <div class="content content__default"><h1 id="java-native-api"><a href="#java-native-api" class="header-anchor">#</a> Java Native API</h1> <h2 id="installation"><a href="#installation" class="header-anchor">#</a> Installation</h2> <h3 id="dependencies"><a href="#dependencies" class="header-anchor">#</a> Dependencies</h3> <ul><li>JDK &gt;= 1.8</li> <li>Maven &gt;= 3.6</li></ul> <h3 id="how-to-install"><a href="#how-to-install" class="header-anchor">#</a> How to install</h3> <p>In root directory:</p> <blockquote><p>mvn clean install -pl session -am -DskipTests</p></blockquote> <h3 id="using-iotdb-java-native-api-with-maven"><a href="#using-iotdb-java-native-api-with-maven" class="header-anchor">#</a> Using IoTDB Java Native API with Maven</h3> <div class="language-xml line-numbers-mode"><pre class="language-xml"><code><span class="token tag"><span class="token tag"><span class="token punctuation">&lt;</span>dependencies</span><span class="token punctuation">&gt;</span></span>
    <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;</span>dependency</span><span class="token punctuation">&gt;</span></span>
      <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;</span>groupId</span><span class="token punctuation">&gt;</span></span>org.apache.iotdb<span class="token tag"><span class="token tag"><span class="token punctuation">&lt;/</span>groupId</span><span class="token punctuation">&gt;</span></span>
      <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;</span>artifactId</span><span class="token punctuation">&gt;</span></span>iotdb-session<span class="token tag"><span class="token tag"><span class="token punctuation">&lt;/</span>artifactId</span><span class="token punctuation">&gt;</span></span>
      <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;</span>version</span><span class="token punctuation">&gt;</span></span>0.13.0-SNAPSHOT<span class="token tag"><span class="token tag"><span class="token punctuation">&lt;/</span>version</span><span class="token punctuation">&gt;</span></span>
    <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;/</span>dependency</span><span class="token punctuation">&gt;</span></span>
<span class="token tag"><span class="token tag"><span class="token punctuation">&lt;/</span>dependencies</span><span class="token punctuation">&gt;</span></span>
</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><h2 id="syntax-description"><a href="#syntax-description" class="header-anchor">#</a> Syntax Description</h2> <ul><li><strong>IoTDB-SQL interface:</strong> The input SQL parameter needs to conform to the <a href="/UserGuide/V0.13.x/Reference/Syntax-Conventions.html">syntax conventions</a> and be escaped for JAVA strings. For example, you need to add a backslash before the double-quotes. (That is: after JAVA escaping, it is consistent with the SQL statement executed on the command line.)</li> <li><strong>Other interfaces:</strong> <ul><li>The node names in path or path prefix as parameter:
<ul><li>The node names which should be escaped by backticks (`) in the SQL statement, and escaping is not required here.</li> <li>The node names enclosed in single or double quotes still need to be enclosed in single or double quotes and must be escaped for JAVA strings.</li> <li>For the <code>checkTimeseriesExists</code> interface, since the IoTDB-SQL interface is called internally, the time-series pathname must be consistent with the SQL syntax conventions and be escaped for JAVA strings.</li></ul></li> <li>Identifiers (such as template names) as parameters: The identifiers which should be escaped by backticks (`) in the SQL statement, and escaping is not required here.</li></ul></li></ul> <h2 id="native-apis"><a href="#native-apis" class="header-anchor">#</a> Native APIs</h2> <p>Here we show the commonly used interfaces and their parameters in the Native API:</p> <h3 id="initialization"><a href="#initialization" class="header-anchor">#</a> Initialization</h3> <ul><li>Initialize a Session</li></ul> <div class="language-java line-numbers-mode"><pre class="language-java"><code><span class="token comment">// use default configuration </span>
session <span class="token operator">=</span> <span class="token keyword">new</span> <span class="token class-name">Session<span class="token punctuation">.</span>Builder</span><span class="token punctuation">.</span><span class="token function">build</span><span class="token punctuation">(</span><span class="token punctuation">)</span><span class="token punctuation">;</span>

<span class="token comment">// initialize with a single node</span>
session <span class="token operator">=</span> 
    <span class="token keyword">new</span> <span class="token class-name">Session<span class="token punctuation">.</span>Builder</span><span class="token punctuation">(</span><span class="token punctuation">)</span>
        <span class="token punctuation">.</span><span class="token function">host</span><span class="token punctuation">(</span><span class="token class-name">String</span> host<span class="token punctuation">)</span>
        <span class="token punctuation">.</span><span class="token function">port</span><span class="token punctuation">(</span><span class="token keyword">int</span> port<span class="token punctuation">)</span>
        <span class="token punctuation">.</span><span class="token function">build</span><span class="token punctuation">(</span><span class="token punctuation">)</span><span class="token punctuation">;</span>

<span class="token comment">// initialize with multiple nodes</span>
session <span class="token operator">=</span> 
    <span class="token keyword">new</span> <span class="token class-name">Session<span class="token punctuation">.</span>Builder</span><span class="token punctuation">(</span><span class="token punctuation">)</span>
        <span class="token punctuation">.</span><span class="token function">nodeUrls</span><span class="token punctuation">(</span><span class="token class-name">List</span><span class="token generics"><span class="token punctuation">&lt;</span><span class="token class-name">String</span><span class="token punctuation">&gt;</span></span> nodeUrls<span class="token punctuation">)</span>
        <span class="token punctuation">.</span><span class="token function">build</span><span class="token punctuation">(</span><span class="token punctuation">)</span><span class="token punctuation">;</span>

<span class="token comment">// other configurations</span>
session <span class="token operator">=</span> 
    <span class="token keyword">new</span> <span class="token class-name">Session<span class="token punctuation">.</span>Builder</span><span class="token punctuation">(</span><span class="token punctuation">)</span>
        <span class="token punctuation">.</span><span class="token function">fetchSize</span><span class="token punctuation">(</span><span class="token keyword">int</span> fetchSize<span class="token punctuation">)</span>
        <span class="token punctuation">.</span><span class="token function">username</span><span class="token punctuation">(</span><span class="token class-name">String</span> username<span class="token punctuation">)</span>
        <span class="token punctuation">.</span><span class="token function">password</span><span class="token punctuation">(</span><span class="token class-name">String</span> password<span class="token punctuation">)</span>
        <span class="token punctuation">.</span><span class="token function">thriftDefaultBufferSize</span><span class="token punctuation">(</span><span class="token keyword">int</span> thriftDefaultBufferSize<span class="token punctuation">)</span>
        <span class="token punctuation">.</span><span class="token function">thriftMaxFrameSize</span><span class="token punctuation">(</span><span class="token keyword">int</span> thriftMaxFrameSize<span class="token punctuation">)</span>
        <span class="token punctuation">.</span><span class="token function">enableCacheLeader</span><span class="token punctuation">(</span><span class="token keyword">boolean</span> enableCacheLeader<span class="token punctuation">)</span>
        <span class="token punctuation">.</span><span class="token function">version</span><span class="token punctuation">(</span><span class="token class-name">Version</span> version<span class="token punctuation">)</span>
        <span class="token punctuation">.</span><span class="token function">build</span><span class="token punctuation">(</span><span class="token punctuation">)</span><span class="token punctuation">;</span>
</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></div></div><p>Version represents the SQL semantic version used by the client, which is used to be compatible with the SQL semantics of 0.12 when upgrading 0.13. The possible values are: <code>V_0_12</code>, <code>V_0_13</code>.</p> <ul><li>Open a Session</li></ul> <div class="language-java line-numbers-mode"><pre class="language-java"><code><span class="token keyword">void</span> <span class="token keyword">open</span><span class="token punctuation">(</span><span class="token punctuation">)</span>
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br></div></div><ul><li>Open a session, with a parameter to specify whether to enable RPC compression</li></ul> <div class="language-java line-numbers-mode"><pre class="language-java"><code><span class="token keyword">void</span> <span class="token keyword">open</span><span class="token punctuation">(</span><span class="token keyword">boolean</span> enableRPCCompression<span class="token punctuation">)</span>
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br></div></div><p>Notice: this RPC compression status of client must comply with that of IoTDB server</p> <ul><li>Close a Session</li></ul> <div class="language-java line-numbers-mode"><pre class="language-java"><code><span class="token keyword">void</span> <span class="token function">close</span><span class="token punctuation">(</span><span class="token punctuation">)</span>
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br></div></div><h3 id="data-definition-interface-ddl-interface"><a href="#data-definition-interface-ddl-interface" class="header-anchor">#</a> Data Definition Interface (DDL Interface)</h3> <h4 id="storage-group-management"><a href="#storage-group-management" class="header-anchor">#</a> Storage Group Management</h4> <ul><li>Set storage group</li></ul> <div class="language-java line-numbers-mode"><pre class="language-java"><code><span class="token keyword">void</span> <span class="token function">setStorageGroup</span><span class="token punctuation">(</span><span class="token class-name">String</span> storageGroupId<span class="token punctuation">)</span>    
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br></div></div><ul><li>Delete one or several storage groups</li></ul> <div class="language-java line-numbers-mode"><pre class="language-java"><code><span class="token keyword">void</span> <span class="token function">deleteStorageGroup</span><span class="token punctuation">(</span><span class="token class-name">String</span> storageGroup<span class="token punctuation">)</span>
<span class="token keyword">void</span> <span class="token function">deleteStorageGroups</span><span class="token punctuation">(</span><span class="token class-name">List</span><span class="token generics"><span class="token punctuation">&lt;</span><span class="token class-name">String</span><span class="token punctuation">&gt;</span></span> storageGroups<span class="token punctuation">)</span>
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br><span class="line-number">2</span><br></div></div><h4 id="timeseries-management"><a href="#timeseries-management" class="header-anchor">#</a> Timeseries Management</h4> <ul><li>Create one or multiple timeseries</li></ul> <div class="language-java line-numbers-mode"><pre class="language-java"><code><span class="token keyword">void</span> <span class="token function">createTimeseries</span><span class="token punctuation">(</span><span class="token class-name">String</span> path<span class="token punctuation">,</span> <span class="token class-name">TSDataType</span> dataType<span class="token punctuation">,</span>
      <span class="token class-name">TSEncoding</span> encoding<span class="token punctuation">,</span> <span class="token class-name">CompressionType</span> compressor<span class="token punctuation">,</span> <span class="token class-name">Map</span><span class="token generics"><span class="token punctuation">&lt;</span><span class="token class-name">String</span><span class="token punctuation">,</span> <span class="token class-name">String</span><span class="token punctuation">&gt;</span></span> props<span class="token punctuation">,</span>
      <span class="token class-name">Map</span><span class="token generics"><span class="token punctuation">&lt;</span><span class="token class-name">String</span><span class="token punctuation">,</span> <span class="token class-name">String</span><span class="token punctuation">&gt;</span></span> tags<span class="token punctuation">,</span> <span class="token class-name">Map</span><span class="token generics"><span class="token punctuation">&lt;</span><span class="token class-name">String</span><span class="token punctuation">,</span> <span class="token class-name">String</span><span class="token punctuation">&gt;</span></span> attributes<span class="token punctuation">,</span> <span class="token class-name">String</span> measurementAlias<span class="token punctuation">)</span>
      
<span class="token keyword">void</span> <span class="token function">createMultiTimeseries</span><span class="token punctuation">(</span><span class="token class-name">List</span><span class="token generics"><span class="token punctuation">&lt;</span><span class="token class-name">String</span><span class="token punctuation">&gt;</span></span> paths<span class="token punctuation">,</span> <span class="token class-name">List</span><span class="token generics"><span class="token punctuation">&lt;</span><span class="token class-name">TSDataType</span><span class="token punctuation">&gt;</span></span> dataTypes<span class="token punctuation">,</span>
      <span class="token class-name">List</span><span class="token generics"><span class="token punctuation">&lt;</span><span class="token class-name">TSEncoding</span><span class="token punctuation">&gt;</span></span> encodings<span class="token punctuation">,</span> <span class="token class-name">List</span><span class="token generics"><span class="token punctuation">&lt;</span><span class="token class-name">CompressionType</span><span class="token punctuation">&gt;</span></span> compressors<span class="token punctuation">,</span>
      <span class="token class-name">List</span><span class="token generics"><span class="token punctuation">&lt;</span><span class="token class-name">Map</span><span class="token punctuation">&lt;</span><span class="token class-name">String</span><span class="token punctuation">,</span> <span class="token class-name">String</span><span class="token punctuation">&gt;</span><span class="token punctuation">&gt;</span></span> propsList<span class="token punctuation">,</span> <span class="token class-name">List</span><span class="token generics"><span class="token punctuation">&lt;</span><span class="token class-name">Map</span><span class="token punctuation">&lt;</span><span class="token class-name">String</span><span class="token punctuation">,</span> <span class="token class-name">String</span><span class="token punctuation">&gt;</span><span class="token punctuation">&gt;</span></span> tagsList<span class="token punctuation">,</span>
      <span class="token class-name">List</span><span class="token generics"><span class="token punctuation">&lt;</span><span class="token class-name">Map</span><span class="token punctuation">&lt;</span><span class="token class-name">String</span><span class="token punctuation">,</span> <span class="token class-name">String</span><span class="token punctuation">&gt;</span><span class="token punctuation">&gt;</span></span> attributesList<span class="token punctuation">,</span> <span class="token class-name">List</span><span class="token generics"><span class="token punctuation">&lt;</span><span class="token class-name">String</span><span class="token punctuation">&gt;</span></span> measurementAliasList<span class="token punctuation">)</span>
</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>Create aligned timeseries</li></ul> <div class="language- line-numbers-mode"><pre class="language-text"><code>void createAlignedTimeseries(String prefixPath, List&lt;String&gt; measurements,
      List&lt;TSDataType&gt; dataTypes, List&lt;TSEncoding&gt; encodings,
      CompressionType compressor, List&lt;String&gt; measurementAliasList);
</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>Attention: Alias of measurements are <strong>not supported</strong> currently.</p> <ul><li>Delete one or several timeseries</li></ul> <div class="language-java line-numbers-mode"><pre class="language-java"><code><span class="token keyword">void</span> <span class="token function">deleteTimeseries</span><span class="token punctuation">(</span><span class="token class-name">String</span> path<span class="token punctuation">)</span>
<span class="token keyword">void</span> <span class="token function">deleteTimeseries</span><span class="token punctuation">(</span><span class="token class-name">List</span><span class="token generics"><span class="token punctuation">&lt;</span><span class="token class-name">String</span><span class="token punctuation">&gt;</span></span> paths<span class="token punctuation">)</span>
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br><span class="line-number">2</span><br></div></div><ul><li>Check whether the specific timeseries exists.</li></ul> <div class="language-java line-numbers-mode"><pre class="language-java"><code><span class="token keyword">boolean</span> <span class="token function">checkTimeseriesExists</span><span class="token punctuation">(</span><span class="token class-name">String</span> path<span class="token punctuation">)</span>
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br></div></div><h4 id="schema-template"><a href="#schema-template" class="header-anchor">#</a> Schema Template</h4> <p>Create a schema template for massive identical devices will help to improve memory performance. You can use Template, InternalNode and MeasurementNode to depict the structure of the template, and use belowed interface to create it inside session.</p> <div class="language-java line-numbers-mode"><pre class="language-java"><code><span class="token keyword">public</span> <span class="token keyword">void</span> <span class="token function">createSchemaTemplate</span><span class="token punctuation">(</span><span class="token class-name">Template</span> template<span class="token punctuation">)</span><span class="token punctuation">;</span>

<span class="token class-name">Class</span> <span class="token class-name">Template</span> <span class="token punctuation">{</span>
    <span class="token keyword">private</span> <span class="token class-name">String</span> name<span class="token punctuation">;</span>
    <span class="token keyword">private</span> <span class="token keyword">boolean</span> directShareTime<span class="token punctuation">;</span>
    <span class="token class-name">Map</span><span class="token generics"><span class="token punctuation">&lt;</span><span class="token class-name">String</span><span class="token punctuation">,</span> <span class="token class-name">Node</span><span class="token punctuation">&gt;</span></span> children<span class="token punctuation">;</span>
    <span class="token keyword">public</span> <span class="token class-name">Template</span><span class="token punctuation">(</span><span class="token class-name">String</span> name<span class="token punctuation">,</span> <span class="token keyword">boolean</span> isShareTime<span class="token punctuation">)</span><span class="token punctuation">;</span>
    
    <span class="token keyword">public</span> <span class="token keyword">void</span> <span class="token function">addToTemplate</span><span class="token punctuation">(</span><span class="token class-name">Node</span> node<span class="token punctuation">)</span><span class="token punctuation">;</span>
    <span class="token keyword">public</span> <span class="token keyword">void</span> <span class="token function">deleteFromTemplate</span><span class="token punctuation">(</span><span class="token class-name">String</span> name<span class="token punctuation">)</span><span class="token punctuation">;</span>
    <span class="token keyword">public</span> <span class="token keyword">void</span> <span class="token function">setShareTime</span><span class="token punctuation">(</span><span class="token keyword">boolean</span> shareTime<span class="token punctuation">)</span><span class="token punctuation">;</span>
<span class="token punctuation">}</span>

<span class="token class-name">Abstract</span> <span class="token class-name">Class</span> <span class="token class-name">Node</span> <span class="token punctuation">{</span>
    <span class="token keyword">private</span> <span class="token class-name">String</span> name<span class="token punctuation">;</span>
    <span class="token keyword">public</span> <span class="token keyword">void</span> <span class="token function">addChild</span><span class="token punctuation">(</span><span class="token class-name">Node</span> node<span class="token punctuation">)</span><span class="token punctuation">;</span>
    <span class="token keyword">public</span> <span class="token keyword">void</span> <span class="token function">deleteChild</span><span class="token punctuation">(</span><span class="token class-name">Node</span> node<span class="token punctuation">)</span><span class="token punctuation">;</span>
<span class="token punctuation">}</span>

<span class="token class-name">Class</span> <span class="token class-name">MeasurementNode</span> <span class="token keyword">extends</span> <span class="token class-name">Node</span> <span class="token punctuation">{</span>
    <span class="token class-name">TSDataType</span> dataType<span class="token punctuation">;</span>
    <span class="token class-name">TSEncoding</span> encoding<span class="token punctuation">;</span>
    <span class="token class-name">CompressionType</span> compressor<span class="token punctuation">;</span>
    <span class="token keyword">public</span> <span class="token class-name">MeasurementNode</span><span class="token punctuation">(</span><span class="token class-name">String</span> name<span class="token punctuation">,</span> 
                           <span class="token class-name">TSDataType</span> dataType<span class="token punctuation">,</span> 
                           <span class="token class-name">TSEncoding</span> encoding<span class="token punctuation">,</span>
                          <span class="token class-name">CompressionType</span> compressor<span class="token punctuation">)</span><span class="token punctuation">;</span>
<span class="token punctuation">}</span>
</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></div></div><p>We strongly suggest you implement templates only with flat-measurement (like object 'flatTemplate' in belowed snippet), since tree-structured template may not be a long-term supported feature in further version of IoTDB.</p> <p>A snippet of using above Method and Class：</p> <div class="language-java line-numbers-mode"><pre class="language-java"><code><span class="token class-name">MeasurementNode</span> nodeX <span class="token operator">=</span> <span class="token keyword">new</span> <span class="token class-name">MeasurementNode</span><span class="token punctuation">(</span><span class="token string">&quot;x&quot;</span><span class="token punctuation">,</span> <span class="token class-name">TSDataType</span><span class="token punctuation">.</span>FLOAT<span class="token punctuation">,</span> <span class="token class-name">TSEncoding</span><span class="token punctuation">.</span>RLE<span class="token punctuation">,</span> <span class="token class-name">CompressionType</span><span class="token punctuation">.</span>SNAPPY<span class="token punctuation">)</span><span class="token punctuation">;</span>
<span class="token class-name">MeasurementNode</span> nodeY <span class="token operator">=</span> <span class="token keyword">new</span> <span class="token class-name">MeasurementNode</span><span class="token punctuation">(</span><span class="token string">&quot;y&quot;</span><span class="token punctuation">,</span> <span class="token class-name">TSDataType</span><span class="token punctuation">.</span>FLOAT<span class="token punctuation">,</span> <span class="token class-name">TSEncoding</span><span class="token punctuation">.</span>RLE<span class="token punctuation">,</span> <span class="token class-name">CompressionType</span><span class="token punctuation">.</span>SNAPPY<span class="token punctuation">)</span><span class="token punctuation">;</span>
<span class="token class-name">MeasurementNode</span> nodeSpeed <span class="token operator">=</span> <span class="token keyword">new</span> <span class="token class-name">MeasurementNode</span><span class="token punctuation">(</span><span class="token string">&quot;speed&quot;</span><span class="token punctuation">,</span> <span class="token class-name">TSDataType</span><span class="token punctuation">.</span>DOUBLE<span class="token punctuation">,</span> <span class="token class-name">TSEncoding</span><span class="token punctuation">.</span>GORILLA<span class="token punctuation">,</span> <span class="token class-name">CompressionType</span><span class="token punctuation">.</span>SNAPPY<span class="token punctuation">)</span><span class="token punctuation">;</span>

<span class="token comment">// This is the template we suggest to implement</span>
<span class="token class-name">Template</span> flatTemplate <span class="token operator">=</span> <span class="token keyword">new</span> <span class="token class-name">Template</span><span class="token punctuation">(</span><span class="token string">&quot;flatTemplate&quot;</span><span class="token punctuation">)</span><span class="token punctuation">;</span>
template<span class="token punctuation">.</span><span class="token function">addToTemplate</span><span class="token punctuation">(</span>nodeX<span class="token punctuation">)</span><span class="token punctuation">;</span>
template<span class="token punctuation">.</span><span class="token function">addToTemplate</span><span class="token punctuation">(</span>nodeY<span class="token punctuation">)</span><span class="token punctuation">;</span>
template<span class="token punctuation">.</span><span class="token function">addToTemplate</span><span class="token punctuation">(</span>nodeSpeed<span class="token punctuation">)</span><span class="token punctuation">;</span>

<span class="token function">createSchemaTemplate</span><span class="token punctuation">(</span>flatTemplate<span class="token punctuation">)</span><span class="token punctuation">;</span>
</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><p>After measurement template created, you can edit the template with belowed APIs.</p> <p>**Attention: **</p> <p><strong>1. templates had been set could not be pruned</strong></p> <p><strong>2. templates will be activated on one node by data points insertion of measurements within the template, or interface <code>createTimeseriesOfSchemaTemplate</code></strong></p> <p><strong>3. templates will not be shown by showtimeseries before activated</strong></p> <div class="language-java line-numbers-mode"><pre class="language-java"><code><span class="token comment">// Add aligned measurements to a template</span>
<span class="token keyword">public</span> <span class="token keyword">void</span> <span class="token function">addAlignedMeasurementsInTemplate</span><span class="token punctuation">(</span><span class="token class-name">String</span> templateName<span class="token punctuation">,</span>
    						  <span class="token class-name">String</span><span class="token punctuation">[</span><span class="token punctuation">]</span> measurementsPath<span class="token punctuation">,</span>
                              <span class="token class-name">TSDataType</span><span class="token punctuation">[</span><span class="token punctuation">]</span> dataTypes<span class="token punctuation">,</span>
                              <span class="token class-name">TSEncoding</span><span class="token punctuation">[</span><span class="token punctuation">]</span> encodings<span class="token punctuation">,</span>
                              <span class="token class-name">CompressionType</span><span class="token punctuation">[</span><span class="token punctuation">]</span> compressors<span class="token punctuation">)</span><span class="token punctuation">;</span>

<span class="token comment">// Add one aligned measurement to a template</span>
<span class="token keyword">public</span> <span class="token keyword">void</span> <span class="token function">addAlignedMeasurementInTemplate</span><span class="token punctuation">(</span><span class="token class-name">String</span> templateName<span class="token punctuation">,</span>
                                <span class="token class-name">String</span> measurementPath<span class="token punctuation">,</span>
                                <span class="token class-name">TSDataType</span> dataType<span class="token punctuation">,</span>
                                <span class="token class-name">TSEncoding</span> encoding<span class="token punctuation">,</span>
                                <span class="token class-name">CompressionType</span> compressor<span class="token punctuation">)</span><span class="token punctuation">;</span>


<span class="token comment">// Add unaligned measurements to a template</span>
<span class="token keyword">public</span> <span class="token keyword">void</span> <span class="token function">addUnalignedMeasurementInTemplate</span><span class="token punctuation">(</span><span class="token class-name">String</span> templateName<span class="token punctuation">,</span>
                                <span class="token class-name">String</span> measurementPath<span class="token punctuation">,</span>
                                <span class="token class-name">TSDataType</span> dataType<span class="token punctuation">,</span>
                                <span class="token class-name">TSEncoding</span> encoding<span class="token punctuation">,</span>
                                <span class="token class-name">CompressionType</span> compressor<span class="token punctuation">)</span><span class="token punctuation">;</span>
                                
<span class="token comment">// Add one unaligned measurement to a template</span>
<span class="token keyword">public</span> <span class="token keyword">void</span> <span class="token function">addUnalignedMeasurementsIntemplate</span><span class="token punctuation">(</span><span class="token class-name">String</span> templateName<span class="token punctuation">,</span>
                                <span class="token class-name">String</span><span class="token punctuation">[</span><span class="token punctuation">]</span> measurementPaths<span class="token punctuation">,</span>
                                <span class="token class-name">TSDataType</span><span class="token punctuation">[</span><span class="token punctuation">]</span> dataTypes<span class="token punctuation">,</span>
                                <span class="token class-name">TSEncoding</span><span class="token punctuation">[</span><span class="token punctuation">]</span> encodings<span class="token punctuation">,</span>
                                <span class="token class-name">CompressionType</span><span class="token punctuation">[</span><span class="token punctuation">]</span> compressors<span class="token punctuation">)</span><span class="token punctuation">;</span>

<span class="token comment">// Delete a node in template</span>
<span class="token keyword">public</span> <span class="token keyword">void</span> <span class="token function">deleteNodeInTemplate</span><span class="token punctuation">(</span><span class="token class-name">String</span> templateName<span class="token punctuation">,</span> <span class="token class-name">String</span> path<span class="token punctuation">)</span><span class="token punctuation">;</span>
</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></div></div><p>You can query measurement inside templates with these APIS:</p> <div class="language-java line-numbers-mode"><pre class="language-java"><code><span class="token comment">// Return the amount of measurements inside a template</span>
<span class="token keyword">public</span> <span class="token keyword">int</span> <span class="token function">countMeasurementsInTemplate</span><span class="token punctuation">(</span><span class="token class-name">String</span> templateName<span class="token punctuation">)</span><span class="token punctuation">;</span>

<span class="token comment">// Return true if path points to a measurement, otherwise returne false</span>
<span class="token keyword">public</span> <span class="token keyword">boolean</span> <span class="token function">isMeasurementInTemplate</span><span class="token punctuation">(</span><span class="token class-name">String</span> templateName<span class="token punctuation">,</span> <span class="token class-name">String</span> path<span class="token punctuation">)</span><span class="token punctuation">;</span>

<span class="token comment">// Return true if path exists in template, otherwise return false</span>
<span class="token keyword">public</span> <span class="token keyword">boolean</span> <span class="token function">isPathExistInTemplate</span><span class="token punctuation">(</span><span class="token class-name">String</span> templateName<span class="token punctuation">,</span> <span class="token class-name">String</span> path<span class="token punctuation">)</span><span class="token punctuation">;</span>

<span class="token comment">// Return all measurements paths inside template</span>
<span class="token keyword">public</span> <span class="token class-name">List</span><span class="token generics"><span class="token punctuation">&lt;</span><span class="token class-name">String</span><span class="token punctuation">&gt;</span></span> <span class="token function">showMeasurementsInTemplate</span><span class="token punctuation">(</span><span class="token class-name">String</span> templateName<span class="token punctuation">)</span><span class="token punctuation">;</span>

<span class="token comment">// Return all measurements paths under the designated patter inside template</span>
<span class="token keyword">public</span> <span class="token class-name">List</span><span class="token generics"><span class="token punctuation">&lt;</span><span class="token class-name">String</span><span class="token punctuation">&gt;</span></span> <span class="token function">showMeasurementsInTemplate</span><span class="token punctuation">(</span><span class="token class-name">String</span> templateName<span class="token punctuation">,</span> <span class="token class-name">String</span> pattern<span class="token punctuation">)</span><span class="token punctuation">;</span>
</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><p>To implement schema template, you can set the template named <code>templateName</code> at path <code>prefixPath</code>.</p> <p><strong>Please notice that, we strongly recommend not setting templates on the nodes above the storage group to accommodate future updates and collaboration between modules.</strong></p> <div class="language-java line-numbers-mode"><pre class="language-java"><code><span class="token keyword">void</span> <span class="token function">setSchemaTemplate</span><span class="token punctuation">(</span><span class="token class-name">String</span> templateName<span class="token punctuation">,</span> <span class="token class-name">String</span> prefixPath<span class="token punctuation">)</span><span class="token punctuation">;</span>
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br></div></div><p>Before setting template, you should first create the template using</p> <div class="language-java line-numbers-mode"><pre class="language-java"><code><span class="token keyword">void</span> <span class="token function">createSchemaTemplate</span><span class="token punctuation">(</span><span class="token class-name">Template</span> template<span class="token punctuation">)</span><span class="token punctuation">;</span>
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br></div></div><p>After setting template to a certain path, you can query for info about template using belowed interface in session:</p> <div class="language-java line-numbers-mode"><pre class="language-java"><code><span class="token comment">/** @return All template names. */</span>
<span class="token keyword">public</span> <span class="token class-name">List</span><span class="token generics"><span class="token punctuation">&lt;</span><span class="token class-name">String</span><span class="token punctuation">&gt;</span></span> <span class="token function">showAllTemplates</span><span class="token punctuation">(</span><span class="token punctuation">)</span><span class="token punctuation">;</span>

<span class="token comment">/** @return All paths have been set to designated template. */</span>
<span class="token keyword">public</span> <span class="token class-name">List</span><span class="token generics"><span class="token punctuation">&lt;</span><span class="token class-name">String</span><span class="token punctuation">&gt;</span></span> <span class="token function">showPathsTemplateSetOn</span><span class="token punctuation">(</span><span class="token class-name">String</span> templateName<span class="token punctuation">)</span><span class="token punctuation">;</span>

<span class="token comment">/** @return All paths are using designated template. */</span>
<span class="token keyword">public</span> <span class="token class-name">List</span><span class="token generics"><span class="token punctuation">&lt;</span><span class="token class-name">String</span><span class="token punctuation">&gt;</span></span> <span class="token function">showPathsTemplateUsingOn</span><span class="token punctuation">(</span><span class="token class-name">String</span> templateName<span class="token punctuation">)</span>
</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>If you are ready to get rid of schema template, you can drop it with belowed interface. Make sure the template to drop has been unset from MTree.</p> <div class="language-java line-numbers-mode"><pre class="language-java"><code><span class="token keyword">void</span> <span class="token function">unsetSchemaTemplate</span><span class="token punctuation">(</span><span class="token class-name">String</span> prefixPath<span class="token punctuation">,</span> <span class="token class-name">String</span> templateName<span class="token punctuation">)</span><span class="token punctuation">;</span>
<span class="token keyword">public</span> <span class="token keyword">void</span> <span class="token function">dropSchemaTemplate</span><span class="token punctuation">(</span><span class="token class-name">String</span> templateName<span class="token punctuation">)</span><span class="token punctuation">;</span>
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br><span class="line-number">2</span><br></div></div><p>Unset the measurement template named <code>templateName</code> from path <code>prefixPath</code>. When you issue this interface, you should assure that there is such a template set at the path.</p> <p>If the template had been activated on one node, you should deactivate from it using the interface:</p> <div class="language-java line-numbers-mode"><pre class="language-java"><code><span class="token keyword">public</span> <span class="token keyword">void</span> <span class="token function">deactivateTemplateOn</span><span class="token punctuation">(</span><span class="token class-name">String</span> templateName<span class="token punctuation">,</span> <span class="token class-name">String</span> prefixPath<span class="token punctuation">)</span><span class="token punctuation">;</span>
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br></div></div><p>The passing in <code>prefixPath</code> is a literal path without wildcard(<code>*</code>or<code>**</code>), or a PathPattern to denote paths match the pattern.</p> <p>The deactivation of the template will delete the data of the timeseries which is under the path of concatenation of path of the node and the measurements inside the activatede template.</p> <h3 id="data-manipulation-interface-dml-interface"><a href="#data-manipulation-interface-dml-interface" class="header-anchor">#</a> Data Manipulation Interface (DML Interface)</h3> <h5 id="insert"><a href="#insert" class="header-anchor">#</a> Insert</h5> <p>It is recommended to use insertTablet to help improve write efficiency.</p> <ul><li>Insert a Tablet，which is multiple rows of a device, each row has the same measurements
<ul><li><strong>Better Write Performance</strong></li> <li><strong>Support null values</strong>: fill the null value with any value, and then mark the null value via BitMap</li></ul></li></ul> <div class="language-java line-numbers-mode"><pre class="language-java"><code><span class="token keyword">void</span> <span class="token function">insertTablet</span><span class="token punctuation">(</span><span class="token class-name">Tablet</span> tablet<span class="token punctuation">)</span>

<span class="token keyword">public</span> <span class="token keyword">class</span> <span class="token class-name">Tablet</span> <span class="token punctuation">{</span>
  <span class="token comment">/** deviceId of this tablet */</span>
  <span class="token keyword">public</span> <span class="token class-name">String</span> prefixPath<span class="token punctuation">;</span>
  <span class="token comment">/** the list of measurement schemas for creating the tablet */</span>
  <span class="token keyword">private</span> <span class="token class-name">List</span><span class="token generics"><span class="token punctuation">&lt;</span><span class="token class-name">MeasurementSchema</span><span class="token punctuation">&gt;</span></span> schemas<span class="token punctuation">;</span>
  <span class="token comment">/** timestamps in this tablet */</span>
  <span class="token keyword">public</span> <span class="token keyword">long</span><span class="token punctuation">[</span><span class="token punctuation">]</span> timestamps<span class="token punctuation">;</span>
  <span class="token comment">/** each object is a primitive type array, which represents values of one measurement */</span>
  <span class="token keyword">public</span> <span class="token class-name">Object</span><span class="token punctuation">[</span><span class="token punctuation">]</span> values<span class="token punctuation">;</span>
  <span class="token comment">/** each bitmap represents the existence of each value in the current column. */</span>
  <span class="token keyword">public</span> <span class="token class-name">BitMap</span><span class="token punctuation">[</span><span class="token punctuation">]</span> bitMaps<span class="token punctuation">;</span>
  <span class="token comment">/** the number of rows to include in this tablet */</span>
  <span class="token keyword">public</span> <span class="token keyword">int</span> rowSize<span class="token punctuation">;</span>
  <span class="token comment">/** the maximum number of rows for this tablet */</span>
  <span class="token keyword">private</span> <span class="token keyword">int</span> maxRowNumber<span class="token punctuation">;</span>
  <span class="token comment">/** whether this tablet store data of aligned timeseries or not */</span>
  <span class="token keyword">private</span> <span class="token keyword">boolean</span> isAligned<span class="token punctuation">;</span>
<span class="token punctuation">}</span>
</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></div></div><ul><li>Insert multiple Tablets</li></ul> <div class="language-java line-numbers-mode"><pre class="language-java"><code><span class="token keyword">void</span> <span class="token function">insertTablets</span><span class="token punctuation">(</span><span class="token class-name">Map</span><span class="token generics"><span class="token punctuation">&lt;</span><span class="token class-name">String</span><span class="token punctuation">,</span> <span class="token class-name">Tablet</span><span class="token punctuation">&gt;</span></span> tablet<span class="token punctuation">)</span>
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br></div></div><ul><li><p>Insert a Record, which contains multiple measurement value of a device at a timestamp. This method is equivalent to providing a common interface for multiple data types of values. Later, the value can be cast to the original type through TSDataType.</p> <p>The correspondence between the Object type and the TSDataType type is shown in the following table.</p> <table><thead><tr><th>TSDataType</th> <th>Object</th></tr></thead> <tbody><tr><td>BOOLEAN</td> <td>Boolean</td></tr> <tr><td>INT32</td> <td>Integer</td></tr> <tr><td>INT64</td> <td>Long</td></tr> <tr><td>FLOAT</td> <td>Float</td></tr> <tr><td>DOUBLE</td> <td>Double</td></tr> <tr><td>TEXT</td> <td>String, Binary</td></tr></tbody></table></li></ul> <div class="language-java line-numbers-mode"><pre class="language-java"><code><span class="token keyword">void</span> <span class="token function">insertRecord</span><span class="token punctuation">(</span><span class="token class-name">String</span> deviceId<span class="token punctuation">,</span> <span class="token keyword">long</span> time<span class="token punctuation">,</span> <span class="token class-name">List</span><span class="token generics"><span class="token punctuation">&lt;</span><span class="token class-name">String</span><span class="token punctuation">&gt;</span></span> measurements<span class="token punctuation">,</span>
   <span class="token class-name">List</span><span class="token generics"><span class="token punctuation">&lt;</span><span class="token class-name">TSDataType</span><span class="token punctuation">&gt;</span></span> types<span class="token punctuation">,</span> <span class="token class-name">List</span><span class="token generics"><span class="token punctuation">&lt;</span><span class="token class-name">Object</span><span class="token punctuation">&gt;</span></span> values<span class="token punctuation">)</span>
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br><span class="line-number">2</span><br></div></div><ul><li>Insert multiple Records</li></ul> <div class="language-java line-numbers-mode"><pre class="language-java"><code><span class="token keyword">void</span> <span class="token function">insertRecords</span><span class="token punctuation">(</span><span class="token class-name">List</span><span class="token generics"><span class="token punctuation">&lt;</span><span class="token class-name">String</span><span class="token punctuation">&gt;</span></span> deviceIds<span class="token punctuation">,</span> <span class="token class-name">List</span><span class="token generics"><span class="token punctuation">&lt;</span><span class="token class-name">Long</span><span class="token punctuation">&gt;</span></span> times<span class="token punctuation">,</span>
    <span class="token class-name">List</span><span class="token generics"><span class="token punctuation">&lt;</span><span class="token class-name">List</span><span class="token punctuation">&lt;</span><span class="token class-name">String</span><span class="token punctuation">&gt;</span><span class="token punctuation">&gt;</span></span> measurementsList<span class="token punctuation">,</span> <span class="token class-name">List</span><span class="token generics"><span class="token punctuation">&lt;</span><span class="token class-name">List</span><span class="token punctuation">&lt;</span><span class="token class-name">TSDataType</span><span class="token punctuation">&gt;</span><span class="token punctuation">&gt;</span></span> typesList<span class="token punctuation">,</span>
    <span class="token class-name">List</span><span class="token generics"><span class="token punctuation">&lt;</span><span class="token class-name">List</span><span class="token punctuation">&lt;</span><span class="token class-name">Object</span><span class="token punctuation">&gt;</span><span class="token punctuation">&gt;</span></span> valuesList<span class="token punctuation">)</span>
</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><ul><li>Insert multiple Records that belong to the same device.
With type info the server has no need to do type inference, which leads a better performance</li></ul> <div class="language-java line-numbers-mode"><pre class="language-java"><code><span class="token keyword">void</span> <span class="token function">insertRecordsOfOneDevice</span><span class="token punctuation">(</span><span class="token class-name">String</span> deviceId<span class="token punctuation">,</span> <span class="token class-name">List</span><span class="token generics"><span class="token punctuation">&lt;</span><span class="token class-name">Long</span><span class="token punctuation">&gt;</span></span> times<span class="token punctuation">,</span>
    <span class="token class-name">List</span><span class="token generics"><span class="token punctuation">&lt;</span><span class="token class-name">List</span><span class="token punctuation">&lt;</span><span class="token class-name">String</span><span class="token punctuation">&gt;</span><span class="token punctuation">&gt;</span></span> measurementsList<span class="token punctuation">,</span> <span class="token class-name">List</span><span class="token generics"><span class="token punctuation">&lt;</span><span class="token class-name">List</span><span class="token punctuation">&lt;</span><span class="token class-name">TSDataType</span><span class="token punctuation">&gt;</span><span class="token punctuation">&gt;</span></span> typesList<span class="token punctuation">,</span>
    <span class="token class-name">List</span><span class="token generics"><span class="token punctuation">&lt;</span><span class="token class-name">List</span><span class="token punctuation">&lt;</span><span class="token class-name">Object</span><span class="token punctuation">&gt;</span><span class="token punctuation">&gt;</span></span> valuesList<span class="token punctuation">)</span>
</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><h4 id="insert-with-type-inference"><a href="#insert-with-type-inference" class="header-anchor">#</a> Insert with type inference</h4> <p>When the data is of String type, we can use the following interface to perform type inference based on the value of the value itself. For example, if value is &quot;true&quot; , it can be automatically inferred to be a boolean type. If value is &quot;3.2&quot; , it can be automatically inferred as a flout type. Without type information, server has to do type inference, which may cost some time.</p> <ul><li>Insert a Record, which contains multiple measurement value of a device at a timestamp</li></ul> <div class="language-java line-numbers-mode"><pre class="language-java"><code><span class="token keyword">void</span> <span class="token function">insertRecord</span><span class="token punctuation">(</span><span class="token class-name">String</span> prefixPath<span class="token punctuation">,</span> <span class="token keyword">long</span> time<span class="token punctuation">,</span> <span class="token class-name">List</span><span class="token generics"><span class="token punctuation">&lt;</span><span class="token class-name">String</span><span class="token punctuation">&gt;</span></span> measurements<span class="token punctuation">,</span> <span class="token class-name">List</span><span class="token generics"><span class="token punctuation">&lt;</span><span class="token class-name">String</span><span class="token punctuation">&gt;</span></span> values<span class="token punctuation">)</span>
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br></div></div><ul><li>Insert multiple Records</li></ul> <div class="language-java line-numbers-mode"><pre class="language-java"><code><span class="token keyword">void</span> <span class="token function">insertRecords</span><span class="token punctuation">(</span><span class="token class-name">List</span><span class="token generics"><span class="token punctuation">&lt;</span><span class="token class-name">String</span><span class="token punctuation">&gt;</span></span> deviceIds<span class="token punctuation">,</span> <span class="token class-name">List</span><span class="token generics"><span class="token punctuation">&lt;</span><span class="token class-name">Long</span><span class="token punctuation">&gt;</span></span> times<span class="token punctuation">,</span> 
   <span class="token class-name">List</span><span class="token generics"><span class="token punctuation">&lt;</span><span class="token class-name">List</span><span class="token punctuation">&lt;</span><span class="token class-name">String</span><span class="token punctuation">&gt;</span><span class="token punctuation">&gt;</span></span> measurementsList<span class="token punctuation">,</span> <span class="token class-name">List</span><span class="token generics"><span class="token punctuation">&lt;</span><span class="token class-name">List</span><span class="token punctuation">&lt;</span><span class="token class-name">String</span><span class="token punctuation">&gt;</span><span class="token punctuation">&gt;</span></span> valuesList<span class="token punctuation">)</span>
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br><span class="line-number">2</span><br></div></div><ul><li>Insert multiple Records that belong to the same device.</li></ul> <div class="language-java line-numbers-mode"><pre class="language-java"><code><span class="token keyword">void</span> <span class="token function">insertStringRecordsOfOneDevice</span><span class="token punctuation">(</span><span class="token class-name">String</span> deviceId<span class="token punctuation">,</span> <span class="token class-name">List</span><span class="token generics"><span class="token punctuation">&lt;</span><span class="token class-name">Long</span><span class="token punctuation">&gt;</span></span> times<span class="token punctuation">,</span>
        <span class="token class-name">List</span><span class="token generics"><span class="token punctuation">&lt;</span><span class="token class-name">List</span><span class="token punctuation">&lt;</span><span class="token class-name">String</span><span class="token punctuation">&gt;</span><span class="token punctuation">&gt;</span></span> measurementsList<span class="token punctuation">,</span> <span class="token class-name">List</span><span class="token generics"><span class="token punctuation">&lt;</span><span class="token class-name">List</span><span class="token punctuation">&lt;</span><span class="token class-name">String</span><span class="token punctuation">&gt;</span><span class="token punctuation">&gt;</span></span> valuesList<span class="token punctuation">)</span>
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br><span class="line-number">2</span><br></div></div><h4 id="insert-of-aligned-timeseries"><a href="#insert-of-aligned-timeseries" class="header-anchor">#</a> Insert of Aligned Timeseries</h4> <p>The Insert of aligned timeseries uses interfaces like insertAlignedXXX, and others are similar to the above interfaces:</p> <ul><li>insertAlignedRecord</li> <li>insertAlignedRecords</li> <li>insertAlignedRecordsOfOneDevice</li> <li>insertAlignedStringRecordsOfOneDevice</li> <li>insertAlignedTablet</li> <li>insertAlignedTablets</li></ul> <h4 id="delete"><a href="#delete" class="header-anchor">#</a> Delete</h4> <ul><li>Delete data before or equal to a timestamp of one or several timeseries</li></ul> <div class="language-java line-numbers-mode"><pre class="language-java"><code><span class="token keyword">void</span> <span class="token function">deleteData</span><span class="token punctuation">(</span><span class="token class-name">String</span> path<span class="token punctuation">,</span> <span class="token keyword">long</span> time<span class="token punctuation">)</span>
<span class="token keyword">void</span> <span class="token function">deleteData</span><span class="token punctuation">(</span><span class="token class-name">List</span><span class="token generics"><span class="token punctuation">&lt;</span><span class="token class-name">String</span><span class="token punctuation">&gt;</span></span> paths<span class="token punctuation">,</span> <span class="token keyword">long</span> time<span class="token punctuation">)</span>
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br><span class="line-number">2</span><br></div></div><h4 id="query"><a href="#query" class="header-anchor">#</a> Query</h4> <ul><li>Raw data query. Time interval include startTime and exclude endTime</li></ul> <div class="language-java line-numbers-mode"><pre class="language-java"><code><span class="token class-name">SessionDataSet</span> <span class="token function">executeRawDataQuery</span><span class="token punctuation">(</span><span class="token class-name">List</span><span class="token generics"><span class="token punctuation">&lt;</span><span class="token class-name">String</span><span class="token punctuation">&gt;</span></span> paths<span class="token punctuation">,</span> <span class="token keyword">long</span> startTime<span class="token punctuation">,</span> <span class="token keyword">long</span> endTime<span class="token punctuation">)</span>
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br></div></div><ul><li>Query the last data, whose timestamp is greater than or equal LastTime</li></ul> <div class="language-java line-numbers-mode"><pre class="language-java"><code><span class="token class-name">SessionDataSet</span> <span class="token function">executeLastDataQuery</span><span class="token punctuation">(</span><span class="token class-name">List</span><span class="token generics"><span class="token punctuation">&lt;</span><span class="token class-name">String</span><span class="token punctuation">&gt;</span></span> paths<span class="token punctuation">,</span> <span class="token keyword">long</span> <span class="token class-name">LastTime</span><span class="token punctuation">)</span>
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br></div></div><h3 id="iotdb-sql-interface"><a href="#iotdb-sql-interface" class="header-anchor">#</a> IoTDB-SQL Interface</h3> <ul><li>Execute query statement</li></ul> <div class="language-java line-numbers-mode"><pre class="language-java"><code><span class="token class-name">SessionDataSet</span> <span class="token function">executeQueryStatement</span><span class="token punctuation">(</span><span class="token class-name">String</span> sql<span class="token punctuation">)</span>
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br></div></div><ul><li>Execute non query statement</li></ul> <div class="language-java line-numbers-mode"><pre class="language-java"><code><span class="token keyword">void</span> <span class="token function">executeNonQueryStatement</span><span class="token punctuation">(</span><span class="token class-name">String</span> sql<span class="token punctuation">)</span>
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br></div></div><h3 id="write-test-interface-to-profile-network-cost"><a href="#write-test-interface-to-profile-network-cost" class="header-anchor">#</a> Write Test Interface (to profile network cost)</h3> <p>These methods <strong>don't</strong> insert data into database and server just return after accept the request.</p> <ul><li>Test the network and client cost of insertRecord</li></ul> <div class="language-java line-numbers-mode"><pre class="language-java"><code><span class="token keyword">void</span> <span class="token function">testInsertRecord</span><span class="token punctuation">(</span><span class="token class-name">String</span> deviceId<span class="token punctuation">,</span> <span class="token keyword">long</span> time<span class="token punctuation">,</span> <span class="token class-name">List</span><span class="token generics"><span class="token punctuation">&lt;</span><span class="token class-name">String</span><span class="token punctuation">&gt;</span></span> measurements<span class="token punctuation">,</span> <span class="token class-name">List</span><span class="token generics"><span class="token punctuation">&lt;</span><span class="token class-name">String</span><span class="token punctuation">&gt;</span></span> values<span class="token punctuation">)</span>

<span class="token keyword">void</span> <span class="token function">testInsertRecord</span><span class="token punctuation">(</span><span class="token class-name">String</span> deviceId<span class="token punctuation">,</span> <span class="token keyword">long</span> time<span class="token punctuation">,</span> <span class="token class-name">List</span><span class="token generics"><span class="token punctuation">&lt;</span><span class="token class-name">String</span><span class="token punctuation">&gt;</span></span> measurements<span class="token punctuation">,</span>
        <span class="token class-name">List</span><span class="token generics"><span class="token punctuation">&lt;</span><span class="token class-name">TSDataType</span><span class="token punctuation">&gt;</span></span> types<span class="token punctuation">,</span> <span class="token class-name">List</span><span class="token generics"><span class="token punctuation">&lt;</span><span class="token class-name">Object</span><span class="token punctuation">&gt;</span></span> values<span class="token punctuation">)</span>
</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></div></div><ul><li>Test the network and client cost of insertRecords</li></ul> <div class="language-java line-numbers-mode"><pre class="language-java"><code><span class="token keyword">void</span> <span class="token function">testInsertRecords</span><span class="token punctuation">(</span><span class="token class-name">List</span><span class="token generics"><span class="token punctuation">&lt;</span><span class="token class-name">String</span><span class="token punctuation">&gt;</span></span> deviceIds<span class="token punctuation">,</span> <span class="token class-name">List</span><span class="token generics"><span class="token punctuation">&lt;</span><span class="token class-name">Long</span><span class="token punctuation">&gt;</span></span> times<span class="token punctuation">,</span>
        <span class="token class-name">List</span><span class="token generics"><span class="token punctuation">&lt;</span><span class="token class-name">List</span><span class="token punctuation">&lt;</span><span class="token class-name">String</span><span class="token punctuation">&gt;</span><span class="token punctuation">&gt;</span></span> measurementsList<span class="token punctuation">,</span> <span class="token class-name">List</span><span class="token generics"><span class="token punctuation">&lt;</span><span class="token class-name">List</span><span class="token punctuation">&lt;</span><span class="token class-name">String</span><span class="token punctuation">&gt;</span><span class="token punctuation">&gt;</span></span> valuesList<span class="token punctuation">)</span>
        
<span class="token keyword">void</span> <span class="token function">testInsertRecords</span><span class="token punctuation">(</span><span class="token class-name">List</span><span class="token generics"><span class="token punctuation">&lt;</span><span class="token class-name">String</span><span class="token punctuation">&gt;</span></span> deviceIds<span class="token punctuation">,</span> <span class="token class-name">List</span><span class="token generics"><span class="token punctuation">&lt;</span><span class="token class-name">Long</span><span class="token punctuation">&gt;</span></span> times<span class="token punctuation">,</span>
        <span class="token class-name">List</span><span class="token generics"><span class="token punctuation">&lt;</span><span class="token class-name">List</span><span class="token punctuation">&lt;</span><span class="token class-name">String</span><span class="token punctuation">&gt;</span><span class="token punctuation">&gt;</span></span> measurementsList<span class="token punctuation">,</span> <span class="token class-name">List</span><span class="token generics"><span class="token punctuation">&lt;</span><span class="token class-name">List</span><span class="token punctuation">&lt;</span><span class="token class-name">TSDataType</span><span class="token punctuation">&gt;</span><span class="token punctuation">&gt;</span></span> typesList
        <span class="token class-name">List</span><span class="token generics"><span class="token punctuation">&lt;</span><span class="token class-name">List</span><span class="token punctuation">&lt;</span><span class="token class-name">Object</span><span class="token punctuation">&gt;</span><span class="token punctuation">&gt;</span></span> valuesList<span class="token punctuation">)</span>
</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><ul><li>Test the network and client cost of insertTablet</li></ul> <div class="language-java line-numbers-mode"><pre class="language-java"><code><span class="token keyword">void</span> <span class="token function">testInsertTablet</span><span class="token punctuation">(</span><span class="token class-name">Tablet</span> tablet<span class="token punctuation">)</span>
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br></div></div><ul><li>Test the network and client cost of insertTablets</li></ul> <div class="language-java line-numbers-mode"><pre class="language-java"><code><span class="token keyword">void</span> <span class="token function">testInsertTablets</span><span class="token punctuation">(</span><span class="token class-name">Map</span><span class="token generics"><span class="token punctuation">&lt;</span><span class="token class-name">String</span><span class="token punctuation">,</span> <span class="token class-name">Tablet</span><span class="token punctuation">&gt;</span></span> tablets<span class="token punctuation">)</span>
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br></div></div><h3 id="coding-examples"><a href="#coding-examples" class="header-anchor">#</a> Coding Examples</h3> <p>To get more information of the following interfaces, please view session/src/main/java/org/apache/iotdb/session/Session.java</p> <p>The sample code of using these interfaces is in example/session/src/main/java/org/apache/iotdb/SessionExample.java，which provides an example of how to open an IoTDB session, execute a batch insertion.</p> <p>For examples of aligned timeseries and measurement template, you can refer to <code>example/session/src/main/java/org/apache/iotdb/AlignedTimeseriesSessionExample.java</code></p> <h2 id="session-pool-for-native-api"><a href="#session-pool-for-native-api" class="header-anchor">#</a> Session Pool for Native API</h2> <p>We provide a connection pool (`SessionPool) for Native API.
Using the interface, you need to define the pool size.</p> <p>If you can not get a session connection in 60 seconds, there is a warning log but the program will hang.</p> <p>If a session has finished an operation, it will be put back to the pool automatically.
If a session connection is broken, the session will be removed automatically and the pool will try
to create a new session and redo the operation.
You can also specify an url list of multiple reachable nodes when creating a SessionPool, just as you would when creating a Session. To ensure high availability of clients in distributed cluster.</p> <p>For query operations:</p> <ol><li>When using SessionPool to query data, the result set is <code>SessionDataSetWrapper</code>;</li> <li>Given a <code>SessionDataSetWrapper</code>, if you have not scanned all the data in it and stop to use it,
you have to call <code>SessionPool.closeResultSet(wrapper)</code> manually;</li> <li>When you call <code>hasNext()</code> and <code>next()</code> of a <code>SessionDataSetWrapper</code> and there is an exception, then
you have to call <code>SessionPool.closeResultSet(wrapper)</code> manually;</li> <li>You can call <code>getColumnNames()</code> of <code>SessionDataSetWrapper</code> to get the column names of query result;</li></ol> <p>Examples: <code>session/src/test/java/org/apache/iotdb/session/pool/SessionPoolTest.java</code></p> <p>Or <code>example/session/src/main/java/org/apache/iotdb/SessionPoolExample.java</code></p> <h2 id="cluster-information-related-apis-only-works-in-the-cluster-mode"><a href="#cluster-information-related-apis-only-works-in-the-cluster-mode" class="header-anchor">#</a> Cluster information related APIs (only works in the cluster mode)</h2> <p>Cluster information related APIs allow users get the cluster info like where a storage group will be
partitioned to, the status of each node in the cluster.</p> <p>To use the APIs, add dependency in your pom file:</p> <div class="language-xml line-numbers-mode"><pre class="language-xml"><code><span class="token tag"><span class="token tag"><span class="token punctuation">&lt;</span>dependencies</span><span class="token punctuation">&gt;</span></span>
    <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;</span>dependency</span><span class="token punctuation">&gt;</span></span>
      <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;</span>groupId</span><span class="token punctuation">&gt;</span></span>org.apache.iotdb<span class="token tag"><span class="token tag"><span class="token punctuation">&lt;/</span>groupId</span><span class="token punctuation">&gt;</span></span>
      <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;</span>artifactId</span><span class="token punctuation">&gt;</span></span>iotdb-thrift-cluster<span class="token tag"><span class="token tag"><span class="token punctuation">&lt;/</span>artifactId</span><span class="token punctuation">&gt;</span></span>
      <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;</span>version</span><span class="token punctuation">&gt;</span></span>0.13.0-SNAPSHOT<span class="token tag"><span class="token tag"><span class="token punctuation">&lt;/</span>version</span><span class="token punctuation">&gt;</span></span>
    <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;/</span>dependency</span><span class="token punctuation">&gt;</span></span>
<span class="token tag"><span class="token tag"><span class="token punctuation">&lt;/</span>dependencies</span><span class="token punctuation">&gt;</span></span>
</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>How to open a connection:</p> <div class="language-java line-numbers-mode"><pre class="language-java"><code><span class="token keyword">import</span> <span class="token import"><span class="token namespace">org<span class="token punctuation">.</span>apache<span class="token punctuation">.</span>thrift<span class="token punctuation">.</span>protocol<span class="token punctuation">.</span></span><span class="token class-name">TBinaryProtocol</span></span><span class="token punctuation">;</span>
<span class="token keyword">import</span> <span class="token import"><span class="token namespace">org<span class="token punctuation">.</span>apache<span class="token punctuation">.</span>thrift<span class="token punctuation">.</span>transport<span class="token punctuation">.</span></span><span class="token class-name">TSocket</span></span><span class="token punctuation">;</span>
<span class="token keyword">import</span> <span class="token import"><span class="token namespace">org<span class="token punctuation">.</span>apache<span class="token punctuation">.</span>thrift<span class="token punctuation">.</span>transport<span class="token punctuation">.</span></span><span class="token class-name">TTransport</span></span><span class="token punctuation">;</span>
<span class="token keyword">import</span> <span class="token import"><span class="token namespace">org<span class="token punctuation">.</span>apache<span class="token punctuation">.</span>thrift<span class="token punctuation">.</span>transport<span class="token punctuation">.</span></span><span class="token class-name">TTransportException</span></span><span class="token punctuation">;</span>
<span class="token keyword">import</span> <span class="token import"><span class="token namespace">org<span class="token punctuation">.</span>apache<span class="token punctuation">.</span>iotdb<span class="token punctuation">.</span>rpc<span class="token punctuation">.</span></span><span class="token class-name">RpcTransportFactory</span></span><span class="token punctuation">;</span>

<span class="token keyword">public</span> <span class="token keyword">class</span> <span class="token class-name">CluserInfoClient</span> <span class="token punctuation">{</span>
  <span class="token class-name">TTransport</span> transport<span class="token punctuation">;</span>
  <span class="token class-name">ClusterInfoService<span class="token punctuation">.</span>Client</span> client<span class="token punctuation">;</span>
  <span class="token keyword">public</span> <span class="token keyword">void</span> <span class="token function">connect</span><span class="token punctuation">(</span><span class="token punctuation">)</span> <span class="token punctuation">{</span>
    transport <span class="token operator">=</span>
            <span class="token class-name">RpcTransportFactory</span><span class="token punctuation">.</span>INSTANCE<span class="token punctuation">.</span><span class="token function">getTransport</span><span class="token punctuation">(</span>
                    <span class="token keyword">new</span> <span class="token class-name">TSocket</span><span class="token punctuation">(</span>
                            <span class="token comment">// the RPC address</span>
                            <span class="token class-name">IoTDBDescriptor</span><span class="token punctuation">.</span><span class="token function">getInstance</span><span class="token punctuation">(</span><span class="token punctuation">)</span><span class="token punctuation">.</span><span class="token function">getConfig</span><span class="token punctuation">(</span><span class="token punctuation">)</span><span class="token punctuation">.</span><span class="token function">getRpcAddress</span><span class="token punctuation">(</span><span class="token punctuation">)</span><span class="token punctuation">,</span>
                            <span class="token comment">// the RPC port</span>
                            <span class="token class-name">ClusterDescriptor</span><span class="token punctuation">.</span><span class="token function">getInstance</span><span class="token punctuation">(</span><span class="token punctuation">)</span><span class="token punctuation">.</span><span class="token function">getConfig</span><span class="token punctuation">(</span><span class="token punctuation">)</span><span class="token punctuation">.</span><span class="token function">getClusterRpcPort</span><span class="token punctuation">(</span><span class="token punctuation">)</span><span class="token punctuation">)</span><span class="token punctuation">)</span><span class="token punctuation">;</span>
    <span class="token keyword">try</span> <span class="token punctuation">{</span>
      transport<span class="token punctuation">.</span><span class="token keyword">open</span><span class="token punctuation">(</span><span class="token punctuation">)</span><span class="token punctuation">;</span>
    <span class="token punctuation">}</span> <span class="token keyword">catch</span> <span class="token punctuation">(</span><span class="token class-name">TTransportException</span> e<span class="token punctuation">)</span> <span class="token punctuation">{</span>
      <span class="token class-name">Assert</span><span class="token punctuation">.</span><span class="token function">fail</span><span class="token punctuation">(</span>e<span class="token punctuation">.</span><span class="token function">getMessage</span><span class="token punctuation">(</span><span class="token punctuation">)</span><span class="token punctuation">)</span><span class="token punctuation">;</span>
    <span class="token punctuation">}</span>
    <span class="token comment">//get the client</span>
    client <span class="token operator">=</span> <span class="token keyword">new</span> <span class="token class-name">ClusterInfoService<span class="token punctuation">.</span>Client</span><span class="token punctuation">(</span><span class="token keyword">new</span> <span class="token class-name">TBinaryProtocol</span><span class="token punctuation">(</span>transport<span class="token punctuation">)</span><span class="token punctuation">)</span><span class="token punctuation">;</span>
  <span class="token punctuation">}</span>
  <span class="token keyword">public</span> <span class="token keyword">void</span> <span class="token function">close</span><span class="token punctuation">(</span><span class="token punctuation">)</span> <span class="token punctuation">{</span>
    transport<span class="token punctuation">.</span><span class="token function">close</span><span class="token punctuation">(</span><span class="token punctuation">)</span><span class="token punctuation">;</span>
  <span class="token punctuation">}</span>
<span class="token punctuation">}</span>
</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></div></div><p>APIs in <code>ClusterInfoService.Client</code>:</p> <ul><li>Get the physical hash ring of the cluster:</li></ul> <div class="language-java line-numbers-mode"><pre class="language-java"><code>list<span class="token generics"><span class="token punctuation">&lt;</span><span class="token class-name">Node</span><span class="token punctuation">&gt;</span></span> <span class="token function">getRing</span><span class="token punctuation">(</span><span class="token punctuation">)</span><span class="token punctuation">;</span>
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br></div></div><ul><li>Get data partition information of input path and time range:</li></ul> <div class="language-java line-numbers-mode"><pre class="language-java"><code><span class="token comment">/**
 * @param path input path (should contains a Storage group name as its prefix)
 * @return the data partition info. If the time range only covers one data partition, the the size
 * of the list is one.
 */</span>
list<span class="token generics"><span class="token punctuation">&lt;</span><span class="token class-name">DataPartitionEntry</span><span class="token punctuation">&gt;</span></span> <span class="token function">getDataPartition</span><span class="token punctuation">(</span><span class="token number">1</span><span class="token operator">:</span>string path<span class="token punctuation">,</span> <span class="token number">2</span><span class="token operator">:</span><span class="token keyword">long</span> startTime<span class="token punctuation">,</span> <span class="token number">3</span><span class="token operator">:</span><span class="token keyword">long</span> endTime<span class="token punctuation">)</span><span class="token punctuation">;</span>
</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><ul><li>Get metadata partition information of input path:</li></ul> <div class="language-java line-numbers-mode"><pre class="language-java"><code><span class="token comment">/**
 * @param path input path (should contains a Storage group name as its prefix)
 * @return metadata partition information
 */</span>
list<span class="token generics"><span class="token punctuation">&lt;</span><span class="token class-name">Node</span><span class="token punctuation">&gt;</span></span> <span class="token function">getMetaPartition</span><span class="token punctuation">(</span><span class="token number">1</span><span class="token operator">:</span>string path<span class="token punctuation">)</span><span class="token punctuation">;</span>
</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></div></div><ul><li>Get the status (alive or not) of all nodes:</li></ul> <div class="language-java line-numbers-mode"><pre class="language-java"><code><span class="token comment">/**
 * @return key: node, value: live or not
 */</span>
map<span class="token generics"><span class="token punctuation">&lt;</span><span class="token class-name">Node</span><span class="token punctuation">,</span> bool<span class="token punctuation">&gt;</span></span> <span class="token function">getAllNodeStatus</span><span class="token punctuation">(</span><span class="token punctuation">)</span><span class="token punctuation">;</span>
</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></div></div><ul><li>get the raft group info (voteFor, term, etc..) of the connected node
(Notice that this API is rarely used by users):</li></ul> <div class="language-java line-numbers-mode"><pre class="language-java"><code><span class="token comment">/**
 * @return A multi-line string with each line representing the total time consumption, invocation
 *     number, and average time consumption.
 */</span>
string <span class="token function">getInstrumentingInfo</span><span class="token punctuation">(</span><span class="token punctuation">)</span><span class="token punctuation">;</span>
</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></div></div></div> <div class="page-nav"><p class="inner"><span class="prev">
        ←
        <a href="/UserGuide/V0.13.x/Reference/Syntax-Conventions.html" class="prev">
          Syntax Conventions
        </a></span> <span class="next"><a href="/UserGuide/V0.13.x/API/Programming-Python-Native-API.html">
          Python Native API
        </a>
        →
      </span></p></div> <p style="text-align: center; color: #909399; font-size: 12px; margin: 0 30px;">Copyright © 2022 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: #909399; font-size: 12px; margin: 0 30px;"><strong>Have a question?</strong> Connect with us on QQ, WeChat, or Slack. <a href="https://github.com/apache/iotdb/issues/1995">Join the community</a> now.</p> <p style="text-align: center; margin-top: 10px; color: #909399; font-size: 12px; margin: 0 30px;">
    We use <a href="https://analytics.google.com">Google Analytics</a> to collect anonymous, aggregated usage information.
  </p></main></div><div class="global-ui"></div></div>
    <script src="/assets/js/app.b50138c2.js" defer></script><script src="/assets/js/3.c8384d0b.js" defer></script><script src="/assets/js/276.d8accd8d.js" defer></script>
  </body>
</html>