Python之操作redis数据库
使用redis模块
一、操作redis
1、添加信息
(1)直接建key-value信息:
- 右键-Add New Key,手动添加key和value


- 右键-Console,打开控制台,写入命令


(2)建个文件夹,在文件夹里面建key-value信息:
只需在Add New Key的Key中建立文件夹名:key即可。


多个冒号就是多个文件夹。
2、存储类型
(1)String类型:

(2)哈希hash类型:

二、Python操作redis数据库步骤
1、导入redis模块
2、建立连接
3、写入命令
import redis ip='xxx.xx.xx.xx'
password='' r=redis.Redis(host=ip,password=password,port=6379,db=1) res=r.get('lrx2')
print(res) #结果为:b'\xe5\x97\xafohyeah234324'
#结果是二进制类型的,需要将二进制类型的转成字符串类型 res.decode()
#.decode()是二进制类型转成字符串
print(res.decode()) #结果为:嗯ohyeah234324
#字符串转成byte二进制类型
res.encode()
#二进制转成字符串类型
res.decode()
三、操作命令——string类型
1、删除数据库里所有的key
- 使用.flushdb()方法
r.flushdb() #删除这个数据库里的所有Key
2、获取所有的key
- 使用.keys('key')方法
print(r.keys('session*')) #获取所有的只以session开头的key
3、新增和修改
- 使用.set('key','value')方法
r.set('lrx','sfdsdf1232')#新增和修改都是它
4、删除
使用.delete('key')方法
r.delete('lrx') #删除指定的key
5、获取值
- 使用.get('key')方法
r.get('lrx') #获取key为lrx的value值
四、操作命令——哈希(hash)类型
格式:
二层字典
session={
"nhy":{'sex':'男','age':18},
"nhy2":{'sex':'男','age':18},
}
优点:
- 管理方便,易于查找。
- 返回值直接就是字典,不是字符串。
1、新增和修改
- 使用.hset('key')方法
r.hset('lrx_stus','xiaohong','{"age":23,"addr":"上海"}')
#大key 小key

2、获取指定value值
- 使用.hget('大key','小key')方法
res=r.hget('lrx_stu','xiaohong') #指定获取里面小key的值
3、获取所有的小key
- 使用.hgetall('大key')方法
res=r.hgetall('lrx_stus') #获取到大key里面所有的数据
print(res)
4、删除大key
- 使用.delete('大key')方法
r.delete('lrx_stus') #删除大key
5、删除小key
- 使用.hdel('大key','小key')方法
r.hdel('lrx_stus','xiaojun') #删除指定的小key
6、返回值由二进制类型转为字符串类型
res=r.hgetall('lrx_stus') #获取到大key里面所有的数据
print(res)
new={}
#1、先循环res
#2、k和v decode一下,放到new这个字典里面
for k,v in res.items():
new[k.decode()]=v.decode()
print('=====下面是转完之后的')
print(new)
#结果为:
#{b'xiaojun': b'{"age":18,"addr":"\xe5\xa4\xa9\xe9\x80\x9a\xe8\x8b\x91"}'}
#<class 'dict'>
#=====下面是转完之后的
#{'xiaojun': '{"age":18,"addr":"天通苑"}'}
在连接数据库时直接加入参数:decode_responses=True,即可直接返回字符串类型数据,就不用再decode了。
五、设置redis失效时间
import flask
server=flask.Flask(__name__)
def get_redis(): #只返回连接redis的链接
return redis.Redis(**setting.redis_info) @server.route('/login',methods=['post','get'])
def login():
uname=flask.request.values.get('username')
pwd=flask.request.values.get('password')
if uname and pwd:
sql="select * from lrx_user_table where username='%s' and password='%s';" %(uname,pwd)
sessionid=tools.my_md5(uname)
login_time=time.strftime("%Y%m%d%H%M%S")
u_id=result[0].get('id')
r=get_redis()
r.set('lrx_session:%s'%u_id,sessionid,60) #存redis的key、value、失效时间
res={"error_code":200,"sessionid":sessionid,"login_time":login_time}
else:
res={"error_code":3001,"msg":"必填信息不全,请查看接口文档"}
return json.dumps(res,ensure_ascii=False,indent=4) @server.route('/pay',methods=['post'])
def pay():
uid=flask.request.values.get('userid')
m = flask.request.values.get('money')
sessionid = flask.request.values.get('session')
if uid and m and sessionid:
r=get_redis()
result=r.get('lrx_session:%s'%uid)
if sessionid==result:
sql="select balance from lrx_account_table where u_id='%s';" %uid
bal=tools.my_mysqldb(sql)[0].get('balance')
balance=float(bal)
res={"error_code":200,"msg":"ok"}
else:
res={"error_code":3003,"msg":"session已过期,请重新登录"}
else:
res={"error_code":3001,"msg":"必填信息不全,请查看接口文档"}
return json.dumps(res,ensure_ascii=False) server.run(**server_info)

Python之操作redis数据库的更多相关文章
- python 之操作redis数据库(非关系型数据库,k-v)
数据库: 1. 关系型数据库 表结构 2. 非关系型数据库 nosql (k - v 速度快),常用的时以下三种: memcache 存在内存里 redis 存在内存里 mangodb 数据还是存在磁 ...
- Python【操作Redis数据库】
Redis非关系型数据库,数据存放在计算机内存中,无SQL语句.Redis中有多种数据类型,比较常用的数据类型是string类型和hash类型.平时我们使用RedisDesktopManager来对R ...
- redis python 操作 Python操作Redis数据库
原文章于此:https://www.cnblogs.com/cnkai/p/7642787.html 有个人修改与改正 Python操作Redis数据库 连接数据库 StrictRedisfrom ...
- 操作redis数据库 & 操作Excel & 开发接口
操作redis数据库: string类型 1. 增 set,传俩个参数 key value(只要是字符串就行)2. 删 delete 传一个参数 key3. 修改 set 在目标key重新传参 key ...
- [转]使用python来操作redis用法详解
转自:使用python来操作redis用法详解 class CommRedisBase(): def __init__(self): REDIS_CONF = {} connection_pool = ...
- Linux+Redis实战教程_day02_3、redis数据类型_4、String命令_5、hash命令_6、java操作redis数据库技术
3. redis数据类型[重点] redis 使用的是键值对保存数据.(map) key:全部都是字符串 value:有五种数据类型 Key名:自定义,key名不要过长,否则影响使用效率 Key名不要 ...
- Python进阶学习_连接操作Redis数据库
安装导入第三方模块Redis pip3 install redis import redis 操作String类型 """ redis 基本命令 String set(n ...
- python学习笔记(十六)python操作redis数据库
Redis是一个key-value存储系统,它支持丰富的数据类型,如:string.list.set.zset(sorted set).hash. Redis特点 Redis以内存作为数据存储介质,所 ...
- 使用python来操作redis用法详解
1.redis连接 redis提供两个类Redis和StrictRedis用于实现Redis的命令,StrictRedis用于实现大部分官方的命令,并使用官方的语法和命令,Redis是StrictRe ...
随机推荐
- array_walk函数与call_user_func_array函数
一, php手册的解释: call_user_func_array - 调用回调函数,并把一个数组参数作为回调函数的参数 说明: mixed call_user_func_array ( cal ...
- Nginx使用教程(七):使用Nginx缓存之proxy cache
定义缓存目录 <br\>使用您喜欢的文本编辑器打开/etc/nginx/nginx.conf,并在http {区域加入: proxy_cache_path /var/www/cache ...
- linux编译64bitHadoop (eg: ubuntu14.04 and hadoop 2.3.0)
Hadoop官网提供的编译好的hadoop-2.3.0.tar.gz二进制包是在32位系统上编译的,在64系统上运行会有一些错误,比如: WARN util.NativeCodeLoader: Una ...
- Vim怎么批量处理文件将tab变为space
:%s/\t/ /g https://zhidao.baidu.com/question/563849372716100364.html
- java中的闭包
闭包(Closure)是一种能被调用的对象,它保存了创建它的作用域的信息 public class Programmer { private String name; public Programme ...
- tomcat的webapps目录中的abc.war
1 在tomcat的webapps目录中,会有类似abc.war类型的文件,在tomcat启动时会自动解压为abc目录. 2 如果tomcat在运行中,不要直接删除abc.war文件,删除后,ab ...
- range()函数
range()函数 函数说明: range(start, stop[, step]) -> range object,根据start与stop指定的范围以及step设定的步长,生成一个序列.参数 ...
- linux stat 查看文件的详细信息
linux stat查看文件详细信息 [root@oldboy01 tmp]# stat /tmp/1.cc File: `/tmp/1.cc' Size: 4 Blocks: 8 IO Block: ...
- svn 锁的处理
svn 锁的处理: 问题: 1:当用户在work copy1 中把某个文件或者文件夹锁住后,删除了这个工作区,重新取下来work copy2,再操作该文件的时候就报错说,该文件已经被锁住,必须先解锁, ...
- 开源的许可证GPL、LGPL、BSD、Apache 2.0
软件开发者要开源软件,不单单是开放源代码就可以了,选择一种许可证很重要,一个许可证之于软件就相当于价值观之于普通人,代表了这个软件的基本品性.一个错误的许可证选择可能会直接导致整个项目的失败.各种开源 ...