Redis

Redis数据库

为什么要学习redis

1、redis是内存 no-sql 数据库,相比mysql等硬盘数据库效率高
2、在内存中配置数据库使用,而不直接使用内存,redis存储的数据是可以管理的
3、memcache也是内存数据库,且django默认采用的就是memcache数据库,用redis替换memcache的路由很简单,后者更强大
    redis支持更多的数据类型
    redis自带缓存机制,出现数据库系统崩溃数据也是可以有找回的功能
    redis可以主动完成数据持久化(自带数据持久化功能    redis的数据过期时间机制也可以自身完成

基础指令

连接指令
>: redis-cli
>: shutdown
>: exit 启动服务
>: redis-server >: redis-server & # 关闭cmd窗口后持续启动 启动客户端连接redis并制定连接库 >: redis-cli -h localhost -p 6379 -n 数据库编号(0~15)
>: redis-cli -n 数据库编号(0-15) # 简写 连接成功后切换数据库
>: select 数据库编号

redis数据类型

支持的数据类型:String、Hash、List、Set、Sorted Set
​
String:存储其他类型不能存的所有数据
Hash:存储 key-value 形式数据,类似于字典
List:存储 一系列有序value 形式数据,列表(数组)
Set:存储 一系列无序value 形式数据,集合
Sorted Set:存储 有排列标号value 形式数据,排行

1.python连接Redis数据库:

下载

>: pip install redis

 

1)直接连接

import redis

red = redis.Redis(host='localhost',port=6379,db=1)
red = redis.Redis(db=1)  # 简写

 

2)连接池连接

连接池的原理是, 通过预先创建多个连接, 当进行redis操作时, 直接获取已经创建的连接进行操作, 而且操作完成后, 不会释放, 用于后续的其他redis操作,这样就达到了避免频繁的redis连接创建和释放的目的, 从而提高性能。redis模块采用ConnectionPool来管理对redis server的所有连接。

import redis

pool = redis.ConnectionPool(host='localhost', port=6379,db=1)
red = redis.Redis(connection_pool=pool)
red.set('key1', 'value1')
red.set('key2', 'value2')

 

2.String类型存取:

set(self, name, value, ex=None, px=None, nx=False, xx=False)

#在Redis中设置值,默认不存在则创建,存在则修改
red.set('key', 'value')
#参数:
#     set(name, value, ex=None, px=None, nx=False, xx=False)
#     ex,过期时间(秒)
#     px,过期时间(毫秒)
#     nx,如果设置为True,则只有key不存在时,当前set操作才执行,同#setnx(key, value)
#     xx,如果设置为True,则只有key存在时,当前set操作才执行


setex(self, name, value, time)
#设置过期时间(秒)

psetex(self, name, time_ms, value)
#设置过期时间(豪秒)

 

mset(self, *args, **kwargs)

#批量设置值
red.mget({"key1":'value1', "key2":'value2'})

 

get(self, name)

#获取某个key的值
red.get('key1')

 

mget(self, keys, *args)

#批量获取
red.mget("key1","key1")

 

strlen(self, name)

#返回key对应值的字节长度(一个汉字3个字节)
red.strlen("key")

 

append(name, value)

#在name对应的值后面追加内容
red.set("key","value")
print(r.get("key"))    #输出:'value'
r.append("key","one")
print(r.get("key"))    #输出:'valueone'

 

3.Hash类型:一个name对应一个dic字典来存储。

hset(self, name, key, value)

#name对应的hash中设置一个键值对(不存在,则创建,否则,修改)
red.hset("name","key","value")

 

hget(self, name, key)

red.hset("name","key","value")
#在name对应的hash中根据key获取value
print(red.hget("name","key"))#输出:'value'

 

hgetall(self, name)

#获取name所有键值对
red.hgetall("name")

 

hmset(self, name, mapping)

#在name对应的hash中批量设置键值对,mapping:字典
dic={"key1":"aa","key2":"bb"}
red.hmset("name",dic)
print(red.hget("name","key2"))#输出:bb

 

hmget(self, name, keys, *args)

#在name对应的hash中批量获取键所对应的值
dic={"key1":"aa","key2":"bb"}
red.hmset("name",dic)
print(red.hmget("name","key1","key2"))#输出:['aa', 'bb']

 

hlen(self, name)

#获取hash键值对的个数
print(red.hlen("name"))#输出:2

 

hkeys(self, name)

#获取hash中所有key
red.hkeys("name")

 

hvals(self, name)

#获取hash中所有value
red.hvals("name")

 

hexists(self, name, key)

#检查name对应的hash是否存在当前传入的key
print(red.hexists("name","key1"))#输出:Ture

 

hdel(self, name, *keys)

#删除指定name对应的key所在的键值对,删除成功返回1,失败返回0
print(red.hdel("name","key1"))#输出:1

 

hincrby(self, name, key, amount=1)

#与hash中key对应的值相加,不存在则创建key=amount(amount为整数)
print(red.hincrby("name","key",amount=10))#返回:10

 

4.list类型:一个name对应一个列表存储。

lpush(self, name, *values)

#元素从list的左边添加,可以添加多个
red.lpush('name','元素1','元素2')

 

rpush(self, name, *values)

#元素从list右边添加,可以添加多个
red.rpush('name','元素1','元素2')

 

lpushx(self, name, *values)

#当name存在时,元素才能从list的左边加入
red.lpushx('name','元素1')

 

rpushx(self, name, *values)

#当name存在时,元素才能从list的右边加入
red.rpushx('name','元素1')

 

 llen(self, name)

#name列表长度
red.llen('name')

 

linsert(self, name, where, refvalue, value)

# 在name对应的列表的某一个值前或后插入一个新值
red.linsert("name","BEFORE","元素2","元素1.5")#在列表内找到第一个"元素2",在它前面插入"元素1.5"

#参数:
#     name: redis的name
#     where: BEFORE(前)或AFTER(后)
#     refvalue: 列表内的值
#     value: 要插入的数据

 

lset(self, name, index, value)

#对list中的某一个索引位置重新赋值
red.lset("name",0,"abc")

 

lrem(self, name, value, num=0)

#删除name对应的list中的指定值
red.lrem("name","元素1",num=0)

# 参数:
#    name:  redis的name
#    value: 要删除的值
#    num:   num=0 删除列表中所有的指定值;
#           num=2 从前到后,删除2个;
#           num=-2 从后向前,删除2个'''

 

lpop(self, name)

#移除列表的左侧第一个元素,返回值则是第一个元素
print(red.lpop("name"))

 

lindex(self, name, index)

#根据索引获取列表内元素
print(red.lindex("name",1))

 

lrange(self, name, start, end)

#分片获取元素
print(red.lrange("name",0,-1))

 

ltrim(self, name, start, end)

#移除列表内没有在该索引之内的值
red.ltrim("name",0,2) 

5.set类型:集合是不允许重复的列表

sadd(self, name, *values)

#给name对应的集合中添加元素
red.sadd("name","aa")
red.sadd("name","aa","bb")

 

scard(self, name)

#获取name对应的集合中的元素个数
red.scard("name")

 

smembers(self, name)

#获取name对应的集合的所有成员
red.smembers('name')

 

sdiff(self, keys, *args)

#在第一个name对应的集合中且不在其他name对应的集合的元素集合
red.sadd("name","aa","bb")
red.sadd("name1","bb","cc")
red.sadd("name2","bb","cc","dd")

print(red.sdiff("name","name1","name2"))#输出:{aa}

 

sismember(self, name, value)

#检查value是否是name对应的集合内的元素

 

smove(self, src, dst, value)

#将某个元素从一个集合中移动到另外一个集合

 

spop(self, name)

#从集合的右侧移除一个元素,并将其返回
posted @ 2019-10-30 08:41  waller  阅读(111)  评论(0编辑  收藏  举报