视频1 视频21 视频41 视频61 视频文章1 视频文章21 视频文章41 视频文章61 推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37 推荐39 推荐41 推荐43 推荐45 推荐47 推荐49 关键词1 关键词101 关键词201 关键词301 关键词401 关键词501 关键词601 关键词701 关键词801 关键词901 关键词1001 关键词1101 关键词1201 关键词1301 关键词1401 关键词1501 关键词1601 关键词1701 关键词1801 关键词1901 视频扩展1 视频扩展6 视频扩展11 视频扩展16 文章1 文章201 文章401 文章601 文章801 文章1001 资讯1 资讯501 资讯1001 资讯1501 标签1 标签501 标签1001 关键词1 关键词501 关键词1001 关键词1501 专题2001
详解使用python操作InfluxDB方法
2020-11-27 14:25:37 责编:小采
文档


环境: CentOS6.5_x
InfluxDB版本:1.1.0
Python版本 : 2.6

准备工作

  • 启动服务器

  •   执行如下命令:

      service influxdb start

      示例如下:

    [root@localhost ~]# service influxdb start
    Starting influxdb...
    influxdb process was started [ OK ]
    [root@localhost ~]#
  • 安装influxdb-python

  • github地址:https://github.com/influxdata/influxdb-python

    安装pip :

    yum install python-pip

    安装influxdb-python :

    pip install influxdb

    基本操作

    使用InfluxDBClient类操作数据库,示例如下:

    from influxdb import InfluxDBClient
    client = InfluxDBClient('localhost', 8086, 'root', '', '') # 初始化
  • 显示已存在的所有数据库

  •   使用get_list_database函数,示例如下:

      print client.get_list_database() # 显示所有数据库名称

  • 创建新数据库

  •   使用create_database函数,示例如下:

      client.create_database('testdb') # 创建数据库

  • 删除数据库

  •   使用drop_database函数,示例如下:

      client.drop_database('testdb') # 删除数据库

    数据库操作完整示例如下:

    #! /usr/bin/env python
    #-*- coding:utf-8 -*-
    
    from influxdb import InfluxDBClient
    client = InfluxDBClient('localhost', 8086, 'root', '', '') # 初始化
    print client.get_list_database() # 显示所有数据库名称
    client.create_database('testdb') # 创建数据库
    print client.get_list_database() # 显示所有数据库名称
    client.drop_database('testdb') # 删除数据库
    print client.get_list_database() # 显示所有数据库名称

    表操作

    InfluxDBClient中要指定连接的数据库,示例如下:

    client = InfluxDBClient('localhost', 8086, 'root', '', 'testdb') # 初始化(指定要操作的数据库)
  • 显示指定数据库中已存在的表

  •   可以通过influxql语句实现,示例如下:

    result = client.query('show measurements;') # 显示数据库中的表print("Result: {0}".format(result))
  • 创建新表并添加数据

  • InfluxDB没有提供单独的建表语句,可以通过并添加数据的方式建表,示例如下:

    json_body = [
     {
     "measurement": "students",
     "tags": {
     "stuid": "s123"
     },
     #"time": "2017-03-12T22:00:00Z",
     "fields": {
     "score": 
     }
     }
    ]
    
    client = InfluxDBClient('localhost', 8086, 'root', '', 'testdb') # 初始化(指定要操作的数据库)
    client.write_points(json_body) # 写入数据,同时创建表
  • 删除表

  • 可以通过influxql语句实现,示例如下:

    client.query("drop measurement students") # 删除表

    数据表操作完整示例如下:

    #! /usr/bin/env python
    #-*- coding:utf-8 -*-
    
    from influxdb import InfluxDBClient
    
    json_body = [
     {
     "measurement": "students",
     "tags": {
     "stuid": "s123"
     },
     #"time": "2017-03-12T22:00:00Z",
     "fields": {
     "score": 
     }
     }
    ]
    
    def showDBNames(client):
     result = client.query('show measurements;') # 显示数据库中的表
     print("Result: {0}".format(result))
    
    client = InfluxDBClient('localhost', 8086, 'root', '', 'testdb') # 初始化(指定要操作的数据库)
    showDBNames(client)
    client.write_points(json_body) # 写入数据,同时创建表
    showDBNames(client)
    client.query("drop measurement students") # 删除表
    showDBNames(client)

    数据操作

    InfluxDBClient中要指定连接的数据库,示例如下:

    client = InfluxDBClient('localhost', 8086, 'root', '', 'testdb') # 初始化(指定要操作的数据库)
  • 添加

  • 可以通过write_points实现,示例如下:

    json_body = [
     {
     "measurement": "students",
     "tags": {
     "stuid": "s123"
     },
     #"time": "2017-03-12T22:00:00Z",
     "fields": {
     "score": 
     }
     }
    ]
    
    client.write_points(json_body) # 写入数据
  • 查询

  • 可以通过influxql语句实现,示例如下:

    result = client.query('select * from students;') 
    print("Result: {0}".format(result))
  • 更新

  • tags 和 timestamp相同时数据会执行覆盖操作,相当于InfluxDB的更新操作。

  • 删除

  • 使用influxql语句实现,delete语法,示例如下:

    client.query('delete from students;') # 删除数据

    数据操作完整示例如下:

    #! /usr/bin/env python
    #-*- coding:utf-8 -*-
    
    from influxdb import InfluxDBClient
    
    json_body = [
     {
     "measurement": "students",
     "tags": {
     "stuid": "s123"
     },
     #"time": "2017-03-12T22:00:00Z",
     "fields": {
     "score": 
     }
     }
    ]
    
    def showDatas(client):
     result = client.query('select * from students;')
     print("Result: {0}".format(result))
    
    client = InfluxDBClient('localhost', 8086, 'root', '', 'testdb') # 初始化
    client.write_points(json_body) # 写入数据
    showDatas(client) # 查询数据
    client.query('delete from students;') # 删除数据
    showDatas(client) # 查询数据

    好,就这些了,希望对你有帮助。

    下载本文
    显示全文
    专题