zoukankan      html  css  js  c++  java
  • Redis 入门知识点

    1、Redis简介

    1.1、简介

    Redis 是完全开源免费的,遵守BSD协议,是一个高性能的key-value数据库。

    Redis 与其他 key - value 缓存产品有以下三个特点:

    • Redis支持数据的持久化,可以将内存中的数据保存在磁盘中,重启的时候可以再次加载进行使用。
    • Redis不仅仅支持简单的key-value类型的数据,同时还提供list,set,zset,hash等数据结构的存储。
    • Redis支持数据的备份,即master-slave模式的数据备份。

    1.2、Redis 优势

    • 性能极高 – Redis能读的速度是110000次/s,写的速度是81000次/s 。
    • 丰富的数据类型 – Redis支持二进制案例的 Strings, Lists, Hashes, Sets 及 Ordered Sets 数据类型操作。
    • 原子 – Redis的所有操作都是原子性的,意思就是要么成功执行要么失败完全不执行。单个操作是原子性的。多个操作也支持事务,即原子性,通过MULTI和EXEC指令包起来。
    • 丰富的特性 – Redis还支持 publish/subscribe, 通知, key 过期等等特性。

    Redis与其他key-value存储有什么不同?

    • Redis有着更为复杂的数据结构并且提供对他们的原子性操作,这是一个不同于其他数据库的进化路径。Redis的数据类型都是基于基本数据结构的同时对程序员透明,无需进行额外的抽象。

    • Redis运行在内存中但是可以持久化到磁盘,所以在对不同数据集进行高速读写时需要权衡内存,因为数据量不能大于硬件内存。在内存数据库方面的另一个优点是,相比在磁盘上相同的复杂的数据结构,在内存中操作起来非常简单,这样Redis可以做很多内部复杂性很强的事情。同时,在磁盘格式方面他们是紧凑的以追加的方式产生的,因为他们并不需要进行随机访问。

    2、安装Redis服务端

    下载:https://github.com/microsoftarchive/redis/releases

    下载zip将其解压至任意无中文路径下,如图所示

    其中“redis.conf”为服务端配置文件,自带压缩包内无此文件,需要至git下载,(https://github.com/microsoftarchive/redis),下载开发版项目后,找到“redis.conf”,将其复制到本机redis路境内即可。

     2.1 启动Redis服务端

    打开命令窗口,切换至Redis安装路径

    redis-server:启动Redis服务端

    redis-server D:Server edis edis.conf:使用指定的配置文件启动Redis服务端

    现在服务端就启动成功了

    2.2 启动Redis客户端

    另启一个命令窗口

    切换到 redis 目录下运行:
    
    redis-cli.exe -h 127.0.0.1 -p 6379
    设置键值对:
    
    set myKey abc
    取出键值对:
    
    get myKey

    此处演示了Redis的基本用法

    Redis支持五种数据类型:string(字符串),hash(哈希),list(列表),set(集合)及zset(sorted set:有序集合)。

    我们在下面的demo中,将Redis集成到项目中,来直观的展示Redis的功能

    3、集成至Java的Demo项目中

    开发环境:  

      IntelliJ IDEA 2017.1 x64  + jdk1.8.0.131

    Jar包版本:

      commons-pool 1.5.5 

      jedis  2.1.0

    Maven项目的pom文件

    <?xml version="1.0" encoding="UTF-8"?>
    <project xmlns="http://maven.apache.org/POM/4.0.0"
             xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
             xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
        <modelVersion>4.0.0</modelVersion>
    
        <groupId>lxd</groupId>
        <artifactId>lxd</artifactId>
        <version>1.0-SNAPSHOT</version>
        <dependencies>
            <dependency>
                <groupId>commons-pool</groupId>
                <artifactId>commons-pool</artifactId>
                <version>1.5.5</version>
            </dependency>
            <dependency>
                <groupId>redis.clients</groupId>
                <artifactId>jedis</artifactId>
                <version>2.1.0</version>
            </dependency>
    
        </dependencies>
    
    
    </project>

    主要代码 RedisClient

    package redis;
    
    import java.util.ArrayList;
    import java.util.Iterator;
    import java.util.List;
    import java.util.Set;
    
    import redis.clients.jedis.*;
    
    public class RedisClient {
        private Jedis jedis;//非切片额客户端连接
        private JedisPool jedisPool;//非切片连接池
        private ShardedJedis shardedJedis;//切片额客户端连接
        private ShardedJedisPool shardedJedisPool;//切片连接池
    
        public Jedis getJedis() {
            return jedis;
        }
    
        public void setJedis(Jedis jedis) {
            this.jedis = jedis;
        }
    
        public JedisPool getJedisPool() {
            return jedisPool;
        }
    
        public void setJedisPool(JedisPool jedisPool) {
            this.jedisPool = jedisPool;
        }
    
        public ShardedJedis getShardedJedis() {
            return shardedJedis;
        }
    
        public void setShardedJedis(ShardedJedis shardedJedis) {
            this.shardedJedis = shardedJedis;
        }
    
        public ShardedJedisPool getShardedJedisPool() {
            return shardedJedisPool;
        }
    
        public void setShardedJedisPool(ShardedJedisPool shardedJedisPool) {
            this.shardedJedisPool = shardedJedisPool;
        }
    
        public RedisClient() {
            initialPool();
            initialShardedPool();
            shardedJedis = shardedJedisPool.getResource();
            jedis = jedisPool.getResource();
    
    
        }
    
        /**
         * 初始化非切片池
         */
        private void initialPool() {
            // 池基本配置 
            JedisPoolConfig config = new JedisPoolConfig();
            config.setMaxActive(20);
            config.setMaxIdle(5);
            config.setMaxWait(1000l);
            config.setTestOnBorrow(false);
    
            jedisPool = new JedisPool(config, "127.0.0.1", 6379);
        }
    
        /**
         * 初始化切片池
         */
        private void initialShardedPool() {
            // 池基本配置 
            JedisPoolConfig config = new JedisPoolConfig();
            config.setMaxActive(20);
            config.setMaxIdle(5);
            config.setMaxWait(1000l);
            config.setTestOnBorrow(false);
            // slave链接 
            List<JedisShardInfo> shards = new ArrayList<JedisShardInfo>();
            shards.add(new JedisShardInfo("127.0.0.1", 6379, "master"));
    
            // 构造池 
            shardedJedisPool = new ShardedJedisPool(config, shards);
        }
    
        public void show() {
            KeyOperate();
            StringOperate();
            ListOperate();
            SetOperate();
            SortedSetOperate();
            HashOperate();
            jedisPool.returnResource(jedis);
            shardedJedisPool.returnResource(shardedJedis);
        }
    
        private void KeyOperate() {
            System.out.println("======================key==========================");
            // 清空数据
            System.out.println("清空库中所有数据:" + jedis.flushDB());
            // 判断key否存在
            System.out.println("判断key999键是否存在:" + shardedJedis.exists("key999"));
            System.out.println("新增key001,value001键值对:" + shardedJedis.set("key001", "value001"));
            System.out.println("判断key001是否存在:" + shardedJedis.exists("key001"));
            // 输出系统中所有的key
            System.out.println("新增key002,value002键值对:" + shardedJedis.set("key002", "value002"));
            System.out.println("系统中所有键如下:");
            Set<String> keys = jedis.keys("*");
            Iterator<String> it = keys.iterator();
            while (it.hasNext()) {
                String key = it.next();
                System.out.println(key);
            }
            // 删除某个key,若key不存在,则忽略该命令。
            System.out.println("系统中删除key002: " + jedis.del("key002"));
            System.out.println("判断key002是否存在:" + shardedJedis.exists("key002"));
            // 设置 key001的过期时间
            System.out.println("设置 key001的过期时间为5秒:" + jedis.expire("key001", 5));
            try {
                Thread.sleep(2000);
            } catch (InterruptedException e) {
            }
            // 查看某个key的剩余生存时间,单位【秒】.永久生存或者不存在的都返回-1
            System.out.println("查看key001的剩余生存时间:" + jedis.ttl("key001"));
            // 移除某个key的生存时间
            System.out.println("移除key001的生存时间:" + jedis.persist("key001"));
            System.out.println("查看key001的剩余生存时间:" + jedis.ttl("key001"));
            // 查看key所储存的值的类型
            System.out.println("查看key所储存的值的类型:" + jedis.type("key001"));
            /*
             * 一些其他方法:1、修改键名:jedis.rename("key6", "key0");
             *             2、将当前db的key移动到给定的db当中:jedis.move("foo", 1)
             */
        }
    
        private void StringOperate() {
            System.out.println("======================String_1==========================");
            // 清空数据
            System.out.println("清空库中所有数据:" + jedis.flushDB());
    
            System.out.println("=============增=============");
            jedis.set("key001", "value001");
            jedis.set("key002", "value002");
            jedis.set("key003", "value003");
            System.out.println("已新增的3个键值对如下:");
            System.out.println(jedis.get("key001"));
            System.out.println(jedis.get("key002"));
            System.out.println(jedis.get("key003"));
    
            System.out.println("=============删=============");
            System.out.println("删除key003键值对:" + jedis.del("key003"));
            System.out.println("获取key003键对应的值:" + jedis.get("key003"));
    
            System.out.println("=============改=============");
            //1、直接覆盖原来的数据
            System.out.println("直接覆盖key001原来的数据:" + jedis.set("key001", "value001-update"));
            System.out.println("获取key001对应的新值:" + jedis.get("key001"));
            //2、直接覆盖原来的数据
            System.out.println("在key002原来值后面追加:" + jedis.append("key002", "+appendString"));
            System.out.println("获取key002对应的新值" + jedis.get("key002"));
    
            System.out.println("=============增,删,查(多个)=============");
            /**
             * mset,mget同时新增,修改,查询多个键值对
             * 等价于:
             * jedis.set("name","ssss");
             * jedis.set("jarorwar","xxxx");
             */
            System.out.println("一次性新增key201,key202,key203,key204及其对应值:" + jedis.mset("key201", "value201",
                    "key202", "value202", "key203", "value203", "key204", "value204"));
            System.out.println("一次性获取key201,key202,key203,key204各自对应的值:" +
                    jedis.mget("key201", "key202", "key203", "key204"));
            System.out.println("一次性删除key201,key202:" + jedis.del(new String[]{"key201", "key202"}));
            System.out.println("一次性获取key201,key202,key203,key204各自对应的值:" +
                    jedis.mget("key201", "key202", "key203", "key204"));
            System.out.println();
    
    
            //jedis具备的功能shardedJedis中也可直接使用,下面测试一些前面没用过的方法
            System.out.println("======================String_2==========================");
            // 清空数据
            System.out.println("清空库中所有数据:" + jedis.flushDB());
    
            System.out.println("=============新增键值对时防止覆盖原先值=============");
            System.out.println("原先key301不存在时,新增key301:" + shardedJedis.setnx("key301", "value301"));
            System.out.println("原先key302不存在时,新增key302:" + shardedJedis.setnx("key302", "value302"));
            System.out.println("当key302存在时,尝试新增key302:" + shardedJedis.setnx("key302", "value302_new"));
            System.out.println("获取key301对应的值:" + shardedJedis.get("key301"));
            System.out.println("获取key302对应的值:" + shardedJedis.get("key302"));
    
            System.out.println("=============超过有效期键值对被删除=============");
            // 设置key的有效期,并存储数据
            System.out.println("新增key303,并指定过期时间为2秒" + shardedJedis.setex("key303", 2, "key303-2second"));
            System.out.println("获取key303对应的值:" + shardedJedis.get("key303"));
            try {
                Thread.sleep(3000);
            } catch (InterruptedException e) {
            }
            System.out.println("3秒之后,获取key303对应的值:" + shardedJedis.get("key303"));
    
            System.out.println("=============获取原值,更新为新值一步完成=============");
            System.out.println("key302原值:" + shardedJedis.getSet("key302", "value302-after-getset"));
            System.out.println("key302新值:" + shardedJedis.get("key302"));
    
            System.out.println("=============获取子串=============");
            System.out.println("获取key302对应值中的子串:" + shardedJedis.getrange("key302", 5, 7));
        }
    
        private void ListOperate() {
            System.out.println("======================list==========================");
            // 清空数据
            System.out.println("清空库中所有数据:" + jedis.flushDB());
    
            System.out.println("=============增=============");
            shardedJedis.lpush("stringlists", "vector");
            shardedJedis.lpush("stringlists", "ArrayList");
            shardedJedis.lpush("stringlists", "vector");
            shardedJedis.lpush("stringlists", "vector");
            shardedJedis.lpush("stringlists", "LinkedList");
            shardedJedis.lpush("stringlists", "MapList");
            shardedJedis.lpush("stringlists", "SerialList");
            shardedJedis.lpush("stringlists", "HashList");
            shardedJedis.lpush("numberlists", "3");
            shardedJedis.lpush("numberlists", "1");
            shardedJedis.lpush("numberlists", "5");
            shardedJedis.lpush("numberlists", "2");
            System.out.println("所有元素-stringlists:" + shardedJedis.lrange("stringlists", 0, -1));
            System.out.println("所有元素-numberlists:" + shardedJedis.lrange("numberlists", 0, -1));
    
            System.out.println("=============删=============");
            // 删除列表指定的值 ,第二个参数为删除的个数(有重复时),后add进去的值先被删,类似于出栈
            System.out.println("成功删除指定元素个数-stringlists:" + shardedJedis.lrem("stringlists", 2, "vector"));
            System.out.println("删除指定元素之后-stringlists:" + shardedJedis.lrange("stringlists", 0, -1));
            // 删除区间以外的数据
            System.out.println("删除下标0-3区间之外的元素:" + shardedJedis.ltrim("stringlists", 0, 3));
            System.out.println("删除指定区间之外元素后-stringlists:" + shardedJedis.lrange("stringlists", 0, -1));
            // 列表元素出栈
            System.out.println("出栈元素:" + shardedJedis.lpop("stringlists"));
            System.out.println("元素出栈后-stringlists:" + shardedJedis.lrange("stringlists", 0, -1));
    
            System.out.println("=============改=============");
            // 修改列表中指定下标的值
            shardedJedis.lset("stringlists", 0, "hello list!");
            System.out.println("下标为0的值修改后-stringlists:" + shardedJedis.lrange("stringlists", 0, -1));
            System.out.println("=============查=============");
            // 数组长度
            System.out.println("长度-stringlists:" + shardedJedis.llen("stringlists"));
            System.out.println("长度-numberlists:" + shardedJedis.llen("numberlists"));
            // 排序
            /*
             * list中存字符串时必须指定参数为alpha,如果不使用SortingParams,而是直接使用sort("list"),
             * 会出现"ERR One or more scores can't be converted into double"
             */
            SortingParams sortingParameters = new SortingParams();
            sortingParameters.alpha();
            sortingParameters.limit(0, 3);
            System.out.println("返回排序后的结果-stringlists:" + shardedJedis.sort("stringlists", sortingParameters));
            System.out.println("返回排序后的结果-numberlists:" + shardedJedis.sort("numberlists"));
            // 子串:  start为元素下标,end也为元素下标;-1代表倒数一个元素,-2代表倒数第二个元素
            System.out.println("子串-第二个开始到结束:" + shardedJedis.lrange("stringlists", 1, -1));
            // 获取列表指定下标的值
            System.out.println("获取下标为2的元素:" + shardedJedis.lindex("stringlists", 2) + "
    ");
        }
    
        private void SetOperate() {
            System.out.println("======================set==========================");
            // 清空数据
            System.out.println("清空库中所有数据:" + jedis.flushDB());
    
            System.out.println("=============增=============");
            System.out.println("向sets集合中加入元素element001:" + jedis.sadd("sets", "element001"));
            System.out.println("向sets集合中加入元素element002:" + jedis.sadd("sets", "element002"));
            System.out.println("向sets集合中加入元素element003:" + jedis.sadd("sets", "element003"));
            System.out.println("向sets集合中加入元素element004:" + jedis.sadd("sets", "element004"));
            System.out.println("查看sets集合中的所有元素:" + jedis.smembers("sets"));
            System.out.println();
    
            System.out.println("=============删=============");
            System.out.println("集合sets中删除元素element003:" + jedis.srem("sets", "element003"));
            System.out.println("查看sets集合中的所有元素:" + jedis.smembers("sets"));
            /*System.out.println("sets集合中任意位置的元素出栈:"+jedis.spop("sets"));//注:出栈元素位置居然不定?--无实际意义
            System.out.println("查看sets集合中的所有元素:"+jedis.smembers("sets"));*/
            System.out.println();
    
            System.out.println("=============改=============");
            System.out.println();
    
            System.out.println("=============查=============");
            System.out.println("判断element001是否在集合sets中:" + jedis.sismember("sets", "element001"));
            System.out.println("循环查询获取sets中的每个元素:");
            Set<String> set = jedis.smembers("sets");
            Iterator<String> it = set.iterator();
            while (it.hasNext()) {
                Object obj = it.next();
                System.out.println(obj);
            }
            System.out.println();
    
            System.out.println("=============集合运算=============");
            System.out.println("sets1中添加元素element001:" + jedis.sadd("sets1", "element001"));
            System.out.println("sets1中添加元素element002:" + jedis.sadd("sets1", "element002"));
            System.out.println("sets1中添加元素element003:" + jedis.sadd("sets1", "element003"));
            System.out.println("sets1中添加元素element002:" + jedis.sadd("sets2", "element002"));
            System.out.println("sets1中添加元素element003:" + jedis.sadd("sets2", "element003"));
            System.out.println("sets1中添加元素element004:" + jedis.sadd("sets2", "element004"));
            System.out.println("查看sets1集合中的所有元素:" + jedis.smembers("sets1"));
            System.out.println("查看sets2集合中的所有元素:" + jedis.smembers("sets2"));
            System.out.println("sets1和sets2交集:" + jedis.sinter("sets1", "sets2"));
            System.out.println("sets1和sets2并集:" + jedis.sunion("sets1", "sets2"));
            System.out.println("sets1和sets2差集:" + jedis.sdiff("sets1", "sets2"));//差集:set1中有,set2中没有的元素
        }
    
        private void SortedSetOperate() {
            System.out.println("======================zset==========================");
            // 清空数据
            System.out.println(jedis.flushDB());
    
            System.out.println("=============增=============");
            System.out.println("zset中添加元素element001:" + shardedJedis.zadd("zset", 7.0, "element001"));
            System.out.println("zset中添加元素element002:" + shardedJedis.zadd("zset", 8.0, "element002"));
            System.out.println("zset中添加元素element003:" + shardedJedis.zadd("zset", 2.0, "element003"));
            System.out.println("zset中添加元素element004:" + shardedJedis.zadd("zset", 3.0, "element004"));
            System.out.println("zset集合中的所有元素:" + shardedJedis.zrange("zset", 0, -1));//按照权重值排序
            System.out.println();
    
            System.out.println("=============删=============");
            System.out.println("zset中删除元素element002:" + shardedJedis.zrem("zset", "element002"));
            System.out.println("zset集合中的所有元素:" + shardedJedis.zrange("zset", 0, -1));
            System.out.println();
    
            System.out.println("=============改=============");
            System.out.println();
    
            System.out.println("=============查=============");
            System.out.println("统计zset集合中的元素中个数:" + shardedJedis.zcard("zset"));
            System.out.println("统计zset集合中权重某个范围内(1.0——5.0),元素的个数:" + shardedJedis.zcount("zset", 1.0, 5.0));
            System.out.println("查看zset集合中element004的权重:" + shardedJedis.zscore("zset", "element004"));
            System.out.println("查看下标1到2范围内的元素值:" + shardedJedis.zrange("zset", 1, 2));
    
        }
    
        private void HashOperate() {
            System.out.println("======================hash==========================");
            //清空数据
            System.out.println(jedis.flushDB());
    
            System.out.println("=============增=============");
            System.out.println("hashs中添加key001和value001键值对:" + shardedJedis.hset("hashs", "key001", "value001"));
            System.out.println("hashs中添加key002和value002键值对:" + shardedJedis.hset("hashs", "key002", "value002"));
            System.out.println("hashs中添加key003和value003键值对:" + shardedJedis.hset("hashs", "key003", "value003"));
            System.out.println("新增key004和4的整型键值对:" + shardedJedis.hincrBy("hashs", "key004", 4l));
            System.out.println("hashs中的所有值:" + shardedJedis.hvals("hashs"));
            System.out.println();
    
            System.out.println("=============删=============");
            System.out.println("hashs中删除key002键值对:" + shardedJedis.hdel("hashs", "key002"));
            System.out.println("hashs中的所有值:" + shardedJedis.hvals("hashs"));
            System.out.println();
    
            System.out.println("=============改=============");
            System.out.println("key004整型键值的值增加100:" + shardedJedis.hincrBy("hashs", "key004", 100l));
            System.out.println("hashs中的所有值:" + shardedJedis.hvals("hashs"));
            System.out.println();
    
            System.out.println("=============查=============");
            System.out.println("判断key003是否存在:" + shardedJedis.hexists("hashs", "key003"));
            System.out.println("获取key004对应的值:" + shardedJedis.hget("hashs", "key004"));
            System.out.println("批量获取key001和key003对应的值:" + shardedJedis.hmget("hashs", "key001", "key003"));
            System.out.println("获取hashs中所有的key:" + shardedJedis.hkeys("hashs"));
            System.out.println("获取hashs中所有的value:" + shardedJedis.hvals("hashs"));
            System.out.println();
        }
    
    }

    测试代码

    package redis;
    
    import redis.clients.jedis.Jedis;
    
    /**
     * Created by lxd on 2019/6/25.
     */
    public class Main {
        public static void main(String[] args) {
            new RedisClient().show();
            /*
            RedisClient redisClient = new RedisClient();
            Jedis jedis = redisClient.getJedis();
            //jedis.append("keylxd","lxdlxdlxd");
            jedis.set("keylxd","lxd2");
            System.out.println(jedis.get("keylxd"));
    */
    
    
        }
    }

    执行结果

    "C:Program FilesJavajdk1.8.0_131injava" "-javaagent:D:ServerIntelliJ IDEA 2017.1libidea_rt.jar=7354:D:ServerIntelliJ IDEA 2017.1in" -Dfile.encoding=UTF-8 -classpath "C:Program FilesJavajdk1.8.0_131jrelibcharsets.jar;C:Program FilesJavajdk1.8.0_131jrelibdeploy.jar;C:Program FilesJavajdk1.8.0_131jrelibextaccess-bridge-64.jar;C:Program FilesJavajdk1.8.0_131jrelibextcldrdata.jar;C:Program FilesJavajdk1.8.0_131jrelibextdnsns.jar;C:Program FilesJavajdk1.8.0_131jrelibextjaccess.jar;C:Program FilesJavajdk1.8.0_131jrelibextjfxrt.jar;C:Program FilesJavajdk1.8.0_131jrelibextlocaledata.jar;C:Program FilesJavajdk1.8.0_131jrelibext
    ashorn.jar;C:Program FilesJavajdk1.8.0_131jrelibextsunec.jar;C:Program FilesJavajdk1.8.0_131jrelibextsunjce_provider.jar;C:Program FilesJavajdk1.8.0_131jrelibextsunmscapi.jar;C:Program FilesJavajdk1.8.0_131jrelibextsunpkcs11.jar;C:Program FilesJavajdk1.8.0_131jrelibextzipfs.jar;C:Program FilesJavajdk1.8.0_131jrelibjavaws.jar;C:Program FilesJavajdk1.8.0_131jrelibjce.jar;C:Program FilesJavajdk1.8.0_131jrelibjfr.jar;C:Program FilesJavajdk1.8.0_131jrelibjfxswt.jar;C:Program FilesJavajdk1.8.0_131jrelibjsse.jar;C:Program FilesJavajdk1.8.0_131jrelibmanagement-agent.jar;C:Program FilesJavajdk1.8.0_131jrelibplugin.jar;C:Program FilesJavajdk1.8.0_131jrelib
    esources.jar;C:Program FilesJavajdk1.8.0_131jrelib
    t.jar;D:WorkSpaceIdeaSpacelxd	argetclasses;C:UsersAdministrator.m2
    epositorycommons-poolcommons-pool1.5.5commons-pool-1.5.5.jar;C:UsersAdministrator.m2
    epository
    edisclientsjedis2.1.0jedis-2.1.0.jar" redis.Main
    ======================key==========================
    清空库中所有数据:OK
    判断key999键是否存在:false
    新增key001,value001键值对:OK
    判断key001是否存在:true
    新增key002,value002键值对:OK
    系统中所有键如下:
    key002
    key001
    系统中删除key002: 1
    判断key002是否存在:false
    设置 key001的过期时间为5秒:1
    查看key001的剩余生存时间:3
    移除key001的生存时间:1
    查看key001的剩余生存时间:-1
    查看key所储存的值的类型:string
    ======================String_1==========================
    清空库中所有数据:OK
    =============增=============
    已新增的3个键值对如下:
    value001
    value002
    value003
    =============删=============
    删除key003键值对:1
    获取key003键对应的值:null
    =============改=============
    直接覆盖key001原来的数据:OK
    获取key001对应的新值:value001-update
    在key002原来值后面追加:21
    获取key002对应的新值value002+appendString
    =============增,删,查(多个)=============
    一次性新增key201,key202,key203,key204及其对应值:OK
    一次性获取key201,key202,key203,key204各自对应的值:[value201, value202, value203, value204]
    一次性删除key201,key202:2
    一次性获取key201,key202,key203,key204各自对应的值:[null, null, value203, value204]
    
    ======================String_2==========================
    清空库中所有数据:OK
    =============新增键值对时防止覆盖原先值=============
    原先key301不存在时,新增key301:1
    原先key302不存在时,新增key302:1
    当key302存在时,尝试新增key302:0
    获取key301对应的值:value301
    获取key302对应的值:value302
    =============超过有效期键值对被删除=============
    新增key303,并指定过期时间为2秒OK
    获取key303对应的值:key303-2second
    3秒之后,获取key303对应的值:null
    =============获取原值,更新为新值一步完成=============
    key302原值:value302
    key302新值:value302-after-getset
    =============获取子串=============
    获取key302对应值中的子串:302
    ======================list==========================
    清空库中所有数据:OK
    =============增=============
    所有元素-stringlists:[HashList, SerialList, MapList, LinkedList, vector, vector, ArrayList, vector]
    所有元素-numberlists:[2, 5, 1, 3]
    =============删=============
    成功删除指定元素个数-stringlists:2
    删除指定元素之后-stringlists:[HashList, SerialList, MapList, LinkedList, ArrayList, vector]
    删除下标0-3区间之外的元素:OK
    删除指定区间之外元素后-stringlists:[HashList, SerialList, MapList, LinkedList]
    出栈元素:HashList
    元素出栈后-stringlists:[SerialList, MapList, LinkedList]
    =============改=============
    下标为0的值修改后-stringlists:[hello list!, MapList, LinkedList]
    =============查=============
    长度-stringlists:3
    长度-numberlists:4
    返回排序后的结果-stringlists:[LinkedList, MapList, hello list!]
    返回排序后的结果-numberlists:[1, 2, 3, 5]
    子串-第二个开始到结束:[MapList, LinkedList]
    获取下标为2的元素:LinkedList
    
    ======================set==========================
    清空库中所有数据:OK
    =============增=============
    向sets集合中加入元素element001:1
    向sets集合中加入元素element002:1
    向sets集合中加入元素element003:1
    向sets集合中加入元素element004:1
    查看sets集合中的所有元素:[element003, element002, element001, element004]
    
    =============删=============
    集合sets中删除元素element003:1
    查看sets集合中的所有元素:[element002, element001, element004]
    
    =============改=============
    
    =============查=============
    判断element001是否在集合sets中:true
    循环查询获取sets中的每个元素:
    element002
    element001
    element004
    
    =============集合运算=============
    sets1中添加元素element001:1
    sets1中添加元素element002:1
    sets1中添加元素element003:1
    sets1中添加元素element002:1
    sets1中添加元素element003:1
    sets1中添加元素element004:1
    查看sets1集合中的所有元素:[element003, element002, element001]
    查看sets2集合中的所有元素:[element003, element002, element004]
    sets1和sets2交集:[element003, element002]
    sets1和sets2并集:[element003, element002, element001, element004]
    sets1和sets2差集:[element001]
    ======================zset==========================
    OK
    =============增=============
    zset中添加元素element001:1
    zset中添加元素element002:1
    zset中添加元素element003:1
    zset中添加元素element004:1
    zset集合中的所有元素:[element003, element004, element001, element002]
    
    =============删=============
    zset中删除元素element002:1
    zset集合中的所有元素:[element003, element004, element001]
    
    =============改=============
    
    =============查=============
    统计zset集合中的元素中个数:3
    统计zset集合中权重某个范围内(1.0——5.0),元素的个数:2
    查看zset集合中element004的权重:3.0
    查看下标1到2范围内的元素值:[element004, element001]
    ======================hash==========================
    OK
    =============增=============
    hashs中添加key001和value001键值对:1
    hashs中添加key002和value002键值对:1
    hashs中添加key003和value003键值对:1
    新增key004和4的整型键值对:4
    hashs中的所有值:[value001, value002, value003, 4]
    
    =============删=============
    hashs中删除key002键值对:1
    hashs中的所有值:[value001, value003, 4]
    
    =============改=============
    key004整型键值的值增加100:104
    hashs中的所有值:[value001, value003, 104]
    
    =============查=============
    判断key003是否存在:true
    获取key004对应的值:104
    批量获取key001和key003对应的值:[value001, value003]
    获取hashs中所有的key:[key004, key003, key001]
    获取hashs中所有的value:[value001, value003, 104]
    
    
    Process finished with exit code 0

    4、常用命令

     1)连接操作命令
        quit:关闭连接(connection)
        auth:简单密码认证
        help cmd: 查看cmd帮助,例如:help quit
        
        2)持久化
        save:将数据同步保存到磁盘
        bgsave:将数据异步保存到磁盘
        lastsave:返回上次成功将数据保存到磁盘的Unix时戳
        shundown:将数据同步保存到磁盘,然后关闭服务
        
        3)远程服务控制
        info:提供服务器的信息和统计
        monitor:实时转储收到的请求
        slaveof:改变复制策略设置
        config:在运行时配置Redis服务器
        
        4)对value操作的命令
        exists(key):确认一个key是否存在
        del(key):删除一个key
        type(key):返回值的类型
        keys(pattern):返回满足给定pattern的所有key
        randomkey:随机返回key空间的一个
        keyrename(oldname, newname):重命名key
        dbsize:返回当前数据库中key的数目
        expire:设定一个key的活动时间(s)
        ttl:获得一个key的活动时间
        select(index):按索引查询
        move(key, dbindex):移动当前数据库中的key到dbindex数据库
        flushdb:删除当前选择数据库中的所有key
        flushall:删除所有数据库中的所有key
        
        5)String
        set(key, value):给数据库中名称为key的string赋予值value
        get(key):返回数据库中名称为key的string的value
        getset(key, value):给名称为key的string赋予上一次的value
        mget(key1, key2,…, key N):返回库中多个string的value
        setnx(key, value):添加string,名称为key,值为value
        setex(key, time, value):向库中添加string,设定过期时间time
        mset(key N, value N):批量设置多个string的值
        msetnx(key N, value N):如果所有名称为key i的string都不存在
        incr(key):名称为key的string增1操作
        incrby(key, integer):名称为key的string增加integer
        decr(key):名称为key的string减1操作
        decrby(key, integer):名称为key的string减少integer
        append(key, value):名称为key的string的值附加value
        substr(key, start, end):返回名称为key的string的value的子串
        
        6)List 
        rpush(key, value):在名称为key的list尾添加一个值为value的元素
        lpush(key, value):在名称为key的list头添加一个值为value的 元素
        llen(key):返回名称为key的list的长度
        lrange(key, start, end):返回名称为key的list中start至end之间的元素
        ltrim(key, start, end):截取名称为key的list
        lindex(key, index):返回名称为key的list中index位置的元素
        lset(key, index, value):给名称为key的list中index位置的元素赋值
        lrem(key, count, value):删除count个key的list中值为value的元素
        lpop(key):返回并删除名称为key的list中的首元素
        rpop(key):返回并删除名称为key的list中的尾元素
        blpop(key1, key2,… key N, timeout):lpop命令的block版本。
        brpop(key1, key2,… key N, timeout):rpop的block版本。
        rpoplpush(srckey, dstkey):返回并删除名称为srckey的list的尾元素,

                  并将该元素添加到名称为dstkey的list的头部
        
        7)Set
        sadd(key, member):向名称为key的set中添加元素member
        srem(key, member) :删除名称为key的set中的元素member
        spop(key) :随机返回并删除名称为key的set中一个元素
        smove(srckey, dstkey, member) :移到集合元素
        scard(key) :返回名称为key的set的基数
        sismember(key, member) :member是否是名称为key的set的元素
        sinter(key1, key2,…key N) :求交集
        sinterstore(dstkey, (keys)) :求交集并将交集保存到dstkey的集合
        sunion(key1, (keys)) :求并集
        sunionstore(dstkey, (keys)) :求并集并将并集保存到dstkey的集合
        sdiff(key1, (keys)) :求差集
        sdiffstore(dstkey, (keys)) :求差集并将差集保存到dstkey的集合
        smembers(key) :返回名称为key的set的所有元素
        srandmember(key) :随机返回名称为key的set的一个元素
        
        8)Hash
        hset(key, field, value):向名称为key的hash中添加元素field
        hget(key, field):返回名称为key的hash中field对应的value
        hmget(key, (fields)):返回名称为key的hash中field i对应的value
        hmset(key, (fields)):向名称为key的hash中添加元素field 
        hincrby(key, field, integer):将名称为key的hash中field的value增加integer
        hexists(key, field):名称为key的hash中是否存在键为field的域
        hdel(key, field):删除名称为key的hash中键为field的域
        hlen(key):返回名称为key的hash中元素个数
        hkeys(key):返回名称为key的hash中所有键
        hvals(key):返回名称为key的hash中所有键对应的value
        hgetall(key):返回名称为key的hash中所有的键(field)及其对应的value

    参考

    https://www.cnblogs.com/edisonfeng/p/3571870.html

          

  • 相关阅读:
    ES6数组的扩展--Array.from()和Array.of()
    前端面试中的各种方法实现
    理解 JavaScript call()/apply()/bind()
    【前端面试】变量和类型计算
    Kubernetes1.3新特性:支持GPU
    撸了一个微信小程序项目
    微信开发(调用各种接口)
    Android 神兵利器之通过解析网页获取到的API数据合集,可拿来就用
    Kubernetes1.4正式发布
    Kubernetes1.4即将发布
  • 原文地址:https://www.cnblogs.com/luxd/p/11081864.html
Copyright © 2011-2022 走看看