介绍

分布式缓存
NoSql:解决高并发、高可用、高可扩展,大数据存储等一系列问题而产生的数据库解决方案。
Redis:键值(Key-Value)存储数据库
Redis是使用c语言开发的一个高性能键值数据库。Redis可以通过一些键值类型来存储数据。
应用场景:
  1. 缓存(数据查询、短连接…)
  2. 任务队列
  3. 临时数据(数据过期处理,比如说:手机验证码2分钟内有效)
数据查询:第一次找DB同时把这个数据存储到缓存中,第二次找redis.[经常使用的热点数据]

数据类型

一. String 类型

赋值语法:SET key value
取值语法: GET key
设置多个键语法: MSET key value [key value …]
获取多个键值语法: MGET key [key …]
删除语法:DEL key
 
递增数字:当存储的字符串是整数时,Redis提供了一个实用的命令INCR,其作用是让当前键值递增,并返回递增后的值。
递增数字语法: INCR key
递减数值语法: DECR key
增加指定的整数语法: INCRBY key increment
减少指定的整数 语法:DECRBY key decrement
  @Test
     public void testString(){
         JedisPool jedisPool = new JedisPool("192.168.56.128",6379);
         Jedis jedis = jedisPool.getResource();
         /*设置单个kv*/
         jedis.set("1","你好");
         System.out.println(jedis.get("1"));

         /*设置多个kv*/
         jedis.mset("1","你好","2","不好");
         System.out.println(jedis.mget("1","2"));

         /*删除k*/
         System.out.println(jedis.del("1"));
         System.out.println(jedis.get("1"));//null

         /*字符串递增*/
         jedis.incr("num");
         System.out.println(jedis.get("num")); //1  2  3 ....

         /*递增固定数*/
         jedis.incrBy("num2",4);
         System.out.println(jedis.get("num2"));//4  8 12 ...

         /*字符串递减*/
         jedis.decr("num3");
         System.out.println(jedis.get("num3"));// -1  -2 -3 ...

         /*递减固定数*/
         jedis.decrBy("num4",4);
         System.out.println(jedis.get("num4"));//-4   -8 ...
     }

二、List集合

Redis的list是采用来链表来存储,双向链表存储数据,特点:增删快、查询慢(Linkedlist)
向列表左边增加元素: LPUSH key value [value ...]
从列表左边弹出元素: LPOP key
向列表右边增加元素 : RPUSH key value [value ...]
从列表右边弹出元素: RPOP key
获取列表中元素的个数: LLEN key
查看列表语法:LRANGE key start stop

  @Test
     public void testList(){
         JedisPool jedisPool = new JedisPool("192.168.56.128",6379);
         Jedis jedis = jedisPool.getResource();

         jedis.flushDB();

         /*从左侧增加*/
         jedis.lpush("list1","11","22","33");

         /*从右侧取*/
         System.out.println(jedis.rpop("list1"));// 11  右侧第一个(当前集合顺序[hahaha,gg,haha],取出就没了)
         /*从左侧取*/
         System.out.println(jedis.lpop("list1"));

         /*查看集合 lrange*/
         System.out.println(jedis.lrange("list1",0,-1));//[22]添加flushDB(),执行该测试方法多次,集合元素唯一,否则重复

         System.out.println(jedis.llen("list1"));
     }

三、Set集合

Set集合类型:无序、不可重复
增加元素语法:SADD key member [member ...]
删除元素语法: SREM key member [member ...]
获得集合中的所有元素 : SMEMBERS key
判断元素是否在集合中: SISMEMBER key member
存与取:无序不可重复
 @Test
    public void testSet() {
        JedisPool jedisPool = new JedisPool("192.168.56.128", 6379);
        Jedis jedis = jedisPool.getResource();

        /*添加元素*/
        jedis.sadd("set1", "1", "2", "3", "3");
        jedis.sadd("set2", "2", "4", "5");

        /*得到集合*/
        System.out.println(jedis.smembers("set1"));// [1,2,3]

        /*元素是否在集合中*/
        System.out.println(jedis.sismember("set1", "1"));//true

        /*取交集*/
        System.out.println(jedis.sinter("set1", "set2"));// [2]

        /*取并集*/
        System.out.println(jedis.sunion("set1", "set2"));//[1,2,3,4,5]

        /*差集*/
        System.out.println(jedis.sdiff("set1", "set2"));//[1,3]

    }

四、SortSet有序集合(Zset)

Sortedset和set的不同之处,是会给set中的元素添加一个分数,然后通过这个分数进行排序。
增加元素:ZADD key score member [score member ...]

向有序集合中加入一个元素和该元素的分数(score),如果该元素已经存在则会用新的分数替换原有的分数。

获得排名在某个范围的元素列表
按照元素分数从大到小的顺序返回
语法:ZREVRANGE key start stop [WITHSCORES]
获取元素的分数 :ZSCORE key member
删除元素ZREM key member [member ...]
获得元素的分数的可以在命令尾部加上WITHSCORES参数
  @Test
     public void testZSet(){
         JedisPool jedisPool = new JedisPool("192.168.56.128", 6379);
         Jedis jedis = jedisPool.getResource();
         Map<String,Double> map = new HashMap<>();
         map.put("zhangsan",1d);
         map.put("lisi",3d);
         map.put("wangwu",2d);

         /*添加*/
         jedis.zadd("score",map);

         /*所有数据 有序*/
         System.out.println(jedis.zrange("score",0,-1));//[zhangsan, wangwu, lisi]

         /*获取元素的分数*/
         System.out.println(jedis.zscore("score","zhangsan")); //1.0

         /*lisi排名*/
         System.out.println(jedis.zrank("score","lisi"));// 2   (默认从零开始)            /*删除*/      System.out.println(jedis.zrem("score","wangwu"));
  }

    

五、Hash散列

hash叫散列类型,它提供了字段和字段值的映射。字段值只能是字符串类型,不支持散列类型、集合类型等其它类型。
赋值语法: HSET key field value

设置一个字段值, HSET命令不区分插入和更新操作,当执行插入操作时HSET命令返回1,当执行更新操作时返回0。

取值语法: HGET key field
设置多个字段语法: HMSET key field value [field value ...]
取多个值语法: HMGET key field [field ...]
获取所有字段值语法:HGETALL key
删除字段语法:HDEL key field [field ...]
     @Test
     public void testHash(){
         JedisPool jedisPool = new JedisPool("192.168.56.128", 6379);
         Jedis jedis = jedisPool.getResource();

         Map<String,String> map = new HashMap<>();
         map.put("1","zhangsan");
         map.put("2","lisi");
         map.put("3","wangwu");

         /*单个添加*/
         jedis.hset("stu1","name","zhaoliu");
         jedis.hset("stu1","age","20");

         /*添加集合*/
         jedis.hmset("stu2",map);

         /*输出*/
         System.out.println(jedis.hgetAll("stu2"));// {1=zhangsan, 2=lisi, 3=wangwu}

         /*取值*/
         System.out.println(jedis.hget("stu1","name"));//zhaoliu

         /*取所有值*/
         System.out.println(jedis.hgetAll("stu1"));//{name=zhaoliu, age=20}

         /*得到keys*/
         System.out.println(jedis.hkeys("stu1"));//[name, age]

         /*得到values*/
         System.out.println(jedis.hvals("stu1"));//[zhaoliu, 20]
     }

其他

keys:返回满足给定pattern 的所有key
 
exists:确认一个key 是否存在,存在返回1
 
del:删除一个key
 
rename:重命名key:rename age age_new
 
type:返回值的类型
 
设置失效时间: expire key  3;    
 
查看剩余秒数:ttl key
 
取消过期时间:persist
 
redis默认有16个数据库,库名db0 - db15,默认使用db0
 
选择数据库:select   [0-15]
 
把0库数据迁移到1库:move  xxx    1(原数据库数据没了)
 
查看key的类型:type key
 
查看数据库大小:dbsize
 
清空数据库:flushdb(清空当前) flushall(所有数据库都清空) 
 
随机返回一个key: randomkey
 
打印:echo     (echo   xxxx)
 
数据库中key数量:dbsize
 
数据库详细信息: info
 
实时存储收到的请求: config get      config  get *   返回所有相关的配置信息

Redis简单介绍与数据类型的更多相关文章

  1. Redis简单介绍以及数据类型存储

    因为我们在大型互联网项目其中.用户訪问量比較大,比較多.会产生并发问题,对于此.我们该怎样解决呢.Redis横空出世,首先,我们来简单的认识一下Redis.具体介绍例如以下所看到的: Redis是一个 ...

  2. Redis简单介绍

    redis简单介绍 Redis VS key-value缓存产品 Redis支持数据的持久化,能够将内存中的数据保持在磁盘中,重新启动的时候能够再次载入进行使用. Redis不只支持简单的key-va ...

  3. Python redis 简单介绍

    Python redis 简单介绍 1.安装 终端输入: pip(or)pip3.6 install redis 安装成功 2.哈哈,发现我并没有redis服务可以访问,所以到这里,在本机安装了red ...

  4. [freemarker篇]04.简单介绍-基本数据类型

    好几天没有更新博客了,最近一顿乱七八糟的忙!今天简单更新第四章,这里只能说是简单介绍,因为权威的还是需要看Freemarker的官方中文手册! 好几天没有更新博客了,最近一顿乱七八糟的忙!今天简单更新 ...

  5. Redis 简单介绍(知识整理笔记)

    前言: Redis 介绍:轻量级.Key-Value.内存数据库.支持持久化 Redis 数据结构:string(字符串),hash(哈希),list(列表),set(集合)及 zset (sorte ...

  6. Redis简单介绍与安装

    Redis是一个开源,高级的键值存储和一个适用的解决方案,用于构建高性能,可扩展的Web应用程序. Redis有三个主要特点,使它优越于其它键值数据存储系统 - 1) Redis将其数据库完全保存在内 ...

  7. Redis实战——简单介绍

    出自:https://www.cnblogs.com/moonlightL/p/7364107.html Redis简单介绍 Redis是一个开源,高级的键值存储和一个适用的解决方案,用于构建高性能, ...

  8. redis学习(一) redis的介绍与安装

    redis简单介绍 redis全称remote-dictionary-server 直译为远程字典服务器, 是一个高性能的key-value存储系统,也被称为数据结构服务器,因为其所存储的数据值(va ...

  9. 01-Redis 简单介绍

    Redis 简单介绍 1.Redis 是什么 Redis 是一种基于键值对的 NoSQL 数据库,与很多键值对数据库不同, redis 中的值可以有 string, hash , list , set ...

随机推荐

  1. zabbix连不上数据库

    [root@localhost etc]# tail -f /var/log/zabbix_server.log 1267:20130722:195451.493 [Z3001] connection ...

  2. 需求分析之WBS

    我们的产品就是当你把废旧的塑料瓶和电池投入回收箱中会产生能量,那么这能量可以干嘛呢那就通过我们的APP进行扫码记录所产生的能量这写能量可以在我们的APP的换吧中进行兑换用户所需要的东西比如:共享单车的 ...

  3. Python用户交互-密码不可见

    输入密码时若让用户不可见,可以使用getpass模块中的getpass方法 # 输入密码时若想要不可见,使用getpass模块中getpass方法即可 import getpass pwd=getpa ...

  4. Apache的配置详解

    Apache的配置由httpd.conf文件配置,因此下面的配置指令都是在httpd.conf文件中修改. 主站点的配置(基本配置) (1) 基本配置: ServerRoot "/mnt/s ...

  5. Java中的Scanner类

    java.util.Scanner是Java5的新特征,我们可以通过Scanner类来获取用户的输入.创建Scanner对象的基本语法: Scanner s = new Scanner(System. ...

  6. 由JDK源码学习HashMap

    HashMap基于hash表的Map接口实现,它实现了Map接口中的所有操作.HashMap允许存储null键和null值.这是它与Hashtable的区别之一(另外一个区别是Hashtable是线程 ...

  7. css3—产品列表之鼠标滑过效果

    <!DOCTYPE HTML> <html> <head> <meta charset="UTF-8" /> <title&g ...

  8. C/C++——存储

    关于各内存空间: 栈(stack):变量,数组.栈的大小是2M(也有的是1M),反正不大,一般递归写错了,没有出口,都会报错stack overflow. 全局区(静态区):全局变量.数组,静态变量. ...

  9. MySQL 分库分表方案,总结的非常好!

    前言 公司最近在搞服务分离,数据切分方面的东西,因为单张包裹表的数据量实在是太大,并且还在以每天60W的量增长. 之前了解过数据库的分库分表,读过几篇博文,但就只知道个模糊概念, 而且现在回想起来什么 ...

  10. docker-4-镜像

    是什么 镜像是一种轻量级.可执行的独立软件包,用来打包软件运行环境和基于运行环境开发的软件, 它包含运行某个软件所需的所有内容,包括代码.运行时.库.环境变量和配置文件. 1.UnionFS(联合文件 ...