Redis 简单实现sql的条件查询

redis的数据类型String、list、hashmap、set、sortedset等,一般情况不容易实现关系型数据库的灵活的条件查询。
简单介绍:把所有的user放入到map中再存入redis中,怎样根据条件查询处user。
User:为用户实体类
JsonUtil:json和实体类之间的转换
TestRedis:redis条件查询测试

package com.test.redis;

public class User { 
    private String name;
    private int age;
    private String  sex;
    private String id;  
    public User(){
        super();
    }   
    public User(String id, String name, int age, String sex){
        this.id = id;
        this.name = name;
        this.age = age;
        this.sex = sex;
    }
     // set和get方法自己补全
}
import com.alibaba.fastjson.JSON;

/**
 * 利用fastjson 对象和json字符创之间的转换
 * @author zhb
 *
 */
public class JsonUtil {
    
    /**
     * 将对象转换成json字符串
     * @param object
     * @return
     */
    public static String toJSONString(Object object){
        if(object!=null){
            return JSON.toJSONString(object);
        }
        return null;
    }   
    
    /**
     * 将json字符串转成对象T
     * @param <T>
     * @param jsonStr
     * @return
     */
    public static <T> Object parseObject(String jsonStr, Class<T> c){
        if(jsonStr!=null){
            return JSON.parseObject(jsonStr, c);
        }
        return null;        
    }
    
}

import redis.clients.jedis.Jedis;

/**
 * 利用redis的几种数据结构(String、list、hashmap、set、sortedset)之间的组合,来实现简单的条件查询
 * 缺点是要提前设置好要查询的要素
 * @author zhb
 *
 */
public class TestRedis {
    
    public static void main(String[] args) {
        
        // 链接redis
        Jedis jedis = new Jedis("127.0.0.1", 6379);
        
        // 存放user的map,user的id为key user的json字符串为value
        Map<String, String> map = new HashMap<String, String>();
        
        String id1 = UUID.randomUUID().toString();
        User user1 = new User(id1, "张三", 22 ,"m");
        map.put(id1, JsonUtil.toJSONString(user1));
        
        String id2 = UUID.randomUUID().toString();
        User user2 = new User(id2, "李四", 23 ,"m");
        map.put(id2, JsonUtil.toJSONString(user2));
        
        String id3 = UUID.randomUUID().toString();
        User user3 = new User(id3, "王五", 26 ,"w");
        map.put(id3, JsonUtil.toJSONString(user3));
        
        String id4 = UUID.randomUUID().toString();
        User user4 = new User(id4, "王六", 25 ,"w");
        map.put(id4, JsonUtil.toJSONString(user4));
        
        // 将存有user的map存入redis  key为user
        jedis.hmset("user", map);
        // 测试取出id3的user的信息
        String u = jedis.hget("user", id3);
        // 取出key为user的所有的用户的map,即刚刚存入的map
        Map<String, String> map1 = jedis.hgetAll("user");
        
//      for (Entry<String, String> entry : map1.entrySet()) {
//           System.out.println("key= " + entry.getKey() + " and value= " + entry.getValue());
//      }
                
        // 到此可以查询所有的user也可以根据user的id查询查询某个用户
        // 但是redis不能像关系型数据库似的进行条件查询,
        // select * from user where age between 20 and 25 and sex m; 查询年龄在20到25岁之间的男性 
        // redis虽然不像关系型数据库似的对条件查询那样灵活,但也可以利用 hashmap、set sortedset等方式进行简单的条件查询
        // 必须把提前要查询的条件设置好
        // 例如上面user例子 ,可以把年龄和id放入 sortedset中,把性别放入分为w和m放入到set中
        
        // key = user_age 为sortedset的key值,年龄 为 score; id为member
        String user_age = "user_age";
        jedis.zadd(user_age, 22, id1);
        jedis.zadd(user_age, 23, id2);
        jedis.zadd(user_age, 26, id3);
        jedis.zadd(user_age, 25, id4);
        // 查询20到25之间的id的值
        Set<String> ageSet = jedis.zrangeByScore(user_age, 20, 25);
        // 取出年龄在20到25之间的所有的user
        List<String>  hmget = jedis.hmget("user",  (String[])ageSet.toArray(new String[ageSet.size()]));
        for (String string : hmget) {
            User user = (User) JsonUtil.parseObject(string, User.class);
            System.out.println("年龄20到25之间user名字:"+user.getName());
        }
        
        // user_sex_m 为男性set的key值的值,id为member
        String user_sex_m = "user_sex_m";
        jedis.sadd(user_sex_m, id1, id2);
        
        // user_sex_w 为女性set的key值的值,id为member
        String user_sex_w = "user_sex_w";
        jedis.sadd(user_sex_w, id3);
        jedis.sadd(user_sex_w, id4);
        
        // 取所有的女性的id
        Set<String> user_sex_wStr = jedis.smembers(user_sex_w);
        
        // 取所有的女性的user
        List<String>  hh = jedis.hmget("user",  (String[])user_sex_wStr.toArray(new String[user_sex_wStr.size()]));
        for (String string : hh) {
            User user = (User) JsonUtil.parseObject(string, User.class);
            System.out.println("女性的名字:"+user.getName());
        }       
    }   

}

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

推荐阅读更多精彩内容

  • 转载地址:http://gnucto.blog.51cto.com/3391516/998509 Redis与Me...
    Ddaidai阅读 21,446评论 0 82
  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 31,602评论 18 399
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,637评论 18 139
  • 这一生要做个有钱人 这是最近刚听的一场分享会的主题,真的好喜欢这句话。马上就在自己的简书新建了个文集叫“有钱人”,...
    燕平说阅读 641评论 2 6
  • 逯沁语阅读 368评论 0 0