redis的简单入门与Jedis的代码操作

redis

1、概念

redis是一款高性能的NoSQL系列的非关系型数据库

2、什么是NoSQL

NoSQL(NoSQL = Not Only SQL ),意即“不仅仅是SQL”,
泛指非关系型的数据库。随着互联网web2.0网站的兴起,传统的关系数据库在应付web2.0网站,特别是超大规模和高并发的SNS类型的web2.0纯动态网站已经显得力不从心,暴露了很多难以克服的问题,而非关系型的数据库则由于其本身的特点得到了非常迅速的发展。NoSQL数据库的产生就是为了解决大规模数据集合多重数据种类带来的挑战,尤其是大数据应用难题,包括超大规模数据的存储。

(例如谷歌或Facebook每天为他们的用户收集万亿比特的数据)。这些类型的数据存储不需要固定的模式,无需多余操作就可以横向扩展。

3、NoSQL和关系型数据库比较

NoSQL的优势和劣势

优点:

  • 关系型数据库有类似Join这样的多表查询机制的限制导致扩展很艰难,NoSQL数据库不支持Join处理,各个数据都是独立设计的,很容易把数据分散在多个服务器上。
  • NoSQL的存储格式是键值存储形式、面向文档形式、面向列形式等,所以可以存储基础类型以及对象或者是集合等各种格式,而关系数据库则只支持基础类型
  • 大量数据的写入处理
  • 对数据进行缓存(Cache)处理
  • 对数组类型的数据进行高速处理
  • 对数据进行全部保存处理

缺点:

  • 不提供关系型数据库对事务的处理
  • 属于新的技术维护的工具和资料有限、将产生一定用户的学习和使用成本
关系型数据库的优势和劣势:

优点:

  • 保持数据的一致性(事务处理)[关系型数据库的最大优势]
  • 由于以标准化为前提,数据更新的开销很小(相同的字段基本上都只有一处)
  • 可以进行Join等复杂查询(不同服务器之间不能进行Join处理)
  • .存在很多实际成果和专业技术信息(成熟的技术)
  • 把所有的数据都通过行和列的二元表现形式表示出来,给人更容易理解的直观感受

缺点:

  • 大量数据的写入处理
  • 为有数据更新的表做索引或表结构(schema)变更
  • 字段不固定时应用
  • 对简单查询需要快速返回结果的处理

4、下载安装

  1. 官网:http://redis.io(不建议访问这个)
  2. 中文网:http://www.redis.net.cn/(建议)
  3. 解压直接可以使用:
    • redis.windows.conf:配置文件
    • redis.cli.exe:redis的客户端
    • redis.server.exe:redis的服务器端

5、命令操作

  1. redis的数据结构:
    • redis存储的是:key,value格式的数据,其中key都市字符串,value有五种不同的数据结构
    • value的数据结构:
      1. 字符串类型 String
      2. 哈希类型 hash:map格式
      3. 列表类型 list:linkedlist格式
      4. 集合类型 set :不可重复,无序
      5. 有序集合 sortedse :不可重复且有序
  2. 字符串类型:String
    • 存储:set key value
    • 获取:get key
    • 删除:del key
  3. 哈希类型
    • 存储:hset key field value
    • 获取:
      1. hget key field:获取指定的field对应的值
      2. hgetall key:获取所有的field和value
    • 删除:hdel key field
  4. 列表类型 list:可以添加一个元素到列表的头部(左边)或者尾部(右边)
    • 存储
      1. lpush key value:将元素加入到列表左边
      2. rpush key value:将元素加入到列表右边
    • 获取:lrange key start end 范围获取(获取全部:lrange key 0 -1)
    • 删除:
      1. lpop key:删除列表最左边的元素,并将元素返回
      2. rpop key:删除列表最右边的元素,并将元素返回
  5. 集合类型 set:不允许重复元素
    • 存储:sadd key value
    • 获取:smembers key (获取set集合中所有元素)
    • 删除:srem key value(删除set集合中某个元素)
  6. 有序结合类型 sortedset:不允许重复元素,且元素有序
    • 存储:zadd key score value
    • 获取:zrange key start end
    • 删除:zrem key value
  7. 通用命令
    • keys *:查询所有的键
    • type key:获取对应的value的类型
    • del key:删除指定的key value

6、持久化

  1. redis是一个内存数据库,当redis服务器重启、或者电脑重启,数据就会丢失,我们可以将redis内存中的数据持久化保存在硬盘文件中

  2. redis的持久化机制
    • ROB:默认方式,不需要进行配置,默认就使用这种机制

      • 在一定的间隔中,检测key的变化情况,然后持久化数据

        1. 编辑redis.windows.conf文件

          ​ save 900 1(15分钟内key至少有1个key发生改变,持久化一次)

          ​ save 300 10(5分钟内key至少有10个key发生改变,持久化一次)

          ​ save 60 10000(1分钟内key至少有10000个key发生改变,持久化一次)

        2. 重新启动redis服务器,并指定配置文件名称

    • AOF:日志记录的方式,可以记录每一条命令的操作。可以每一次命令操作后,持久化数据

      1. 编辑redis.windows.conf文件
        • appendonly no(关闭aof) -----> appendonly yes(开启aof)
        • appendfsync always:每一次操作都持久化
        • appendfsync everysec:每隔一秒进行一次持久化
        • appendfsync no:不进行持久化

7、java客户端 Jedis

  • Jedis:一款java操作redis数据库的工具

  • 使用步骤
    1. 下载jedis的jar包

      ​ 地址:https://mvnrepository.com/

    在这里插入图片描述

    1. 使用

      //1、获取连接
      Jedis jedis=new Jedis("localhost",6379);
      //2、操作
      jedis.set("username","zhangsan");
      //3、关闭连接
      jedis.close();
      
  • Jedis操作各种redis中的数据结构
    1. 字符串类型 String
     @Test
        public void test2(){
            //1、获取连接
            Jedis jedis=new Jedis();//如果是空参,默认是:“localhost”,6379端口
            //2、操作
            //存储
            jedis.set("username","zhangsan");
            //获取
            String s=jedis.get("username");
            System.out.println(s);
            //可以使用setex()方法存储可以指定过期时间的key和value
            jedis.setex("activecode",20,"4536");//将activecode:4536键值对存入redis,并在20s后删除
            //3、关闭连接
            jedis.close();
        }
    
    1. 哈希类型 hash:map格式
    /**
     * hash 数据结构操作
     */
    @Test
    public void test3(){
        //1、获取连接
        Jedis jedis=new Jedis();//如果是空参,默认是:“localhost”,6379端口
        //2、操作
        //存储
        jedis.hset("user","name","lisi");
        jedis.hset("user","age","38");
        jedis.hset("user","gender","male");
        //获取
        String s=jedis.hget("user","name");
        System.out.println(s);
        //获取hash中所有map的数据
        Map<String, String> user = jedis.hgetAll("user");
        Set<String> keySet = user.keySet();
        for (String key : keySet) {
            String value=user.get(key);
            System.out.println(key+":"+value);
        }
    
        //3、关闭连接
        jedis.close();
    }
    
    1. 列表类型 list:linkedlist格式
    /**
     * list 数据结构操作
     */
    @Test
    public void test4(){
        //1、获取连接
        Jedis jedis=new Jedis();//如果是空参,默认是:“localhost”,6379端口
        
        //2、操作
        //list存储
        jedis.lpush("mylist","a","b","c");//从左边存
        jedis.rpush("mylist","a","b","c");//从右边存
    
        //list范围获取
        List<String> mylist = jedis.lrange("mylist", 0, -1);//0,-1代表的是获取全部
        System.out.println(mylist);//c, b, a, a, b, c
    
        //list弹出
        String s1 = jedis.lpop("mylist");//弹出最左边的元素(删除最左边的元素)
        System.out.println(s1);//c
        String s2 = jedis.rpop("mylist");//弹出最右边的元素(删除最右边的元素)
        System.out.println(s2);//c
    
        List<String> mylist1 = jedis.lrange("mylist", 0, -1);
        System.out.println(mylist1);//b, a, a, b
    
        //3、关闭连接
        jedis.close();
    }
    
    1. 集合类型 set :不可重复,无序
    /**
     * set 数据结构操作
     * 不可以重复,无序
     */
    @Test
    public void test5(){
        //1、获取连接
        Jedis jedis=new Jedis();//如果是空参,默认是:“localhost”,6379端口
    
        //2、操作
        //set存储
        jedis.sadd("myset","java","php","c++");
    
        //set获取
        Set<String> myset = jedis.smembers("myset");
        System.out.println(myset);
    
        //3、关闭连接
        jedis.close();
    }
    
    1. 有序集合 sortedse :不可重复且有序
    /**
     * sortedset 数据结构操作
     * 不可以重复,有序
     */
    @Test
    public void test6(){
        //1、获取连接
        Jedis jedis=new Jedis();//如果是空参,默认是:“localhost”,6379端口
    
        //2、操作
        //sortedset存储
        jedis.zadd("mysortedset",3,"亚瑟");
        jedis.zadd("mysortedset",20,"后羿");
        jedis.zadd("mysortedset",50,"李白");
    
        //sortedset获取
        Set<String> mysortedset = jedis.zrange("mysortedset", 0, -1);//获取全部,根据score从小到大排列
        System.out.println(mysortedset);
    
        //3、关闭连接
        jedis.close();
    }
    
    
    
  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值