標籤:取資料 記憶體 let session type god oca 操作 存在
資料庫:
1. 關係型資料庫
2. 非關係型資料庫 nosql (k - v 速度快),常用的時以下三種:
- memcache 存在記憶體裡
- redis 存在記憶體裡
- mangodb 資料還是存在磁碟上
Redis裡的資料類型有String 和hash類型,下面主要是對Redis 的一些操作。
一、String類型
r = redis.Redis(host=‘localhost‘,port=6379,db=3)r.set(‘nancy2‘,‘201801211505‘) #set資料print(r.get(‘nancy‘)) # b‘201801211505‘print(r.get(‘unexsitkey‘)) #->Noneprint(r.get(‘nancy1‘).decode()) #redis 裡面取出來的資料都是bytes類型,所有要用decode()方法轉成字串 ->201801211505r.delete(‘nancy‘) #刪除一個r.setex(‘nancy_session‘,‘aaabb66‘,‘20‘) #可以指定key的失效時間,最後一個單位,單位是秒r.set(‘redis:nancy‘,‘python000‘)r.set(‘redis:nancy1‘,‘redis00123‘)r.set(‘redis1:kate‘,‘redis11‘)print(r.keys())#byte 類型,list 所有的keyprint(r.keys(‘redis*‘)) #以txz開頭的key,byte 類型,-> [b‘redis:nancy1‘, b‘redis:nancy‘, b‘redis1:kate‘]print(r.type(‘redis:nancy‘)) #-> b‘string‘
注意: set get delete setex 都是針對redis裡的string類型
二、hash類型
r.hset(‘sessions‘,‘lily‘,‘167890‘)r.hset(‘sessions‘,‘kate‘,‘34901‘)value = r.hget(‘sessions‘,‘nancy‘) #擷取資料print(value)value1 = r.hget(‘session‘,‘unexsit‘)#不存在返回Noneprint(value1)redis_data = r.hgetall(‘sessions‘) #擷取hash類型裡所有的資料,資料類型是字典all_date = {}for k,v in redis_data.items(): k = k.decode() v = v.decode() all_date[k] = vprint(redis_data)#byte 型的字典,{b‘kate‘: b‘34901‘, b‘lily‘: b‘167890‘}print(r.type(‘sessions‘)) #擷取key的類型 -> b‘hash‘
python 之操作redis資料庫(非關係型資料庫,k-v)