1、redis安装和启动
redis-cli -h ip
见文档
2、redis函数学习
1)字符串
set key value
get key
getrange key start end --->字符串提取,字符串从0开始,包含start和end
getset key value --->设置key的值,返回的是旧值,新值会设置成功
setex key seconds value ---->设置key的值,过期时间为seconds,如果存在,替换之,时间以s为单位
setnx key value --->该key不存在的时候才设置,存在不设置
setrange key offset value --->将该key对应的值从offset开始替换为value
strlen key --->得到该key对应的值的长度
mset:
mset key1 value1 key2 value2 key3 value3 --->同时设置多个键值对
msetnx --->同时设置多个键值对,当键不存在的时候才设置
psetex key time value ->设置键值对,时间以ms为单位
incr key --->
为key对应的值增加1
如果key不存在,那么先创建这个key,值为0,然后设置为1
如果key对应的是字符串,那么报错
incrby key number --->在指定的key对应的值加incre_amount
decr key
减一
decrby key number --->减去指定的数量
append key value --->在指定的key对应的值后面追加value
mget --->一次获取多个键的值
2)队列
lpush key value1 value2 --->依次将value1和value2从左边插入到队列key中
lrange key start stop --->依次的显示队列key中从start开始到stop结束的所有元素
start 0 stop -1代表最后一个
lpushx key value --->当队列key存在的时候才往队列头部插入数据,如果队列不存在,插入失败
lpop key --->弹出队列key中最左边的元素
rpush key value1 value2 --->将value从右边插入到队列key中
rpushx key value --->将value从右边插入到队列key中,但是前提是队列key必须存在
rpop key --->将队列key中最右边的元素弹出
rpoplpush src dst --->将队列src中最右边的元素插入到队列dst中的最左边
ltrim key start stop --->将队列中start-stop区间之外的所有元素全部干掉
闭区间
lset key index value --->将队列key中的第index个元素设置为value
下标从0开始
llen key --->得到队列key中元素的个数
lindex key index --->获取队列key中第index个元素
lrem key count value
count > 0 从最左边开始,干掉count个和value相等的元素
count < 0 从最右边开始,干掉-count个和value相等的元素
count = 0 干掉队列key中所有和value相等的元素
linsert key before|after value newvalue --->在队列key中的value的前面或者后面插入newvalue
3)集合
无序性、唯一性
sadd key value1 value2 value3 --->往集合key中插入多个值
scard key --->得到集合中元素的个数
smembers key --->查看集合key中所有的元素
sdiff key1 key2 key3--->保留key1中key2和key3没有的元素(求差) ,key1不变,但结果返回给你
sdiffstore dst key1 key2 key3 --->将这个(sdiff key1 key2 key3)的结果保留到集合dst中
sinter key1 key2 --->取出key1和key2的交集
sinterstore dst key1 key2 --->将sinter key1 key2的结果保存到集合dst中
sismember key value --->判断value在不在集合key中,在的话返回1,不在的话返回0
smove src dst value ---> 将集合src中的value元素移动到集合dst中
spop key--->从集合key中随机弹出一个元素
srandmember key count
count > 0 count < 集合元素个数: 返回你一个数组,而且数组元素唯一
count > 集合元素个数:返回你该集合中所有的元素
count < 0:返回给你-count个元素,但是不保证唯一
srem key value1 value2 --->移除集合key中的value1和value2元素
sunion key1 key2 --->得到集合key1和集合key2的并集
sunionstore dst key1 key2 --->将集合key1和集合key2的并集保存到dst中
4)哈希
hset key field value --->给对应的key设置属性和属性值
hsetnx key field value --->该key中不存在的field才设置为value
hget key field --->获取指定key的field属性
hdel key field1 field2 --->删除对应key中指定的属性
hexists key field --->对应的key中是否存在这个属性,存在返回1,不存在返回0
hgetall key --->获取这个key对应的所有的属性和值
hincrby key field number --->给这个key对应的属性值加减number
hincrbyfloat key field number --->给这个key对应的属性值加减number,number为float值
hkeys key --->对应的key中所有的属性名
hvals key --->对应的key中所有的值
hlen key --->对应的key有多少个属性
hmset key field1 value1 field2 value2 ... --->同时为key设置多个属性和属性值
hmget key field1 field2 ... --->同时获取key的多个属性的值
5)有序集合
zadd key score member --->将分值为score的成员member加入到有序集合key中
zcard key --->得到集合key中元素的个数
zcount key start stop --->得到集合key中分值在start到stop之间的元素的个数
闭区间 [start stop] 这个写分值
zincrby key number member --->给集合key中指定的member元素的分值加上number
zrange key start stop [withscores]
显示集合中的元素 start和stop是下标 0 -1
显示成员的时候可以显示分值
zrangebyscore key min max
按照区间去查找对应的元素 min和max 是分值
【注】前面的只能写数字,肯定是大于等于,后面的可以写开区间,不写默认就是闭区间
0 (100 0<= <100
0 100 0<= <=100
默认升序排列好
zrank key member
从低到高排列,下标从0开始
查找member在有序集合key中的排名 显示的是下标
zrem key member1 member2 --->移除有序集合中指定的元素
zrevrange key start stop withscores --->查询从start到stop之间所有的元素,但是是从大到小排列
zrevrank key member --->用法和zrank一样,但是是从大大小排列的顺序
【注】得到的是下标
zrevrangebyscore key max min
根据成绩从高到低排序,得到指定分值区间的成员
ZREVRANGEBYSCORE salary +inf -inf # 逆序排列所有成员
zscore key member --->返回指定成员的分数
键命令
0-15:redis默认有16个数据库,默认是在第0个数据库中操作
select num:切换数据库
keys *:所有键
del key:删除键
EXPIRE key seconds:给指定的key添加过期时间,单位是s
ttl key:以秒为单位,返回这个键剩余的时间秒数
exists key:判断一个键是否存在
flushdb: 删除当前数据库中所有的键
flushall:删除所有数据库中的所有键
rename key newkey #修改key的名称(如果新的key的名字存在 则会把存在的key的值 覆盖掉)
randomkey #随机返回一个 key
move key db 将指定键移动到指定库
临时设置密码
获取密码
config get requirepass
设置密码
config set requirepass 123456
当有密码的时候认证
auth 密码
取消密码
config set requirepass ''
永久设置密码
到配置文件中设置
requirepass 密码
配置其他机器可以连接,打开redis配置文件
bind 127.0.0.1 这句话注释掉
protected_mode no 这句话yes修改为no
重启才能生效 干掉这个进程重新打开
3、redis持久化机制rdb
持久化:在内存中的数据不能保存,如果想要保存需要保存到硬盘中
redis的数据就是在内存中的,如果将redis关掉,再去打开,数据在不在?
redis有持久化机制,就是rdb机制
stop-writes-on-bgsave-error yes 后台写入的时候,停止文件写入
rdbcompression yes 写文件的时候有压缩格式
rdbchecksum yes 对rdb文件校验
dbfilename dump.rdb 保存的rdb文件的文件名
dir ./ 保存的文件的路径
可以手动保存 redis-cli bgsave
复制过来,替换这个文件,下次启动的时候就是使用的新的rdb文件
4、python操作redis
import redis
每一个指令到代码中都是一个函数,然后输入和输出就会变成函数的输入和输出
见代码
5、MongoDB安装
MongoDB也是一个数据库,是一个NoSQL,非关系型数据库
直接保存在硬盘中,保存的数据类似json格式,字典格式
MongoDB开源免费,你可以去官网下载安装包还有文档,文档写了如何安装和使用,但是都是英文看不懂,而且这个源码包下载不下来。
支持-windows、linux、mac