InfluxDB : データベース 基本操作2022/11/16 |
InfluxDB のデータベースの基本操作です。
|
|
[1] | データベースを作成する。 |
[root@dlp ~]# influx -username admin -password adminpassword Connected to http://localhost:8086 version 1.8.10 InfluxDB shell version: 1.8.10 # [test_database] 作成 > create database test_database > show databases name: databases name ---- _internal test_database > show users user admin ---- ----- admin true serverworld true centos false # [serverworld] ユーザーに [test_database] の全権限を付与 > grant all on "test_database" to "serverworld" # [centos] ユーザーに [test_database] の [read] 権限を付与 > grant read on "test_database" to "centos" > show grants for "serverworld" database privilege -------- --------- test_database ALL PRIVILEGES > exit |
[2] | データベースにデータを投入する。 |
# InfluxDB のデータ形式
# ⇒ measurement,tag_set field_set timestamp
# insert <measurement>[,<tag_key>=<tag_value>[,<tag_key>=<tag_value>]] <field_key>=<field_value>[,<field_key>=<field_value>] [<timestamp>]
#
# [tag_set] はオプショナル
# [timestamp] は省略可 ⇒ 省略した場合は現在の UNIX Time (ナノ秒単位) が使用される
# UNIX Time (ナノ秒) は [date] コマンドで確認可 ⇒ $ date +%s%N
# [test_database] に接続 [root@dlp ~]# influx -username serverworld -password userpassword -database test_database Connected to http://localhost:8086 version 1.8.10 InfluxDB shell version: 1.8.10 # [cpu] メジャメントに [idle] 値をセットしてデータ投入 > insert cpu idle=99.50 > insert cpu idle=99.00 > insert cpu idle=99.30 > select * from cpu name: cpu time idle ---- ---- 1668560387734915114 99.5 1668560390914406080 99 1668560394274894937 99.3 # [weather] メジャメントに [location] タグと [temperature] 値をセットしてデータ投入 > insert weather,location=hiroshima temperature=20 > insert weather,location=hiroshima temperature=22 > insert weather,location=osaka temperature=18 > insert weather,location=osaka temperature=19 > select * from weather name: weather time location temperature ---- -------- ----------- 1668560449505414137 hiroshima 20 1668560453481923962 hiroshima 22 1668560457786432353 osaka 18 1668560461579212003 osaka 19 # [WHERE] で条件を指定して表示 > select * from weather where "location" = 'hiroshima' and temperature <= 20 name: weather time location temperature ---- -------- ----------- 1668560449505414137 hiroshima 20 # [timestamp] を RFC3339 で表示 > precision rfc3339 > select * from weather name: weather time location temperature ---- -------- ----------- 2022-11-16T01:00:49.505414137Z hiroshima 20 2022-11-16T01:00:53.481923962Z hiroshima 22 2022-11-16T01:00:57.786432353Z osaka 18 2022-11-16T01:01:01.579212003Z osaka 19 > exit |
[3] | データを削除する。 |
# RFC3339 を指定して接続 [root@dlp ~]# influx -username serverworld -password userpassword -database test_database -precision rfc3339 Connected to http://localhost:8086 version 1.8.10 InfluxDB shell version: 1.8.10 > select * from weather name: weather time location temperature ---- -------- ----------- 2022-11-16T01:08:49.962037857Z hiroshima 20 2022-11-16T01:08:54.594667745Z hiroshima 22 2022-11-16T01:08:59.707172393Z osaka 18 2022-11-16T01:09:06.483927581Z osaka 19 # [timestamp] が [2022-11-16 01:08:50] より以前のデータを削除 > delete from weather where time <= '2022-11-16 01:08:50' > select * from weather name: weather time location temperature ---- -------- ----------- 2022-11-16T01:08:54.594667745Z hiroshima 22 2022-11-16T01:08:59.707172393Z osaka 18 2022-11-16T01:09:06.483927581Z osaka 19 # [location = hiroshima] のデータを削除 > drop series from "weather" where "location" = 'hiroshima' # * delete *** ⇒ Index から系列を削除しない, Time Interval による条件指定可 # * drop *** ⇒ Index から系列を削除, Time Interval による条件指定不可 # [measurement] を削除する場合は以下 > drop measurement "cpu" > show measurements name: measurements name ---- weather # データベースを削除する場合は以下 > drop database "test_database" > show databases name: databases name ---- _internal > exit |
Sponsored Link |