Redis基础

Redis基础

Redis简介

NoSQL

NoSQL:即Not-OnlySQL(泛指非关系型的数据库),作为关系型数据库的补充。

作用:应对基于海量用户和海量数据前提下的数据处理问题。

特征:

  • 可扩容,可伸缩
  • 大数据量下高性能
  • 灵活的数据模型
  • 高可用

Redis概念

Redis是用C语言开发的一个开源的高性能键值对(key-value)数据库。

特征:

  1. 数据间没有必然的关联关系
  2. 内部采用单线程机制进行工作
  3. 高性能
  4. 多数据类型支持
  5. 持久化支持

Redis数据

Redis数据存储格式

Redis自身的是一个Map,所有的数据以键值对的方式存储。

key的设置约定

表名:主键名:主键值:字段名


数据类型

string类型

  • 存储的数据:单个数据,最简单的数据存储类型,也是最常用的数据存储类型
  • 存储数据的格式:一个存储空间保存一个数据
  • 存储内容:通常使用字符串,如果字符串以整数的形式是展示,可以作为数字操作使用

hash类型

  • 存储需求:对一系列存储的数据进行编组,方便管理,典型应用存储对象信息
  • 需要的存储结构:一个存储空间保存多个键值对数据
  • hash:底层使用哈希表结构实现数据存储

list类型

  • 存储需求:存储多个数据,并对数据进入存储空间的顺序进行区分
  • 需要的存储结构:一个存储空间保存多个数据,且通过数据可以体现进入顺序
  • list:保存多个数据,底层使用双向链表存储结构实现

set类型

  • 存储需求:存储大量的数据,在查询方面提供跟高的效率
  • 需要的存储结构:能够保存大量的数据,高效的内部存储机制,便于查询
  • set:与hash的存储结构完全相同,将值存储于hash的key中,hash的value中存储nil,并且值不允许重复

sorted_set类型

  • 存储需求:数据排序有利于数据的有效展示,需要提供一种可以根据自身特征进行排序的方式
  • 需要的存储结构:新的存储模型,可以保存可排序的数据
  • sorted_set:在set的存储结构基础上添加可排序字段

Redis的基本操作

String类型

信息添加

  • 功能:设置 key value

  • 命令

set key value

信息查询

  • 功能:根据 key 查询 value

  • 命令

get key

信息删除

  • 功能:删除 key value

  • 命令

del key

添加/修改多个数据

mset key1 value1 key2 value2 ...

获取多个数据

mget key1 key2 ...

获取数据字符个数(字符串长度)

strlen key

追加信息到原始信息后

append key value

设置数值数据增加/减少指定范围的值

incr/decr key
incrby/decrby key integerNumber
incrbyfloat key floatNumber

设置指定时常的生命周期的数据

setex key seconds value     
psetex key milliseconds     

注意事项:

  • 数据操作返回值
    • 表示数据运行结果是否成功,成功:(integer)1、失败:(integer)0
    • 表示运行结果值,如:(integer)3
  • 未获取到数据
    • (nil) 等同于null
  • 数据最大存储量:512MB

Hash类型

添加/修改数据

hset key field value
hsetnx key field value      //如果库中存在key则不添加

获取数据

hget key field
hgetall key         //获取全部

删除数据

hdel key field1 [field2]

添加/修改多个数据

hmset key field1 value1 field2 value2 ...

获取数据

hmget key field1 field2 ...

获取哈希表中的字数

hlen key

获取哈希表中是否存在指定字段

hexists key field

获取哈希表中所有的字段名或字段值

hkeys key
hvals key

设置指定字段的数值数据增加指定范围的值

hincrby key field integerNumber
hincrbyfloat key field floatNumber

注意事项:

  • hash类型下的value只能存储字符串,不允许存储其他数据类型
  • 每个hash可以存储232-1个键值对
  • hash类型十分贴近对象的数据存储形式,并且可以灵活的添加或删除对象属性,但hash设计初衷并不是为了存储大量对象,所以不可滥用,更不可将hash作为对象列表使用
  • hgetall可以获取全部属性,但是如果内部field过多,会导致遍历整体数据效率变低,成为数据访问瓶颈

List类型

添加/修改数据

lpush key value1 [value2] ...   //左进入
rpush key value1 [value2] ...   //右进入

获取数据

lrange key start stop
lindex key index
llen key

获取并移除数据

lpop key
rpop key

规定时间内获取并移除数据

blpop key1 [key2] timeout
brpop key1 [key2] timeout

移除指定数据

lrem key count value

注意事项:

  • list中保存的数据都是string类型的,最多容纳232-1条数据
  • list具有索引的概念,但是操作时通常以队列的形式进行出入队操作,或以栈形式进行出入栈操作
  • 获取全部数据操作的结束索引设置为-1
  • list可以对数据进行分页操作,通常第一页信息来自于list,第二页及更多信息通过数据库加载

Set类型

添加数据

sadd key member1 [member2]

获取全部数据

semebers key

删除数据

srem key member1 [member2]

获取集合数据总量

scard key

判断集合中是否包含指定数据

sismember key member

随机获取集合中指定数量的数据

srandmember key [count]

随机获取集合中的某个数据并将该数据移出集合

spop key [count]

求两个集合的交、并、差集

sinter key1 [key...]
sunion key1 [key...]
sdiff key1 [key...]

求两个集合的交、并、差集并存到指定集合中

sinterstore destination key1 [key...]
sunionstore destination key1 [key...]
sdiffstore destination key1 [key...]

将指定数据从原始集合中移动到目标集合中

smove source destination member

注意事项:

  • set类型不允许数据重复,如果添加的数据在set中已存在,将只保留一份
  • set虽然与hash的存储结构相同,但是无法启用hash中存储值的空间

Sorted_set类型

添加数据

zadd key score1 member1 [score member ...]

获取全部数据

zrange key start stop [WITHSCORES]
zrevrange key start stop [WITHSCORES]

删除数据

zrem key member [member ...]

按条件获取数据

zrangebyrescore key min max [WITHSCORES] [LIMIT]
zrevrangebyscore key min max [WITHSCORES] [LIMIT]

条件删除数据

zremrangebyrank key start stop
zremrangebyscore key min max

获取集合数据总量

zcard key
zcount key min max

集合交、并操作

zinterstore destination numkeys key [key ...]
zunionstore destination numkeys key [key ...]

获取数据对应的索引(排名)

zrank key member
zrevrank key member

score值获取与修改

zscore key member
zincrby key increment 

注意事项:

  • score保存的数据存储空间是64位
  • score保存的数据也可以是一个双精度的double值,基于双精度浮点数的特征,可能会丢失精度,使用时需要谨慎
  • sorted_set底层存储结构还是基于set的,因此数据不允许重复,如果重复添加数据,score值将被覆盖,保留最后一次修改的结果

通用命令

key的基本操作

删除指定key

del key

获取key是否存在

exists key

获取key的类型

type key

查询key

keys pattern
* 匹配任意数量的任意符号
? 匹配任意一个符号
[] 匹配一个指定的符号

改变key的名字

rename key newkey
renamenx key newkey

对所有key排序

sort

时效性操作:

为指定的key设置有效期

expire key seconds
pexpire key milliseconds
expireat key timestamp
pexpireat key milliseconds

获取key的有效时间

ttl key
pttl key

将key从时效性转换为永久性

persist key


数据库基本操作

  • redis为每个服务提供有16个数据库,编号从0-15
  • 每个数据库之间的数据相互独立

切换数据库

select index

数据移动

move key db

数据清除

dbsize      //查看数据总量
flushdb     //清除当前数据
flushall    //清除全部数据

其他操作

quit
ping
echo message


Jdies

Jedis简介

Jedis是Java语言连接redis服务。


使用方式

在pom文件中导入jedis的依赖。

<!-- jedis -->
<dependency>
    <groupId>redis.clients</groupId>
    <artifactId>jedis</artifactId>
    <version>3.2.0</version>
</dependency>

在类中进行连接

//1.连接redis
Jedis jedis = new Jedis("127.0.0.1", 6379);
//2.操作redis
jedis.set("name","squid");//Jedis中的方法名与redis中命令名完全一致
String name = jedis.get("name");
System.out.println(name);
//3.断开连接
jedis.close();

注意:从redis中取出的所有数据类型与java中的数据类型一一对应。


Jedis工具类

public class JedisUtil {
    private static JedisPool jedisPool = null;
    private static Integer port = null;
    private static Integer maxTotal = null;
    private static Integer maxIdle = null;

    static{
        ResourceBundle resourceBundle = ResourceBundle.getBundle("redis");//获取配置文件
        String host = resourceBundle.getString("redis.host");
        port = Integer.valueOf(resourceBundle.getString("redis.port"));
        maxTotal = Integer.valueOf(resourceBundle.getString("redis.maxTotal"));
        maxIdle = Integer.valueOf(resourceBundle.getString("redis.maxIdle"));

        JedisPoolConfig jedisPoolConfig = new JedisPoolConfig();
        jedisPoolConfig.setMaxTotal(maxTotal);//最大连接数
        jedisPoolConfig.setMaxIdle(maxIdle);//活动连接数
        jedisPool = new JedisPool(jedisPoolConfig,host,port);
    }
    public static Jedis getJedis(){
        return jedisPool.getResource();
    }
}

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,658评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,482评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,213评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,395评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,487评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,523评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,525评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,300评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,753评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,048评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,223评论 1 343
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,905评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,541评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,168评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,417评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,094评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,088评论 2 352