• redis相关


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

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

    Redis 优势

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

    ---------------------------------------------------------

    安装成功后:

     -----------------------------------------------------------------------

    Redis 数据类型

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

    string (字符串):最大能存储 512MB

    hash(哈希):是一个 string 类型的 field 和 value 的映射表

     list(列表):Redis 列表是简单的字符串列表,按照插入顺序排序。你可以添加一个元素到列表的头部(左边)或者尾部(右边)。

     set(集合):Redis 的 Set 是 string 类型的无序集合。

     zset(sorted set:有序集合):Redis zset 和 set 一样也是string类型元素的集合,且不允许重复的成员。

     ------------------------------------

    java操作redis

    package dataMonitor.datawarehouse;

    import java.util.HashMap;
    import java.util.Iterator;
    import java.util.List;
    import java.util.Map;

    import redis.clients.jedis.Jedis;

    public class RedisDemo {
        static Jedis jedis = new Jedis("172.16.193.200", 6379);

        public static void main(String[] args) {
            System.out.println("连接成功------->" + jedis.ping());
        
            //testString();
            testMap();

        }

        public static void testString() {
            // 添加数据
            jedis.set("name", "danyu");
            System.out.println(jedis.get("name"));

            // 拼接字符串
            jedis.append("name", "wang");
            System.out.println(jedis.get("name"));

            // 删除数据
            jedis.del("name");
            System.out.println(jedis.get("name"));

            // 设置多个键值对
            jedis.mset("name", "yc", "age", "22", "qq", "1933108196");
            jedis.incr("age");// 加1操作
            System.out.println(jedis.get("name") + "-" + jedis.get("age") + "-" + jedis.get("qq"));
        }

        public static void testMap() {
            // 添加数据
            Map<String, String> map = new HashMap<String, String>();

            map.put("name", "yc");
            map.put("age", "22");
            map.put("qq", "1933108196");
            jedis.hmset("user", map);

            // 取出users中的Name,执行结果:[minxr]-->注意结果是一个泛型的List
            // 第一个参数是存入redis中map对象的key,后面跟的是放入map中对象的key,后面的key可以是多个,是可变的
            List<String> rsmap = jedis.hmget("user", "name", "age", "qq");
            System.out.println(rsmap);

            // 删除map中的某个键值
            jedis.hdel("user", "age");
            System.out.println(jedis.hmget("user", "age"));// 因为删除了,所以返回的是Null
            System.out.println(jedis.hlen("user"));// 返回key为user的键中存放的值的个数2
            System.out.println(jedis.exists("user"));// 是否存在key为user的记录,返回true
            System.out.println(jedis.hkeys("user"));// 返回map对象中的所有key
            System.out.println(jedis.hvals("user"));// 返回map对象中的所有value

            Iterator<String> iter = jedis.hkeys("user").iterator();
            while (iter.hasNext()) {
                String key = iter.next();
                System.out.println(key + ":" + jedis.hmget("user", key));
            }

        }

        /**
         * redis操作List集合
         */
        public static void testList() {
            // 开始前,先移除所有的内容
            jedis.del("java framework");
            System.out.println(jedis.lrange("java framework", 0, -1));

            // 先向key java framework 中存放三条数据
            jedis.lpush("java framework", "spring");
            jedis.lpush("java framework", "struts");
            jedis.lpush("java framework", "hibernate");

            // 再取出所有数据jedis.lrange是按范围取出
            // 第一个是key,第二个是起始位置,第三个是结束位置,jedis.llen获取长度 -1表示取得所有
            System.out.println(jedis.lrange("java framework", 0, -1));

            jedis.del("java framework");
            jedis.rpush("java framework", "spring");
            jedis.rpush("java framework", "struts");
            jedis.rpush("java framework", "hibernate");
            System.out.println(jedis.lrange("java framework", 0, -1));

        }

        /**
         * redis操作set集合
         *
         */

        public static void testSet() {

            // 添加
            jedis.sadd("user", "liuling");
            jedis.sadd("user", "xinxin");
            jedis.sadd("user", "ling");
            jedis.sadd("user", "zhangxinxin");
            jedis.sadd("user", "who");

            // 删除
            jedis.srem("user", "who");
            System.out.println(jedis.smembers("user"));// 获取所有加入的value
            System.out.println(jedis.sismember("user", "who"));// 判断who是否是user集合的元素
            System.out.println(jedis.srandmember("user"));
            System.out.println(jedis.scard("user"));// 返回集合的元素个数

        }

        /**
         * redis排序
         */

        public static void testSort() {

            // jedis 排序
            // 注意,此处的rpush和lpush是List的操作。是一个双向链表(但从表现来看的)
            jedis.del("a");// 先清除数据,再加入数据进行测试
            jedis.rpush("a", "1");
            jedis.lpush("a", "6");
            jedis.lpush("a", "3");
            jedis.lpush("a", "9");
            System.out.println(jedis.lrange("a", 0, -1));
            System.out.println(jedis.sort("a"));// [1,3,6,9] //输入排序后结果
            System.out.println(jedis.lrange("a", 0, -1));

        }

    }

  • 相关阅读:
    tp5更改入口文件到根目录的方法分享
    Linux安装JBOSS
    JBOSS和WebLogic区别
    面向对象编程的思维方式
    Struts+Spring+Hibernate整合入门详解
    DB2 UDB V8.1 管理
    oracle与DB2的一些架构
    oracle和DB2的差异
    JDK和JRE的区别
    Linux安装weblogic
  • 原文地址:https://www.cnblogs.com/danyuzhu11/p/11906413.html
Copyright © 2020-2023  润新知