\u521b\u5efa\u5b9e\u65f6\u6570\u636e\u8868\u683c<\/strong><\/h4>\n\n\n\n\u4e3a\u5e73\u53f0\u4e2d\u7684\u6bcf\u79cd\u8bbe\u5907\u7c7b\u578b\u521b\u5efa\u4e00\u4e2a\u72ec\u7acb\u7684\u8d85\u7ea7\u8868\uff08super table\uff09\uff0c\u4e3a\u6bcf\u79cd\u8bbe\u5907\u7c7b\u578b\u4e0b\u7684\u6bcf\u4e2a\u5177\u4f53\u8bbe\u5907\u521b\u5efa\u72ec\u7acb\u7684\u8bbe\u5907\u5b50\u8868\u3002<\/p>\n\n\n\n
create stable if not exists product_${productKey} (ts timestamp,linestate bool,${device_properties}) tags (device_code binary(64));<\/code>\ncreate table if not exists device_${device_code} using product_${productKey} tags (${device_code})<\/code><\/pre>\n\n\n\n<\/h4>\n\n\n\n\u521b\u5efa\u72b6\u6001\u8868<\/strong><\/h4>\n\n\n\n\u4e3a\u5e73\u53f0\u4e2d\u6240\u6709\u8bbe\u5907\u521b\u5efa\u4e00\u4e2a\u5171\u540c\u7684\u8d85\u7ea7\u8868\u3002<\/p>\n\n\n\n
create stable if not exists device_state (ts timestamp,linestate bool,run_status int,error_code binary(64),run_total_time int,stop_total_time int,error_total_time int) tags (device_code binary(64),product_key binary(64));<\/code>\ncreate table if not exists device_state_${device_code} using device_state tags (${device_code},${productKey})<\/code><\/pre>\n\n\n\n\u6307\u6807\u8ba1\u7b97<\/strong><\/h4>\n\n\n\n\u6211\u4eec\u57fa\u4e8e JEXL \u8868\u8fbe\u5f0f + \u5b9e\u65f6\u67e5\u8be2\u7684\u65b9\u5f0f\u5b9e\u73b0\u4e86\u7cfb\u7edf\u4e2d\u7684\u6307\u6807\u8ba1\u7b97\u3002\u6211\u4eec\u4f7f\u7528 JEXL \u8868\u8fbe\u5f0f\u6765\u5b9a\u4e49\u6307\u6807\u7684\u8ba1\u7b97\u8868\u8fbe\u5f0f\uff0c\u7cfb\u7edf\u89e3\u6790\u540e\u5c06\u53d8\u91cf\u66ff\u6362\u6210 SQL \u67e5\u8be2\u4efb\u52a1\uff0c\u5728\u67e5\u8be2\u8fd4\u56de\u7ed3\u679c\u540e\u518d\u5230\u7cfb\u7edf\u4e2d\u8fdb\u884c\u8ba1\u7b97\uff0c\u8fd4\u56de\u81f3\u524d\u7aef\u3002<\/p>\n\n\n\n
\u6bd4\u5982\u8ba1\u7b97\u67d0\u9879\u76ee\u4e0b\u6240\u6709\u8bbe\u5907\u5f53\u524d\u7535\u538b\u7684\u5e73\u5747\u503c\uff0c\u5176\u8868\u8fbe\u5f0f\u4e3a avg(voltage,run_status=1 && project=abc)\uff0c\u5b83\u4f1a\u88ab\u5206\u89e3\u4e3a\uff1a1\uff09\u67e5\u8be2 run_status=1 && project=abc \u7684\u6240\u6709\u8bbe\u5907\uff1b2\uff09\u67e5\u8be2\u7b2c\u4e00\u6b65\u7ed3\u679c\u4e2d\u6240\u6709\u8bbe\u5907 voltage \u5b57\u6bb5\u7684\u6700\u65b0\u503c\uff1b3\uff09\u8ba1\u7b97\u7b2c\u4e8c\u6b65\u6240\u6709\u8bbe\u5907\u6700\u65b0\u7ed3\u679c\u7684\u5e73\u5747\u503c\u3002<\/p>\n\n\n\n
\u5f97\u76ca\u4e8e\u591a\u7ebf\u7a0b\u548c TDengine \u9ad8\u6548\u7684\u67e5\u8be2\u8868\u73b0\uff0c\u5355\u4e2a KPI \u7684\u67e5\u8be2 P99 \u8868\u73b0\u5c0f\u4e8e 100ms\u3002<\/p>\n\n\n\n