blob: cb1d6a3352d0caadbc24a460d915c03712cf1735 [file] [log] [blame]
<!DOCTYPE html>
<html lang="zh-CN">
<head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width,initial-scale=1">
<title> </title>
<meta name="generator" content="VuePress 1.5.2">
<link rel="icon" href="/favicon.ico">
<meta name="description" content=" ">
<meta name="Description" content="Apache IoTDB: Time Series Database for IoT">
<meta name="Keywords" content="TSDB, time series, time series database, IoTDB, IoT database, IoT data management,时序数据库, 时间序列管理, IoTDB, 物联网数据库, 实时数据库, 物联网数据管理, 物联网数据">
<meta name="baidu-site-verification" content="wfKETzB3OT">
<meta name="google-site-verification" content="mZWAoRY0yj_HAr-s47zHCGHzx5Ju-RVm5wDbPnwQYFo">
<link rel="preload" href="/assets/css/0.styles.ec7af591.css" as="style"><link rel="preload" href="/assets/js/app.aab05fb2.js" as="script"><link rel="preload" href="/assets/js/3.1dc302ea.js" as="script"><link rel="preload" href="/assets/js/239.a3762b13.js" as="script"><link rel="prefetch" href="/assets/js/10.df7ec35f.js"><link rel="prefetch" href="/assets/js/100.eb839982.js"><link rel="prefetch" href="/assets/js/101.62cc7e3c.js"><link rel="prefetch" href="/assets/js/102.4fb75106.js"><link rel="prefetch" href="/assets/js/103.d948e8d2.js"><link rel="prefetch" href="/assets/js/104.dc2ec975.js"><link rel="prefetch" href="/assets/js/105.8c9c6ca3.js"><link rel="prefetch" href="/assets/js/106.787e200d.js"><link rel="prefetch" href="/assets/js/107.48adb385.js"><link rel="prefetch" href="/assets/js/108.2dd434b6.js"><link rel="prefetch" href="/assets/js/109.d5bd6b44.js"><link rel="prefetch" href="/assets/js/11.fdd2791a.js"><link rel="prefetch" href="/assets/js/110.db673f1b.js"><link rel="prefetch" href="/assets/js/111.5786d2f6.js"><link rel="prefetch" href="/assets/js/112.40054610.js"><link rel="prefetch" href="/assets/js/113.78698039.js"><link rel="prefetch" href="/assets/js/114.1a34e10c.js"><link rel="prefetch" href="/assets/js/115.c5191fa3.js"><link rel="prefetch" href="/assets/js/116.b522d27c.js"><link rel="prefetch" href="/assets/js/117.d58b55e7.js"><link rel="prefetch" href="/assets/js/118.f996da1b.js"><link rel="prefetch" href="/assets/js/119.95d2c7eb.js"><link rel="prefetch" href="/assets/js/12.53a797d3.js"><link rel="prefetch" href="/assets/js/120.c1e94071.js"><link rel="prefetch" href="/assets/js/121.32bdde4b.js"><link rel="prefetch" href="/assets/js/122.00b68073.js"><link rel="prefetch" href="/assets/js/123.a9afc8fd.js"><link rel="prefetch" href="/assets/js/124.1497f406.js"><link rel="prefetch" href="/assets/js/125.70e1f532.js"><link rel="prefetch" href="/assets/js/126.dd069639.js"><link rel="prefetch" href="/assets/js/127.0a4bd1cd.js"><link rel="prefetch" href="/assets/js/128.66a4bdd6.js"><link rel="prefetch" href="/assets/js/129.31da435b.js"><link rel="prefetch" href="/assets/js/13.769b2d75.js"><link rel="prefetch" href="/assets/js/130.a55118c1.js"><link rel="prefetch" href="/assets/js/131.692c7e8c.js"><link rel="prefetch" href="/assets/js/132.92f478be.js"><link rel="prefetch" href="/assets/js/133.d8d1fda7.js"><link rel="prefetch" href="/assets/js/134.079a54eb.js"><link rel="prefetch" href="/assets/js/135.603463f1.js"><link rel="prefetch" href="/assets/js/136.1367f4f4.js"><link rel="prefetch" href="/assets/js/137.e2dd9afd.js"><link rel="prefetch" href="/assets/js/138.aef15ddd.js"><link rel="prefetch" href="/assets/js/139.0a4e81c3.js"><link rel="prefetch" href="/assets/js/14.c590e545.js"><link rel="prefetch" href="/assets/js/140.7fcac681.js"><link rel="prefetch" href="/assets/js/141.490f341e.js"><link rel="prefetch" href="/assets/js/142.8695a90f.js"><link rel="prefetch" href="/assets/js/143.2906308a.js"><link rel="prefetch" href="/assets/js/144.3ef9d83e.js"><link rel="prefetch" href="/assets/js/145.b7e21983.js"><link rel="prefetch" href="/assets/js/146.f4f05f49.js"><link rel="prefetch" href="/assets/js/147.2cf5fcc7.js"><link rel="prefetch" href="/assets/js/148.4ca7f432.js"><link rel="prefetch" href="/assets/js/149.b892eba8.js"><link rel="prefetch" href="/assets/js/15.4e36e03a.js"><link rel="prefetch" href="/assets/js/150.c3b675ab.js"><link rel="prefetch" href="/assets/js/151.573ed3bf.js"><link rel="prefetch" href="/assets/js/152.847be55c.js"><link rel="prefetch" href="/assets/js/153.ac2f5049.js"><link rel="prefetch" href="/assets/js/154.d8f17cf5.js"><link rel="prefetch" href="/assets/js/155.7e577cee.js"><link rel="prefetch" href="/assets/js/156.09e95d19.js"><link rel="prefetch" href="/assets/js/157.26abc4b8.js"><link rel="prefetch" href="/assets/js/158.77955f1f.js"><link rel="prefetch" href="/assets/js/159.c355ea29.js"><link rel="prefetch" href="/assets/js/16.0b89faa2.js"><link rel="prefetch" href="/assets/js/160.e4ef16f7.js"><link rel="prefetch" href="/assets/js/161.910be1d9.js"><link rel="prefetch" href="/assets/js/162.632afcfd.js"><link rel="prefetch" href="/assets/js/163.f5057cff.js"><link rel="prefetch" href="/assets/js/164.744b0d75.js"><link rel="prefetch" href="/assets/js/165.58f59259.js"><link rel="prefetch" href="/assets/js/166.ca91cb14.js"><link rel="prefetch" href="/assets/js/167.542edc26.js"><link rel="prefetch" href="/assets/js/168.bb4a1767.js"><link rel="prefetch" href="/assets/js/169.cd7762cb.js"><link rel="prefetch" href="/assets/js/17.54956aa7.js"><link rel="prefetch" href="/assets/js/170.bc1fbd49.js"><link rel="prefetch" href="/assets/js/171.957b8fc0.js"><link rel="prefetch" href="/assets/js/172.07512139.js"><link rel="prefetch" href="/assets/js/173.1dc87f34.js"><link rel="prefetch" href="/assets/js/174.8cc0b78c.js"><link rel="prefetch" href="/assets/js/175.fff490c7.js"><link rel="prefetch" href="/assets/js/176.8f18d71a.js"><link rel="prefetch" href="/assets/js/177.c14bf697.js"><link rel="prefetch" href="/assets/js/178.484171c5.js"><link rel="prefetch" href="/assets/js/179.db8ce2fc.js"><link rel="prefetch" href="/assets/js/18.74f41e6a.js"><link rel="prefetch" href="/assets/js/180.e2d90285.js"><link rel="prefetch" href="/assets/js/181.89d19240.js"><link rel="prefetch" href="/assets/js/182.d6a1e6c1.js"><link rel="prefetch" href="/assets/js/183.0e33f8be.js"><link rel="prefetch" href="/assets/js/184.4f2a386b.js"><link rel="prefetch" href="/assets/js/185.88f314d4.js"><link rel="prefetch" href="/assets/js/186.c88ddd9d.js"><link rel="prefetch" href="/assets/js/187.361a4180.js"><link rel="prefetch" href="/assets/js/188.3bd63846.js"><link rel="prefetch" href="/assets/js/189.a1cde7be.js"><link rel="prefetch" href="/assets/js/19.b2902618.js"><link rel="prefetch" href="/assets/js/190.6ada374d.js"><link rel="prefetch" href="/assets/js/191.3c92390c.js"><link rel="prefetch" href="/assets/js/192.79ef5864.js"><link rel="prefetch" href="/assets/js/193.f037d2e1.js"><link rel="prefetch" href="/assets/js/194.ea7f7dae.js"><link rel="prefetch" href="/assets/js/195.986eb514.js"><link rel="prefetch" href="/assets/js/196.647c1541.js"><link rel="prefetch" href="/assets/js/197.5b581b72.js"><link rel="prefetch" href="/assets/js/198.ffb0d3bb.js"><link rel="prefetch" href="/assets/js/199.2d0d96c8.js"><link rel="prefetch" href="/assets/js/20.6630eb9b.js"><link rel="prefetch" href="/assets/js/200.c5aad4aa.js"><link rel="prefetch" href="/assets/js/201.2008406c.js"><link rel="prefetch" href="/assets/js/202.8c1db698.js"><link rel="prefetch" href="/assets/js/203.d5203c70.js"><link rel="prefetch" href="/assets/js/204.e54acfa8.js"><link rel="prefetch" href="/assets/js/205.c4b100e4.js"><link rel="prefetch" href="/assets/js/206.e49b85d8.js"><link rel="prefetch" href="/assets/js/207.29a65e32.js"><link rel="prefetch" href="/assets/js/208.96c25b78.js"><link rel="prefetch" href="/assets/js/209.da5b902e.js"><link rel="prefetch" href="/assets/js/21.7348c820.js"><link rel="prefetch" href="/assets/js/210.0996b0bc.js"><link rel="prefetch" href="/assets/js/211.1daccc6a.js"><link rel="prefetch" href="/assets/js/212.30632baa.js"><link rel="prefetch" href="/assets/js/213.7c93918f.js"><link rel="prefetch" href="/assets/js/214.ef5415e3.js"><link rel="prefetch" href="/assets/js/215.efbf083a.js"><link rel="prefetch" href="/assets/js/216.4f8f1a97.js"><link rel="prefetch" href="/assets/js/217.aa94f853.js"><link rel="prefetch" href="/assets/js/218.7b852cd9.js"><link rel="prefetch" href="/assets/js/219.43f1e1a9.js"><link rel="prefetch" href="/assets/js/22.342c3455.js"><link rel="prefetch" href="/assets/js/220.46e3baeb.js"><link rel="prefetch" href="/assets/js/221.90351c5d.js"><link rel="prefetch" href="/assets/js/222.566b541a.js"><link rel="prefetch" href="/assets/js/223.e69b2bf7.js"><link rel="prefetch" href="/assets/js/224.4407f53f.js"><link rel="prefetch" href="/assets/js/225.5da34be9.js"><link rel="prefetch" href="/assets/js/226.0cd60a1c.js"><link rel="prefetch" href="/assets/js/227.5190fe78.js"><link rel="prefetch" href="/assets/js/228.d32ee20e.js"><link rel="prefetch" href="/assets/js/229.42f60648.js"><link rel="prefetch" href="/assets/js/23.a1dc7ce4.js"><link rel="prefetch" href="/assets/js/230.fb64689c.js"><link rel="prefetch" href="/assets/js/231.941ed40a.js"><link rel="prefetch" href="/assets/js/232.b76c5958.js"><link rel="prefetch" href="/assets/js/233.fdbc3089.js"><link rel="prefetch" href="/assets/js/234.e427f6ad.js"><link rel="prefetch" href="/assets/js/235.71d57a1d.js"><link rel="prefetch" href="/assets/js/236.043d2fa9.js"><link rel="prefetch" href="/assets/js/237.7935de95.js"><link rel="prefetch" href="/assets/js/238.3f43ff91.js"><link rel="prefetch" href="/assets/js/24.7d99b547.js"><link rel="prefetch" href="/assets/js/240.264dc456.js"><link rel="prefetch" href="/assets/js/241.d8ebf4e1.js"><link rel="prefetch" href="/assets/js/242.7883df9a.js"><link rel="prefetch" href="/assets/js/243.3d0545a3.js"><link rel="prefetch" href="/assets/js/244.b254bb28.js"><link rel="prefetch" href="/assets/js/245.721a0673.js"><link rel="prefetch" href="/assets/js/246.3d2e0605.js"><link rel="prefetch" href="/assets/js/247.db755fe6.js"><link rel="prefetch" href="/assets/js/248.70ba84e9.js"><link rel="prefetch" href="/assets/js/249.c1c45b75.js"><link rel="prefetch" href="/assets/js/25.e9c9b8c3.js"><link rel="prefetch" href="/assets/js/250.28854dfe.js"><link rel="prefetch" href="/assets/js/251.c64305bb.js"><link rel="prefetch" href="/assets/js/252.bfb4ef3d.js"><link rel="prefetch" href="/assets/js/253.7c4e160d.js"><link rel="prefetch" href="/assets/js/254.3bb9c624.js"><link rel="prefetch" href="/assets/js/255.d5d8be96.js"><link rel="prefetch" href="/assets/js/256.d559b233.js"><link rel="prefetch" href="/assets/js/257.758697f3.js"><link rel="prefetch" href="/assets/js/258.7ddfde22.js"><link rel="prefetch" href="/assets/js/259.c1c40084.js"><link rel="prefetch" href="/assets/js/26.e429c51b.js"><link rel="prefetch" href="/assets/js/260.f918b40f.js"><link rel="prefetch" href="/assets/js/261.cd3ecfe4.js"><link rel="prefetch" href="/assets/js/262.4a65733d.js"><link rel="prefetch" href="/assets/js/263.d4643aa4.js"><link rel="prefetch" href="/assets/js/264.8034043d.js"><link rel="prefetch" href="/assets/js/265.2d6e5394.js"><link rel="prefetch" href="/assets/js/266.945130cb.js"><link rel="prefetch" href="/assets/js/267.5779d8ad.js"><link rel="prefetch" href="/assets/js/268.3b8f7bf7.js"><link rel="prefetch" href="/assets/js/269.a6ea55d0.js"><link rel="prefetch" href="/assets/js/27.1092da6f.js"><link rel="prefetch" href="/assets/js/270.9e898993.js"><link rel="prefetch" href="/assets/js/271.d92f29b1.js"><link rel="prefetch" href="/assets/js/272.1cde5105.js"><link rel="prefetch" href="/assets/js/273.1df9246d.js"><link rel="prefetch" href="/assets/js/274.1d6613c2.js"><link rel="prefetch" href="/assets/js/275.55412b2d.js"><link rel="prefetch" href="/assets/js/276.eea117ab.js"><link rel="prefetch" href="/assets/js/277.d8cfd95d.js"><link rel="prefetch" href="/assets/js/278.ffad1db7.js"><link rel="prefetch" href="/assets/js/279.47bf065d.js"><link rel="prefetch" href="/assets/js/28.53650c51.js"><link rel="prefetch" href="/assets/js/280.49a50966.js"><link rel="prefetch" href="/assets/js/281.77b2a706.js"><link rel="prefetch" href="/assets/js/282.2714e4c8.js"><link rel="prefetch" href="/assets/js/283.1575531b.js"><link rel="prefetch" href="/assets/js/284.2c0c07ad.js"><link rel="prefetch" href="/assets/js/285.1696a921.js"><link rel="prefetch" href="/assets/js/286.5d791a4f.js"><link rel="prefetch" href="/assets/js/287.22c1ce09.js"><link rel="prefetch" href="/assets/js/288.652aaa7e.js"><link rel="prefetch" href="/assets/js/289.a07dc9d5.js"><link rel="prefetch" href="/assets/js/29.066202c5.js"><link rel="prefetch" href="/assets/js/290.597e6c27.js"><link rel="prefetch" href="/assets/js/291.307b1ef3.js"><link rel="prefetch" href="/assets/js/292.2939b2d7.js"><link rel="prefetch" href="/assets/js/293.42df9e57.js"><link rel="prefetch" href="/assets/js/294.f686160c.js"><link rel="prefetch" href="/assets/js/295.6e9b105c.js"><link rel="prefetch" href="/assets/js/296.f7fc5047.js"><link rel="prefetch" href="/assets/js/297.8482da6f.js"><link rel="prefetch" href="/assets/js/298.c2879999.js"><link rel="prefetch" href="/assets/js/299.177ef1c1.js"><link rel="prefetch" href="/assets/js/30.8899de4a.js"><link rel="prefetch" href="/assets/js/300.c3011a98.js"><link rel="prefetch" href="/assets/js/301.7595ce9b.js"><link rel="prefetch" href="/assets/js/302.a4083048.js"><link rel="prefetch" href="/assets/js/303.20e1e819.js"><link rel="prefetch" href="/assets/js/304.e69eabb5.js"><link rel="prefetch" href="/assets/js/305.18813104.js"><link rel="prefetch" href="/assets/js/306.db4c539d.js"><link rel="prefetch" href="/assets/js/307.1eadef68.js"><link rel="prefetch" href="/assets/js/308.0c148c77.js"><link rel="prefetch" href="/assets/js/309.75f04fa5.js"><link rel="prefetch" href="/assets/js/31.74a260ea.js"><link rel="prefetch" href="/assets/js/310.956c93b3.js"><link rel="prefetch" href="/assets/js/311.fab6126e.js"><link rel="prefetch" href="/assets/js/312.472991b0.js"><link rel="prefetch" href="/assets/js/313.b8d0b24a.js"><link rel="prefetch" href="/assets/js/314.24577949.js"><link rel="prefetch" href="/assets/js/315.87d89712.js"><link rel="prefetch" href="/assets/js/316.570b8ece.js"><link rel="prefetch" href="/assets/js/317.8630c35a.js"><link rel="prefetch" href="/assets/js/318.1d9e6706.js"><link rel="prefetch" href="/assets/js/319.4097770a.js"><link rel="prefetch" href="/assets/js/32.7dba92e8.js"><link rel="prefetch" href="/assets/js/320.a4d30cfc.js"><link rel="prefetch" href="/assets/js/321.efd17a08.js"><link rel="prefetch" href="/assets/js/322.1975e542.js"><link rel="prefetch" href="/assets/js/323.f43938be.js"><link rel="prefetch" href="/assets/js/324.80e620c4.js"><link rel="prefetch" href="/assets/js/325.eea5c98b.js"><link rel="prefetch" href="/assets/js/326.b01277ee.js"><link rel="prefetch" href="/assets/js/327.7f068672.js"><link rel="prefetch" href="/assets/js/328.f2f456c1.js"><link rel="prefetch" href="/assets/js/329.7879d79b.js"><link rel="prefetch" href="/assets/js/33.6f1de65a.js"><link rel="prefetch" href="/assets/js/330.c4f06595.js"><link rel="prefetch" href="/assets/js/331.dcecbbb4.js"><link rel="prefetch" href="/assets/js/332.56b7ace5.js"><link rel="prefetch" href="/assets/js/333.5b3dc02e.js"><link rel="prefetch" href="/assets/js/334.2445b2e3.js"><link rel="prefetch" href="/assets/js/335.c1a7666e.js"><link rel="prefetch" href="/assets/js/336.14ea02eb.js"><link rel="prefetch" href="/assets/js/337.92a1eebf.js"><link rel="prefetch" href="/assets/js/338.e2c82f63.js"><link rel="prefetch" href="/assets/js/339.61ab3afc.js"><link rel="prefetch" href="/assets/js/34.bd36ea6d.js"><link rel="prefetch" href="/assets/js/340.e6381542.js"><link rel="prefetch" href="/assets/js/341.06d1a04a.js"><link rel="prefetch" href="/assets/js/342.0c7db480.js"><link rel="prefetch" href="/assets/js/343.eae84cc4.js"><link rel="prefetch" href="/assets/js/344.600f5857.js"><link rel="prefetch" href="/assets/js/345.895f6f4e.js"><link rel="prefetch" href="/assets/js/346.0f36054a.js"><link rel="prefetch" href="/assets/js/347.fb779741.js"><link rel="prefetch" href="/assets/js/348.c8c979e8.js"><link rel="prefetch" href="/assets/js/349.7c8c7182.js"><link rel="prefetch" href="/assets/js/35.8794367a.js"><link rel="prefetch" href="/assets/js/350.6594590a.js"><link rel="prefetch" href="/assets/js/351.53fce239.js"><link rel="prefetch" href="/assets/js/352.35ec8ac2.js"><link rel="prefetch" href="/assets/js/353.7b4fbfbb.js"><link rel="prefetch" href="/assets/js/354.23ecd67f.js"><link rel="prefetch" href="/assets/js/355.3036280e.js"><link rel="prefetch" href="/assets/js/356.6994b1c5.js"><link rel="prefetch" href="/assets/js/357.87843ebc.js"><link rel="prefetch" href="/assets/js/358.99fb8c0e.js"><link rel="prefetch" href="/assets/js/359.4a8e0f6b.js"><link rel="prefetch" href="/assets/js/36.dbfe70fd.js"><link rel="prefetch" href="/assets/js/360.3b6b56f2.js"><link rel="prefetch" href="/assets/js/361.6a890781.js"><link rel="prefetch" href="/assets/js/362.d7161ced.js"><link rel="prefetch" href="/assets/js/363.a9ab6794.js"><link rel="prefetch" href="/assets/js/364.5ea7b05c.js"><link rel="prefetch" href="/assets/js/365.6ee82532.js"><link rel="prefetch" href="/assets/js/366.695af3fe.js"><link rel="prefetch" href="/assets/js/367.fa247cc1.js"><link rel="prefetch" href="/assets/js/368.ce8203d7.js"><link rel="prefetch" href="/assets/js/369.07ce9f2d.js"><link rel="prefetch" href="/assets/js/37.7ad39219.js"><link rel="prefetch" href="/assets/js/370.1f03bbad.js"><link rel="prefetch" href="/assets/js/371.c53badb2.js"><link rel="prefetch" href="/assets/js/372.61dae475.js"><link rel="prefetch" href="/assets/js/373.19d3b9dc.js"><link rel="prefetch" href="/assets/js/374.deba685c.js"><link rel="prefetch" href="/assets/js/375.b8774b96.js"><link rel="prefetch" href="/assets/js/376.8ffb9732.js"><link rel="prefetch" href="/assets/js/377.a78a55c5.js"><link rel="prefetch" href="/assets/js/378.25a24939.js"><link rel="prefetch" href="/assets/js/379.ee6780ec.js"><link rel="prefetch" href="/assets/js/38.571d97a7.js"><link rel="prefetch" href="/assets/js/380.2c8e4c39.js"><link rel="prefetch" href="/assets/js/381.d2537d37.js"><link rel="prefetch" href="/assets/js/382.f188f5aa.js"><link rel="prefetch" href="/assets/js/383.19ba3299.js"><link rel="prefetch" href="/assets/js/384.14229453.js"><link rel="prefetch" href="/assets/js/385.e72e7623.js"><link rel="prefetch" href="/assets/js/386.e5fd2287.js"><link rel="prefetch" href="/assets/js/387.348649a0.js"><link rel="prefetch" href="/assets/js/388.91379896.js"><link rel="prefetch" href="/assets/js/389.ae818bc1.js"><link rel="prefetch" href="/assets/js/39.afda26e0.js"><link rel="prefetch" href="/assets/js/390.9bc0ecf2.js"><link rel="prefetch" href="/assets/js/391.96918708.js"><link rel="prefetch" href="/assets/js/392.ecb684cf.js"><link rel="prefetch" href="/assets/js/393.f1a2f009.js"><link rel="prefetch" href="/assets/js/394.1b21a999.js"><link rel="prefetch" href="/assets/js/395.b94a7ea2.js"><link rel="prefetch" href="/assets/js/396.e4592dfd.js"><link rel="prefetch" href="/assets/js/397.1c34de3b.js"><link rel="prefetch" href="/assets/js/398.5341fb9b.js"><link rel="prefetch" href="/assets/js/399.5585f448.js"><link rel="prefetch" href="/assets/js/4.256130eb.js"><link rel="prefetch" href="/assets/js/40.a7fda1a5.js"><link rel="prefetch" href="/assets/js/400.7202f552.js"><link rel="prefetch" href="/assets/js/401.42943381.js"><link rel="prefetch" href="/assets/js/402.90c70df5.js"><link rel="prefetch" href="/assets/js/403.9513b679.js"><link rel="prefetch" href="/assets/js/404.56ae1c4e.js"><link rel="prefetch" href="/assets/js/405.736155d7.js"><link rel="prefetch" href="/assets/js/406.0b7c929c.js"><link rel="prefetch" href="/assets/js/407.f1660a22.js"><link rel="prefetch" href="/assets/js/408.d77b4eed.js"><link rel="prefetch" href="/assets/js/409.57b13e89.js"><link rel="prefetch" href="/assets/js/41.d0455f88.js"><link rel="prefetch" href="/assets/js/410.0ac0b985.js"><link rel="prefetch" href="/assets/js/411.a24fe3ce.js"><link rel="prefetch" href="/assets/js/412.c8949d31.js"><link rel="prefetch" href="/assets/js/413.9348cdaf.js"><link rel="prefetch" href="/assets/js/414.5476bceb.js"><link rel="prefetch" href="/assets/js/415.367d85f6.js"><link rel="prefetch" href="/assets/js/416.556d1b58.js"><link rel="prefetch" href="/assets/js/417.43c05f09.js"><link rel="prefetch" href="/assets/js/418.120b5cef.js"><link rel="prefetch" href="/assets/js/419.9f19f44b.js"><link rel="prefetch" href="/assets/js/42.0918e90a.js"><link rel="prefetch" href="/assets/js/420.f104a309.js"><link rel="prefetch" href="/assets/js/421.9126aec5.js"><link rel="prefetch" href="/assets/js/422.5cf330d9.js"><link rel="prefetch" href="/assets/js/423.d7231f78.js"><link rel="prefetch" href="/assets/js/424.6df09c53.js"><link rel="prefetch" href="/assets/js/43.10d96685.js"><link rel="prefetch" href="/assets/js/44.a3535bf1.js"><link rel="prefetch" href="/assets/js/45.a70f329b.js"><link rel="prefetch" href="/assets/js/46.5b5905c7.js"><link rel="prefetch" href="/assets/js/47.7a327a86.js"><link rel="prefetch" href="/assets/js/48.6b166b34.js"><link rel="prefetch" href="/assets/js/49.649d442c.js"><link rel="prefetch" href="/assets/js/5.f601e2c6.js"><link rel="prefetch" href="/assets/js/50.c5fb2695.js"><link rel="prefetch" href="/assets/js/51.a0ab7916.js"><link rel="prefetch" href="/assets/js/52.d1ec2122.js"><link rel="prefetch" href="/assets/js/53.397b47bc.js"><link rel="prefetch" href="/assets/js/54.65465bf1.js"><link rel="prefetch" href="/assets/js/55.80ea5cb9.js"><link rel="prefetch" href="/assets/js/56.b2f340c6.js"><link rel="prefetch" href="/assets/js/57.19a2c675.js"><link rel="prefetch" href="/assets/js/58.30b2d7e4.js"><link rel="prefetch" href="/assets/js/59.680940a9.js"><link rel="prefetch" href="/assets/js/6.721631ef.js"><link rel="prefetch" href="/assets/js/60.a608a453.js"><link rel="prefetch" href="/assets/js/61.cc1db890.js"><link rel="prefetch" href="/assets/js/62.7e8f4824.js"><link rel="prefetch" href="/assets/js/63.1a495e69.js"><link rel="prefetch" href="/assets/js/64.bc808e35.js"><link rel="prefetch" href="/assets/js/65.4599fb61.js"><link rel="prefetch" href="/assets/js/66.9f519a71.js"><link rel="prefetch" href="/assets/js/67.c2eea14a.js"><link rel="prefetch" href="/assets/js/68.7dacd0ee.js"><link rel="prefetch" href="/assets/js/69.3cf6be47.js"><link rel="prefetch" href="/assets/js/7.ca2cff26.js"><link rel="prefetch" href="/assets/js/70.154db1d1.js"><link rel="prefetch" href="/assets/js/71.5e74a55e.js"><link rel="prefetch" href="/assets/js/72.04b04992.js"><link rel="prefetch" href="/assets/js/73.6d44ceae.js"><link rel="prefetch" href="/assets/js/74.46618890.js"><link rel="prefetch" href="/assets/js/75.cf1936c6.js"><link rel="prefetch" href="/assets/js/76.f16398a0.js"><link rel="prefetch" href="/assets/js/77.01918d4a.js"><link rel="prefetch" href="/assets/js/78.f9911849.js"><link rel="prefetch" href="/assets/js/79.23a27387.js"><link rel="prefetch" href="/assets/js/8.c47fdf90.js"><link rel="prefetch" href="/assets/js/80.3f146599.js"><link rel="prefetch" href="/assets/js/81.fd4cc088.js"><link rel="prefetch" href="/assets/js/82.99513a8e.js"><link rel="prefetch" href="/assets/js/83.c6be4217.js"><link rel="prefetch" href="/assets/js/84.421f5640.js"><link rel="prefetch" href="/assets/js/85.820ffd5a.js"><link rel="prefetch" href="/assets/js/86.497e18c6.js"><link rel="prefetch" href="/assets/js/87.ae9e8388.js"><link rel="prefetch" href="/assets/js/88.4c5105e2.js"><link rel="prefetch" href="/assets/js/89.1f652761.js"><link rel="prefetch" href="/assets/js/9.cc76f2db.js"><link rel="prefetch" href="/assets/js/90.4a9eb03c.js"><link rel="prefetch" href="/assets/js/91.7e226fac.js"><link rel="prefetch" href="/assets/js/92.dd96bf00.js"><link rel="prefetch" href="/assets/js/93.ec32463a.js"><link rel="prefetch" href="/assets/js/94.9575ff6e.js"><link rel="prefetch" href="/assets/js/95.99afeeb5.js"><link rel="prefetch" href="/assets/js/96.063584de.js"><link rel="prefetch" href="/assets/js/97.e7ed0e68.js"><link rel="prefetch" href="/assets/js/98.873a8141.js"><link rel="prefetch" href="/assets/js/99.9cd99ea3.js"><link rel="prefetch" href="/assets/js/vendors~docsearch.3b3aacb0.js">
<link rel="stylesheet" href="/assets/css/0.styles.ec7af591.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="/zh/" 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">文档</span> <span class="arrow right"></span></a> <ul class="nav-dropdown" style="display:none;"><li class="dropdown-item"><!----> <a href="/zh/UserGuide/Master/Get Started/QuickStart.html" class="nav-link">In progress</a></li><li class="dropdown-item"><!----> <a href="/zh/UserGuide/V0.10.x/Get Started/QuickStart.html" class="nav-link">V0.10.x</a></li><li class="dropdown-item"><!----> <a href="/zh/UserGuide/V0.9.x/0-Get Started/1-QuickStart.html" class="nav-link">V0.9.x</a></li><li class="dropdown-item"><!----> <a href="/zh/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="/zh/SystemDesign/Architecture/Architecture.html" class="nav-link">系统设计</a></div><div class="nav-item"><a href="/zh/Download/" class="nav-link">下载</a></div><div class="nav-item"><div class="dropdown-wrapper"><a class="dropdown-title"><span class="title">社区</span> <span class="arrow right"></span></a> <ul class="nav-dropdown" style="display:none;"><li class="dropdown-item"><!----> <a href="https://cwiki.apache.org/confluence/display/iotdb" class="nav-link external">
Wiki
<!----></a></li><li class="dropdown-item"><!----> <a href="/zh/Community/Community-Project Committers.html" class="nav-link">开发人员</a></li><li class="dropdown-item"><!----> <a href="/zh/Community/Community-Powered By.html" class="nav-link">技术支持</a></li><li class="dropdown-item"><!----> <a href="/zh/Community/Materials.html" class="nav-link">活动与报告</a></li><li class="dropdown-item"><!----> <a href="/zh/Community/Feedback.html" class="nav-link">交流与反馈</a></li></ul></div></div><div class="nav-item"><div class="dropdown-wrapper"><a class="dropdown-title"><span class="title">开发</span> <span class="arrow right"></span></a> <ul class="nav-dropdown" style="display:none;"><li class="dropdown-item"><!----> <a href="/zh/Development/VoteRelease.html" class="nav-link">如何投票</a></li><li class="dropdown-item"><!----> <a href="/zh/Development/HowToCommit.html" class="nav-link">如何提交代码</a></li><li class="dropdown-item"><!----> <a href="/zh/Development/Committer.html" class="nav-link">成为Committer</a></li><li class="dropdown-item"><!----> <a href="/zh/Development/ContributeGuide.html" class="nav-link">项目开发指南</a></li><li class="dropdown-item"><!----> <a href="/zh/Development/format-changelist.html" class="nav-link">TsFile的更改列表</a></li><li class="dropdown-item"><!----> <a href="/zh/Development/rpc-changelist.html" class="nav-link">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">
基金会
<!----></a></li><li class="dropdown-item"><!----> <a href="http://www.apache.org/licenses/" class="nav-link external">
许可证
<!----></a></li><li class="dropdown-item"><!----> <a href="http://www.apache.org/security/" class="nav-link external">
安全
<!----></a></li><li class="dropdown-item"><!----> <a href="http://www.apache.org/foundation/sponsorship.html" class="nav-link external">
赞助
<!----></a></li><li class="dropdown-item"><!----> <a href="http://www.apache.org/foundation/thanks.html" class="nav-link external">
致谢
<!----></a></li><li class="dropdown-item"><!----> <a href="http://www.apache.org/events/current-event" class="nav-link external">
活动
<!----></a></li></ul></div></div><div class="nav-item"><div class="dropdown-wrapper"><a class="dropdown-title"><span class="title">语言</span> <span class="arrow right"></span></a> <ul class="nav-dropdown" style="display:none;"><li class="dropdown-item"><!----> <a href="/SystemDesign/DataQuery/FillFunction.html" class="nav-link">English</a></li><li class="dropdown-item"><!----> <a href="/zh/SystemDesign/DataQuery/FillFunction.html" aria-current="page" class="nav-link router-link-exact-active router-link-active">简体中文</a></li></ul></div></div> <a href="https://github.com/apache/incubator-iotdb.git" target="_blank" rel="noopener noreferrer" class="repo-link">
gitHub
<svg xmlns="http://www.w3.org/2000/svg" aria-hidden="true" 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></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">文档</span> <span class="arrow right"></span></a> <ul class="nav-dropdown" style="display:none;"><li class="dropdown-item"><!----> <a href="/zh/UserGuide/Master/Get Started/QuickStart.html" class="nav-link">In progress</a></li><li class="dropdown-item"><!----> <a href="/zh/UserGuide/V0.10.x/Get Started/QuickStart.html" class="nav-link">V0.10.x</a></li><li class="dropdown-item"><!----> <a href="/zh/UserGuide/V0.9.x/0-Get Started/1-QuickStart.html" class="nav-link">V0.9.x</a></li><li class="dropdown-item"><!----> <a href="/zh/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="/zh/SystemDesign/Architecture/Architecture.html" class="nav-link">系统设计</a></div><div class="nav-item"><a href="/zh/Download/" class="nav-link">下载</a></div><div class="nav-item"><div class="dropdown-wrapper"><a class="dropdown-title"><span class="title">社区</span> <span class="arrow right"></span></a> <ul class="nav-dropdown" style="display:none;"><li class="dropdown-item"><!----> <a href="https://cwiki.apache.org/confluence/display/iotdb" class="nav-link external">
Wiki
<!----></a></li><li class="dropdown-item"><!----> <a href="/zh/Community/Community-Project Committers.html" class="nav-link">开发人员</a></li><li class="dropdown-item"><!----> <a href="/zh/Community/Community-Powered By.html" class="nav-link">技术支持</a></li><li class="dropdown-item"><!----> <a href="/zh/Community/Materials.html" class="nav-link">活动与报告</a></li><li class="dropdown-item"><!----> <a href="/zh/Community/Feedback.html" class="nav-link">交流与反馈</a></li></ul></div></div><div class="nav-item"><div class="dropdown-wrapper"><a class="dropdown-title"><span class="title">开发</span> <span class="arrow right"></span></a> <ul class="nav-dropdown" style="display:none;"><li class="dropdown-item"><!----> <a href="/zh/Development/VoteRelease.html" class="nav-link">如何投票</a></li><li class="dropdown-item"><!----> <a href="/zh/Development/HowToCommit.html" class="nav-link">如何提交代码</a></li><li class="dropdown-item"><!----> <a href="/zh/Development/Committer.html" class="nav-link">成为Committer</a></li><li class="dropdown-item"><!----> <a href="/zh/Development/ContributeGuide.html" class="nav-link">项目开发指南</a></li><li class="dropdown-item"><!----> <a href="/zh/Development/format-changelist.html" class="nav-link">TsFile的更改列表</a></li><li class="dropdown-item"><!----> <a href="/zh/Development/rpc-changelist.html" class="nav-link">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">
基金会
<!----></a></li><li class="dropdown-item"><!----> <a href="http://www.apache.org/licenses/" class="nav-link external">
许可证
<!----></a></li><li class="dropdown-item"><!----> <a href="http://www.apache.org/security/" class="nav-link external">
安全
<!----></a></li><li class="dropdown-item"><!----> <a href="http://www.apache.org/foundation/sponsorship.html" class="nav-link external">
赞助
<!----></a></li><li class="dropdown-item"><!----> <a href="http://www.apache.org/foundation/thanks.html" class="nav-link external">
致谢
<!----></a></li><li class="dropdown-item"><!----> <a href="http://www.apache.org/events/current-event" class="nav-link external">
活动
<!----></a></li></ul></div></div><div class="nav-item"><div class="dropdown-wrapper"><a class="dropdown-title"><span class="title">语言</span> <span class="arrow right"></span></a> <ul class="nav-dropdown" style="display:none;"><li class="dropdown-item"><!----> <a href="/SystemDesign/DataQuery/FillFunction.html" class="nav-link">English</a></li><li class="dropdown-item"><!----> <a href="/zh/SystemDesign/DataQuery/FillFunction.html" aria-current="page" class="nav-link router-link-exact-active router-link-active">简体中文</a></li></ul></div></div> <a href="https://github.com/apache/incubator-iotdb.git" target="_blank" rel="noopener noreferrer" class="repo-link">
gitHub
<svg xmlns="http://www.w3.org/2000/svg" aria-hidden="true" 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></a></nav> <ul class="sidebar-links"><li><section class="sidebar-group depth-0"><p class="sidebar-heading"><span>系统设计</span> <!----></p> <!----></section></li><li><section class="sidebar-group collapsable depth-0"><p class="sidebar-heading"><span>应用概览</span> <span class="arrow right"></span></p> <!----></section></li><li><section class="sidebar-group collapsable depth-0"><p class="sidebar-heading"><span>TsFile</span> <span class="arrow right"></span></p> <!----></section></li><li><section class="sidebar-group collapsable depth-0"><p class="sidebar-heading"><span>查询引擎</span> <span class="arrow right"></span></p> <!----></section></li><li><section class="sidebar-group collapsable depth-0"><p class="sidebar-heading"><span>元数据管理</span> <span class="arrow right"></span></p> <!----></section></li><li><section class="sidebar-group collapsable depth-0"><p class="sidebar-heading"><span>存储引擎</span> <span class="arrow right"></span></p> <!----></section></li><li><section class="sidebar-group collapsable depth-0"><p class="sidebar-heading open"><span>数据查询</span> <span class="arrow down"></span></p> <ul class="sidebar-links sidebar-group-items"><li><a href="/zh/SystemDesign/DataQuery/DataQuery.html" class="sidebar-link">数据查询</a></li><li><a href="/zh/SystemDesign/DataQuery/QueryFundamentals.html" class="sidebar-link">查询基础介绍</a></li><li><a href="/zh/SystemDesign/DataQuery/SeriesReader.html" class="sidebar-link">查询基础组件</a></li><li><a href="/zh/SystemDesign/DataQuery/RawDataQuery.html" class="sidebar-link">原始数据查询</a></li><li><a href="/zh/SystemDesign/DataQuery/AggregationQuery.html" class="sidebar-link">聚合查询</a></li><li><a href="/zh/SystemDesign/DataQuery/GroupByQuery.html" class="sidebar-link">降采样查询</a></li><li><a href="/zh/SystemDesign/DataQuery/LastQuery.html" class="sidebar-link">最近时间戳 Last 查询</a></li><li><a href="/zh/SystemDesign/DataQuery/AlignByDeviceQuery.html" class="sidebar-link">按设备对齐查询</a></li><li><a href="/zh/SystemDesign/DataQuery/FillFunction.html" aria-current="page" class="active sidebar-link">空值填充</a></li><li><a href="/zh/SystemDesign/DataQuery/GroupByFillQuery.html" class="sidebar-link">降采样补空值查询</a></li></ul></section></li><li><section class="sidebar-group collapsable depth-0"><p class="sidebar-heading"><span>工具</span> <span class="arrow right"></span></p> <!----></section></li><li><section class="sidebar-group collapsable depth-0"><p class="sidebar-heading"><span>连接器</span> <span class="arrow right"></span></p> <!----></section></li><li><section class="sidebar-group collapsable depth-0"><p class="sidebar-heading"><span>客户端</span> <span class="arrow right"></span></p> <!----></section></li></ul> </aside> <main class="page"> <div class="content content__default"><h1 id="空值填充"><a href="#空值填充" class="header-anchor">#</a> 空值填充</h1> <p>空值填充的主要逻辑在 FillQueryExecutor</p> <ul><li>org.apache.iotdb.db.query.executor.FillQueryExecutor</li></ul> <p>IoTDB 中支持两种填充方式,Previous填充和Linear填充。</p> <h2 id="previous填充"><a href="#previous填充" class="header-anchor">#</a> Previous填充</h2> <p>Previous填充是使用离查询时间戳最近且小于等于查询时间戳的值来进行填充的一种方式,下图展示了一种可能的填充情况。</p> <div class="language- line-numbers-mode"><pre class="language-text"><code> |
+-------------------------+ |
| seq files | |
+-------------------------+ |
|
+---------------------------+
| unseq files | |
+---------------------------+
|
|
queryTime
</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><h2 id="设计原理"><a href="#设计原理" class="header-anchor">#</a> 设计原理</h2> <p>在实际生产场景中,可能需要在大量的顺序和乱序TsFile中查找可用的填充值,因此解开大量TsFile文件会成为性能瓶颈。我们设计的思路在于尽可能的减少需要解开tsFile文件的个数,从而加速找到填充值这一过程。</p> <h2 id="顺序文件查找-最近点"><a href="#顺序文件查找-最近点" class="header-anchor">#</a> 顺序文件查找&quot;最近点&quot;</h2> <p>首先在顺序文件中查询满足条件的&quot;最近点&quot;。由于所有顺序文件及其所有包含的chunk数据都已经按照顺序排列,因此这个&quot;最近点&quot;可以通过<code>retrieveValidLastPointFromSeqFiles()</code>方法很容易找到。</p> <p>这个找到的&quot;最近点&quot;是可以成为Previous填充的最终值的,因此它在接下来的搜索中能够被用来作为下界来寻找其他更好的的填充值。接下来只有那些时间戳大于这个下界的点才是Previous填充的结果值。</p> <p>下例中的unseq 文件由于其最大值没有超过&quot;最近点&quot;,因此不需要再进一步搜索。</p> <div class="language- line-numbers-mode"><pre class="language-text"><code> last point
| |
+---------------------------+
| seq file | | |
+---------------------------+
+-------------------------+ | |
| unseq file | | |
+-------------------------+ | |
| |
|
queryTime
</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><h2 id="筛选乱序文件"><a href="#筛选乱序文件" class="header-anchor">#</a> 筛选乱序文件</h2> <p>筛选并解开乱序文件的逻辑在成员函数<code>UnpackOverlappedUnseqFiles(long lBoundTime)</code>中,该方法接受一个下界参数,将满足要求的乱序文件解开且把它们的TimeseriesMetadata结构存入<code>unseqTimeseriesMetadataList</code>中。</p> <p><code>UnpackOverlappedUnseqFiles(long lBoundTime)</code>方法首先用 <code>lBoundTime</code>排除掉不满足要求的乱序文件,剩下被筛选后的乱序文件都一定会包含<code>queryTime</code>时间戳,即startTime &lt;= queryTime and queryTime &lt;= endTime。如果乱序文件的start time大于<code>lBoundTime</code>,更新<code>lBoundTime</code></p> <p>下图中,case 1中的<code>lBoundTime</code>将会被更新,而case 2中的则不会被更新。</p> <div class="language- line-numbers-mode"><pre class="language-text"><code>case1 case2
| | |
| +---------------------------+
| | | unseq file | |
| +---------------------------+
| | |
| | |
lBoundTime lBoundTime queryTime
</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><div class="language- line-numbers-mode"><pre class="language-text"><code>while (!unseqFileResource.isEmpty()) {
// The very end time of unseq files is smaller than lBoundTime,
// then skip all the rest unseq files
if (unseqFileResource.peek().getEndTimeMap().get(seriesPath.getDevice()) &lt; lBoundTime) {
return;
}
TimeseriesMetadata timeseriesMetadata =
FileLoaderUtils.loadTimeSeriesMetadata(
unseqFileResource.poll(), seriesPath, context, timeFilter, allSensors);
if (timeseriesMetadata != null &amp;&amp; timeseriesMetadata.getStatistics().canUseStatistics()
&amp;&amp; lBoundTime &lt;= timeseriesMetadata.getStatistics().getEndTime()) {
lBoundTime = Math.max(lBoundTime, timeseriesMetadata.getStatistics().getStartTime());
unseqTimeseriesMetadataList.add(timeseriesMetadata);
break;
}
}
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br><span class="line-number">2</span><br><span class="line-number">3</span><br><span class="line-number">4</span><br><span class="line-number">5</span><br><span class="line-number">6</span><br><span class="line-number">7</span><br><span class="line-number">8</span><br><span class="line-number">9</span><br><span class="line-number">10</span><br><span class="line-number">11</span><br><span class="line-number">12</span><br><span class="line-number">13</span><br><span class="line-number">14</span><br><span class="line-number">15</span><br><span class="line-number">16</span><br></div></div><p>接下来我们可以使用得到的Timeseries Metadata来查找所有其他重叠的乱序文件。需要注意的依旧是当一个重叠的乱序文件被找到后,需要按情况更新<code>lBoundTime</code></p> <div class="language- line-numbers-mode"><pre class="language-text"><code>while (!unseqFileResource.isEmpty()
&amp;&amp; (lBoundTime &lt;= unseqFileResource.peek().getEndTimeMap().get(seriesPath.getDevice()))) {
TimeseriesMetadata timeseriesMetadata =
FileLoaderUtils.loadTimeSeriesMetadata(
unseqFileResource.poll(), seriesPath, context, timeFilter, allSensors);
unseqTimeseriesMetadataList.add(timeseriesMetadata);
// update lBoundTime if current unseq timeseriesMetadata's last point is a valid result
if (timeseriesMetadata.getStatistics().canUseStatistics()
&amp;&amp; endtimeContainedByTimeFilter(timeseriesMetadata.getStatistics())) {
lBoundTime = Math.max(lBoundTime, timeseriesMetadata.getStatistics().getEndTime());
}
}
</code></pre> <div class="line-numbers-wrapper"><span class="line-number">1</span><br><span class="line-number">2</span><br><span class="line-number">3</span><br><span class="line-number">4</span><br><span class="line-number">5</span><br><span class="line-number">6</span><br><span class="line-number">7</span><br><span class="line-number">8</span><br><span class="line-number">9</span><br><span class="line-number">10</span><br><span class="line-number">11</span><br><span class="line-number">12</span><br></div></div><h2 id="组合最终结果"><a href="#组合最终结果" class="header-anchor">#</a> 组合最终结果</h2> <p>最终结果在方法<code>getFillResult()</code> 中生成。</p> <div class="language- line-numbers-mode"><pre class="language-text"><code>public TimeValuePair getFillResult() throws IOException {
TimeValuePair lastPointResult = retrieveValidLastPointFromSeqFiles();
UnpackOverlappedUnseqFiles(lastPointResult.getTimestamp());
long lastVersion = 0;
PriorityQueue&lt;ChunkMetadata&gt; sortedChunkMetatdataList = sortUnseqChunkMetadatasByEndtime();
while (!sortedChunkMetatdataList.isEmpty()
&amp;&amp; lastPointResult.getTimestamp() &lt;= sortedChunkMetatdataList.peek().getEndTime()) {
ChunkMetadata chunkMetadata = sortedChunkMetatdataList.poll();
TimeValuePair lastChunkPoint = getChunkLastPoint(chunkMetadata);
if (shouldUpdate(lastPointResult.getTimestamp(), lastVersion,
lastChunkPoint.getTimestamp(), chunkMetadata.getVersion())) {
lastPointResult = lastChunkPoint;
lastVersion = chunkMetadata.getVersion();
}
}
return lastPointResult;
}
</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></div></div><h1 id="linear-填充"><a href="#linear-填充" class="header-anchor">#</a> Linear 填充</h1> <p>对于T时间的 Linear Fill 线性填充值是由该时间序列的两个相关值做线性拟合得到的:T之前的最近时间戳对应的值,T之后的最早时间戳对应的值。
基于这种特点,线性填充只能被应用于数字类型如:int, double, float。</p> <h2 id="计算前时间值"><a href="#计算前时间值" class="header-anchor">#</a> 计算前时间值</h2> <p>前时间值使用与 Previous Fill 中相同方式计算.</p> <h2 id="计算后时间值"><a href="#计算后时间值" class="header-anchor">#</a> 计算后时间值</h2> <p>后时间值使用聚合运算中的&quot;MIN_TIME&quot;和&quot;FIRST_VALUE&quot;,分别计算出T时间之后最近的时间戳和对应的值,并组成time-value对返回。</p></div> <div class="page-nav"><p class="inner"><span class="prev">
<a href="/zh/SystemDesign/DataQuery/AlignByDeviceQuery.html" class="prev">
按设备对齐查询
</a></span> <span class="next"><a href="/zh/SystemDesign/DataQuery/GroupByFillQuery.html">
降采样补空值查询
</a>
</span></p></div> <p style="text-align: center;">Copyright © 2020 The Apache Software Foundation.<br>
Apache and the Apache feather logo are trademarks of The Apache Software Foundation</p> <p style="text-align:justify!important;paddingLeft:10px;paddingRight:10px;">
Disclaimer: Apache IoTDB (incubating) is an effort undergoing incubation at The Apache Software Foundation (ASF), sponsored by the Apache Incubator. Incubation is required of all newly accepted projects until a further review indicates that the infrastructure, communications, and decision making process have stabilized in a manner consistent with other successful ASF projects. While incubation status is not necessarily a reflection of the completeness or stability of the code, it does indicate that the project has yet to be fully endorsed by the ASF.
</p></main></div><div class="global-ui"></div></div>
<script src="/assets/js/app.aab05fb2.js" defer></script><script src="/assets/js/3.1dc302ea.js" defer></script><script src="/assets/js/239.a3762b13.js" defer></script>
</body>
</html>