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 ...
随机推荐
- jQuery设置radio、select、checkbox只读属性后,如何在后台得到数据
1 设置表单的readonly属性 对于radio.select.checkbox来说,readonly属性对这三个标签不起什么作用. 2 设置表单的disabled属性 以radio为例说明. 代码 ...
- firefox浏览器 插件--【维基百科+谷歌翻译】高级应用之 带图翻译
[维基词典+谷歌翻译]插件地址: https://addons.mozilla.org/zh-CN/firefox/addon/google-dictionary-and-google-t/?src= ...
- windowsserver2019系统下载
windowsserver2019系统分为标准版和数据中心版,两个版本和windows2012,2016一样没有64位系统,点击下载windowsserver2019系统.
- 4.11Python数据处理篇之Matplotlib系列(十一)---图例,网格,背景的设置
目录 目录 前言 (一)图例legend 1.默认不带参数的图例 2.添加参数的图例 3.将图例移动到框外 (二)网格grid 1.说明 2.源代码: 3.输出效果 (三)背景axses 1.设置全局 ...
- linux上部署SpringBoot项目及遇到的问题
打开sftp步骤, 在显示的已连接的窗口上右键, 选择connect SFTP Session就可以打开文件上传的窗口 从windows上传文件到linux, 首先linux需要先切换到想要保存文件的 ...
- Java访问级别修饰符
用途 控制其他类可以访问的字段或方法 修饰符 public.protected.no modifier(未声明).private 访问级别 修饰符 当前类 包 子类 其他包 public √ √ √ ...
- 修改mysql默认端口
最初,我将mysql端口改成了3307,现在需要将其改3306端口,已改好,做个记录 首先:借助资源监视器,找到对应的端口,查看对应的Pid,然后打开任务管理器,点击服务,找到对应的服务器,将其服务停 ...
- 设计模式のStrategyPattern(策略模式)----行为模式
一.问题产生背景 当我们进行一系列处理时(员工工资核算,会员管理,计算器,优惠活动),会有很多相似的算法和处理过程,只是由于具体的算法的差异,导致必须不同处理.这些处理和客户端无关,我们可以把这些算法 ...
- 6.05-btc
import requests from lxml import etree import json class BtcSpider(object): def __init__(self): self ...
- poj2635
版权声明:本文为博主原创文章,未经博主同意不得转载. https://blog.csdn.net/chaoweilanmao/article/details/33417423 这道题一看是大数题就知道 ...