首頁 > 軟體

python 包 redis 資料庫的操作教學

2022-04-19 13:00:09

一、安裝

  • redis 是一個 Key-Value 資料庫
  • Value 支援 string(字串),list(列表),set(集合),zset(有序集合),hash(雜湊型別)等型別
pip install redis

二、連線

import redis

# 方式一
r = redis.StrictRedis(host='localhost', port=6379, db=0)

# 方式二
r = redis.Redis(host='localhost', port=6379, decode_responses=True)

# 方式三,連線池
pool = redis.ConnectionPool(host='localhost', port=6379, decode_responses=True)
r = redis.Redis(host='localhost', port=6379, decode_responses=True)

三、string基本命令

import redis

r = redis.Redis(host='localhost', port=6379, decode_responses=True)

# 設定值並設定過期時間, ex單位: 秒
r.set('food', 'mutton', ex=3)
# 獲取值
r.get('food')
# 設定值並設定過期時間, px單位: 毫秒
r.set('food', 'beef', px=3)
# nx=True時,則只有name不存在時,當前set操作才執行
r.set('fruit', 'watermelon', nx=True)
# xx=True時,則只有name存在時,當前set操作才執行
r.set('fruit', 'watermelon', xx=True)
# setnx設定值,只有name不存在時,執行設定操作
r.setnx('fruit1', 'banana')
# setex第一個引數是key,第二個是過期時間(秒),第三個是值
r.setex("fruit2", 5, "orange")
# psetex第一個引數是key,第二個是過期時間(毫秒),第三個是值
r.psetex("fruit3", 5000, "apple")
# 批次設定值 mset(*args, **kwargs)
r.mset(k1="v1", k2="v2")
# 批次獲取
r.mget('k1', 'k2')
r.mget(['k1', 'k2'])
# 設定新值並獲取原來的值
r.getset("food", "barbecue")
# 獲取子序列(根據位元組獲取,非字元)
r.getrange("cn_name", 0, 2)
r.getrange("en_name", 0, -1)
# 修改字串內容,從指定字串索引開始向後替換(新值太長時,則向後新增)
r.setrange("en_name", 1, "ccc")
# 對 name 對應值的二進位制表示的位進行操作
r.setbit(name, offset, value)
# 獲取name對應的值的二進位制表示中的某位的值,0或1
r.getbit("foo1", 0)
# 獲取name對應的值的二進位制表示中 1 的個數
r.bitcount("foo",0,1)
# 獲取多個值,並將值做位運算,將最後的結果儲存至新的name對應的值
r.bitop("AND","new","foo","foo1")
# 返回name對應值的位元組長度(一個漢字3個位元組)
r.strlen("foo")
# 自增 name 對應的值,當 name 不存在時,則建立 name=amount,否則,則自增。
r.incr("foo", amount=1)
# 自增 name對應的值,當name不存在時,則建立name=amount,否則,則自增。
r.incrbyfloat("foo1", amount=2.0)
# 自減 name 對應的值,當 name 不存在時,則建立 name=amount,否則,則自減。
r.decr("foo4", amount=3)
# 在redis name對應的值後面追加內容
r.append("name", "haha")

四、hash基本命令

import redis

r = redis.Redis(host='localhost', port=6379, decode_responses=True)

# name對應的hash中設定一個鍵值對(不存在,則建立;否則,修改)
r.hset("hash1", "k1", "v1")
# 在name對應的hash中批次設定鍵值對
r.hmset("hash2", {"k2": "v2", "k3": "v3"})
# 在name對應的hash中獲取根據key獲取value
r.hmget("hash2", "k2", "k3")
r.hmget("hash2", ["k2", "k3"])
# 取出所有的鍵值對
r.hgetall("hash1")
# 得到所有鍵值對的格式 hash長度
r.hlen("hash1")
# 得到所有的keys(類似字典的取所有keys)
r.hkeys("hash1")
# 得到所有的value(類似字典的取所有value)
r.hvals("hash1")
# 判斷成員是否存在(類似字典的in)
r.hexists("hash1", "k4")
# 刪除鍵值對
r.hdel("hash1", "k1")
# 自增自減整數
r.hincrby("hash1", "k3", amount=-1)
# 自增自減浮點數
r.hincrbyfloat("hash1", "k5", amount=-1.0)
# 取值檢視--分片讀取
r.hscan("hash1")
# 利用yield封裝hscan建立生成器,實現分批去redis中獲取資料
for item in r.hscan_iter('hash1'):
print(item)
print(r.hscan_iter("hash1"))

五、list基本命令

import redis

r = redis.Redis(host='localhost', port=6379, decode_responses=True)

# 增加 (從左邊新增加)--沒有就新建
r.lpush("list1", 11, 22, 33)
# 增加(從右邊增加)--沒有就新建
r.rpush("list2", 11, 22, 33)
# 在name對應的list中新增元素,只有name已經存在時,值新增到列表的最左邊
r.lpushx("list10", 10)
# 往已經有的name的列表的右邊新增元素,沒有的話無法建立
r.rpushx("list2", 99)
# 在name對應的列表的某一個值前或後插入一個新值
r.linsert("list2", "before", "11", "00")
# 修改(指定索引號進行修改)
r.lset("list2", 0, -11)
# 刪除(指定值進行刪除)
r.lrem("list2", "11", 1)
# 刪除並返回
r.lpop("list2") # 刪除列表最左邊的元素,並且返回刪除的元素
r.rpop("list2") # 刪除列表最右邊的元素,並且返回刪除的元素
# 刪除索引之外的值
r.ltrim("list2", 0, 2)
# 根據索引號取值
r.lindex("list2", 0)
# 移動 元素從一個列表移動到另外一個列表
r.rpoplpush("list1", "list2")
# 移動 元素從一個列表移動到另外一個列表 可以設定超時
r.brpoplpush("list1", "list2", timeout=2)
# 一次移除多個列表
r.blpop(["list10", "list11"], timeout=2)
# 自定義增量迭代
def list_iter(name):
"""
自定義redis列表增量迭代
:param name: redis中的name,即:迭代name對應的列表
:return: yield 返回 列表元素
"""
list_count = r.llen(name)
for index in range(list_count):
yield r.lindex(name, index)

六、set基本命令

import redis

r = redis.Redis(host='localhost', port=6379, decode_responses=True)

# 新增
r.sadd("set1", 33, 44, 55, 66)
# 獲取元素個數 類似於len
r.scard("set1")
# 獲取集合中所有的成員
r.smembers("set1")
# 獲取集合中所有的成員--元組形式
r.sscan("set1")
# 獲取集合中所有的成員--迭代器的方式
for i in r.sscan_iter("set1"):
print(i)
# 差集
r.sdiff("set1", "set2")
# 差集--差集存在一個新的集合中
r.sdiffstore("set3", "set1", "set2")
# 交集
r.sinter("set1", "set2")
# 交集--交集存在一個新的集合中
r.sinterstore("set3", "set1", "set2")
# 並集
r.sunion("set1", "set2")
# 並集--並集存在一個新的集合
r.sunionstore("set3", "set1", "set2")
# 判斷是否是集合的成員 類似in
r.sismember("set1", 33)
# 移動 將某個成員從一個集合中移動到另外一個集合
r.smove("set1", "set2", 44)
# 刪除--隨機刪除並且返回被刪除值
r.spop("set2")
# 刪除--指定值刪除
r.srem("set2", 11)

七、zset基本命令

import redis

r = redis.Redis(host='localhost', port=6379, decode_responses=True)

# 新增
r.zadd("zset2", 'm1', 22, 'm2', 44)
# 獲取有序集合元素個數 類似於len
r.zcard("zset1")
# 獲取有序集合的所有元素
r.zrevrange("zset1", 0, -1)
# 獲取所有元素--迭代器
for i in r.zscan_iter("zset3"): # 遍歷迭代器
print(i)
# 獲取name對應的有序集合中分數 在 [min,max] 之間的個數
r.zcount("zset3", 11, 22)
# 自增
r.zincrby("zset3", "n2", amount=2)
# 獲取值的索引號
r.zrank("zset3", "n1")
# 刪除--指定值刪除
r.zrem("zset3", "n3")
# 刪除--根據排行範圍刪除,按照索引號來刪除
r.zremrangebyrank("zset3", 0, 1)
# 刪除--根據分數範圍刪除
r.zremrangebyscore("zset3", 11, 22)
# 獲取值對應的分數
r.zscore("zset3", "n27")

八、其他通用命令

import redis

r = redis.Redis(host='localhost', port=6379, decode_responses=True)

# 刪除 根據刪除redis中的任意資料型別
r.delete("gender")
# 檢查名字是否存在
r.exists("zset1")
# 模糊匹配 根據模型獲取redis的name
r.keys("foo*")
# 設定超時時間
r.expire("list5", time=3)
# 重新命名
r.rename("list5", "list5-1")
# 隨機獲取name
r.randomkey()
# 獲取型別
r.type("set1")
# 查詢所有的Key
r.keys()
# 當前redis包含多少條資料
r.dbsize()
# 清空r中的所有資料
r.flushdb()

九、管道命令

  • redis預設在執行每次請求都會建立(連線池申請連線)和斷開(歸還連線池)一次連線操作
  • 如果想要在一次請求中指定多個命令,則可以使用pipline實現一次請求指定多個命令
  • 並且預設情況下一次pipline 是原子性操作
  • 管道(pipeline)是redis在提供單個請求中緩衝多條伺服器命令的基礎類別的子類
  • 它通過減少伺服器-使用者端之間反覆的TCP資料庫包
  • 從而大大提高了執行批次命令的功能
import redis

r = redis.Redis(host='localhost', port=6379, decode_responses=True)

# 預設的情況下,管道里執行的命令可以保證執行的原子性
# 預設 pipe = r.pipeline(transaction=True)
# 禁止 pipe = r.pipeline(transaction=False)

# 建立一個管道
pipe = r.pipeline()

pipe.set('name', 'jack')
pipe.set('role', 'sb')
pipe.sadd('faz', 'baz')
pipe.incr('num')
pipe.execute()

# 或者寫成 pipe.set('hello', 'redis').sadd('faz', 'baz').incr('num').execute()

print(r.get("name"))
print(r.get("role"))
print(r.get("num"))

到此這篇關於python 包 redis 資料庫的操作教學的文章就介紹到這了,更多相關 redis 資料庫操作 內容請搜尋it145.com以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援it145.com!


IT145.com E-mail:sddin#qq.com