接口IRedisDaoHash:

package com.net.test.redis.base.dao;

import com.net.test.redis.base.entity.UserPsg;

/**
* @author ***
* @Time:2017年8月9日 下午1:43:23
* @version 1.0
* @description redis的哈希操作
*/
public interface IRedisDaoHash { public void set(String key,UserPsg psg);
public void get(String key,String hKye);
public void setClazz(String key,Object cls); public void getKeys(String key);
public void getValues(String key); public void length(String key);
public void exists(String key,String hashKey);
public void delete(String key, Object...hashKeys); }

实现类:

package com.net.test.redis.base.dao.imp;

import java.util.Iterator;
import java.util.List;
import java.util.Map;
import java.util.Set; import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.redis.core.HashOperations;
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.stereotype.Component; import com.net.test.redis.base.dao.IRedisDaoHash;
import com.net.test.redis.base.entity.UserPsg;
import com.net.test.redis.base.until.ClassInfo; /**
* @author ***
* @Time:2017年8月9日 下午2:04:54
* @version 1.0
* @description
*/
@Component
public class RedisDaoHashImp implements IRedisDaoHash { @Autowired
private RedisTemplate<String, String> redis; /**
* @description 设置hash的键、属性和值。此方法写的比较死,无法做到通用
* @param key
* @param psg
*/
@Override
public void set(String key, UserPsg psg)
{
HashOperations<String, String, Object> oper = redis.opsForHash();
oper.put(key, "address", psg.getAddress());
oper.put(key, "phone", psg.getPhone());
} /**
* @description 此方法利用反射技术,做到了任何pojo都可以通用此方法(目前不支持内置对象,好像redis也不支持内置对象)
* @param key
* @param object
*/
@Override
public void setClazz(String key, Object object)
{
HashOperations<String, String, Object> oper = redis.opsForHash();
ClassInfo info = new ClassInfo();
Map<String, String> map;
try {
map = info.getFieldsByClass(object);
Set<String> set = map.keySet();
for(Iterator<String> iter = set.iterator();iter.hasNext();)
{
String hKey = iter.next();
String hValue = map.get(hKey);
oper.put(key, hKey, hValue);
}
} catch (Exception e) {
e.printStackTrace();
}
} /**
* @description 根据hash的键(key)和属性(hKye)查询出对应的属性
* @param key
* @param hKye
*/
@Override
public void get( String key, String hKye)
{
HashOperations<String, String, Object> oper = redis.opsForHash();
String value = (String) oper.get(key, hKye);
System.out.println("hash 的get方法获取值 :" + value);
} /**
* @description 获取键(key)下面的所有属性
* @param key
*/
@Override
public void getKeys(String key) {
HashOperations<String, String, Object> oper = redis.opsForHash();
Set<String> set = oper.keys(key); System.out.println( key + "下面的键有:");
for(Iterator<String> iter = set.iterator();iter.hasNext();)
{
String _key = iter.next();
System.out.println(_key);
}
} /**
* @description 获取键(key)下面的所有值
* @param key
*/
@Override
public void getValues(String key)
{
HashOperations<String, String, Object> oper = redis.opsForHash();
List<Object> list = oper.values(key); System.out.println( key + "下面的键有:");
for(Iterator<Object> iter = list.iterator();iter.hasNext();)
{
String _key = iter.next().toString();
System.out.println(_key);
}
} /**
* @description 根据键获取属性个数
* @param key
*/
@Override
public void length(String key) {
HashOperations<String, String, Object> oper = redis.opsForHash();
int size = oper.size(key).intValue();
System.out.println(key + "属性共有 :"+ size);
} /**
* @description 判断键是否存在
* @param key
* @param hashKey
*/
@Override
public void exists(String key,String hashKey) {
HashOperations<String, String, Object> oper = redis.opsForHash();
boolean b = oper.hasKey(key, hashKey);
System.out.println(key + "下面的" +hashKey + "属性:" + b);
} /**
* @description 删除指定的键(key)下面的属性(hashKeys)
* @param key
* @param hashKeys
*/
@Override
public void delete(String key, Object...hashKeys) {
HashOperations<String, String, Object> oper = redis.opsForHash();
oper.delete(key,hashKeys);
} }

反射依赖方法,自己封装的:

package com.net.test.redis.base.until;

import java.lang.reflect.Field;
import java.lang.reflect.Method;
import java.util.HashMap;
import java.util.Map; /**
* @author ****
* @Time:2017年8月9日 下午3:16:37
* @version 1.0
* @description 反射基类
*/ public class ClassInfo { /**
* @description 利用反射,读取pojo属性以及get**方法
* @param object
* @return
* @throws Exception
*/
public Map<String,String> getFieldsByClass(Object object) throws Exception
{
Map<String,String> map = new HashMap<String,String>();
Class<?> clazz = object.getClass();
Field[] fields = clazz.getDeclaredFields();
for(int i = 0; i < fields.length; i++)
{
String key = fields[i].getName();
String Ukey = key.replace(key.substring(0, 1), key.substring(0, 1).toUpperCase());
String value = "get" + Ukey ; Method method = clazz.getDeclaredMethod(value);
Object obj = method.invoke(object); map.put(key, obj.toString());
}
return map;
} }

Redis之Hash类型操作的更多相关文章

  1. Redis - hash类型操作

    hash 类型操作设置操作:hset:    hset key filed value        创建指定key的filed-value名值对 hsetnx:    hsetnx key file ...

  2. redis之Hash类型常用方法总结

    redis之Hash类型常用方法总结 格式: 存--HMGET key field [field ...] 取--HMGET key field [field ...] M:表示能取多个值,many ...

  3. redis的Hash类型以及其操作

    hashes类型 hashes类型及操作Redis hash是一个string类型的field和value的映射表.它的添加.删除操作都是0(1)(平均).hash特别适合用于存储对象.相较于将对象的 ...

  4. 二:redis 的hash类型相关操作

    =====================二种:hash类型================== 介绍:redis -> hash是一个string类型的field和value的映射表 hash ...

  5. python - hash类型操作

    Redis在内存中存储hash类型是以name对应一个字典形式存储的 常用操作 在name对应的hash中获取根据key获取valuehget(name,key) 在name 对应的hash 中设备键 ...

  6. StackExchange.Redis 之 hash 类型示例

    StackExchange.Redis 的组件封装示例网上有很多,自行百度搜索即可. 这里只演示如何使用Hash类型操作数据: // 在 hash 中存入或修改一个值 并设置order_hashkey ...

  7. redis的hash类型

    1.简单描述 hash是一个string类型的field和value的映射表.添加和删除操作都是O(1)(平均)的复杂度.hash类型特别适合用于存储对象.在field的数量在限制的范围内以及valu ...

  8. redis的hash类型!!!!

    Hash类型 redsi的hash是基本类型之一,键值本身又是一对键值结构,是string类型的field和value的映射表,或者说是集合,适合存储对象. Hash的增操作 127.0.0.1:63 ...

  9. python之Redis的字符串类型操作

    redis的数据类型: 字符串型    哈希     列表     集合     有序集合 1.String(字符串类型) set  命令:   设置一个键和值,键存在则只覆盖,返回ok > s ...

随机推荐

  1. JAVA多线程之线程池的使用

    合理利用线程池能够带来三个好处. 第一:降低资源消耗.通过重复利用已创建的线程降低线程创建和销毁造成的消耗. 第二:提高响应速度.当任务到达时,任务可以不需要等到线程创建就能立即执行. 第三:提高线程 ...

  2. 关于js框架 dwz 与 yii的的分页 以及筛选的结合

    此为jicheng1014 原创....地址为http://jicheng1014.cnblogs.com dwz是一个不错的前端框架  但是 注意   所有的后端   都是要自己写的 常见的应用是 ...

  3. 【JavaEE】tomcat部署项目的几种方式 .

    一.静态部署1.直接将web项目文件件拷贝到webapps 目录中     Tomcat的Webapps目录是Tomcat默认的应用目录,当服务器启动时,会加载所有这个目录下的应用.所以可以将JSP程 ...

  4. elasticsearch.yml基本配置说明

    一.基本配置 elasticsearch的config文件夹里面有两个配置文 件:elasticsearch.yml和logging.yml,第一个是es的基本配置文件,第二个是日志配置文件,es也是 ...

  5. Error: connect ECONNREFUSED 127.0.0.1:8080

    Error: connect ECONNREFUSED 127.0.0.1:8080    at Object.exports._errnoException (util.js:1018:11)    ...

  6. $(formName).data(“bootstrapValidator”).getFieldElements('fieldName'); 校验单个字段

    问题也出自于业务系统后台,应该来说也比较常见吧 房产类型分为一抵和二抵,二抵的时候用户必须填写一抵债权金额,一抵的时候则不显示一抵债权金额也不校验,因为我所有的校验都是写在标签上,哪些必填直接写在标签 ...

  7. 使用腾讯IP分享计划网站中的纯JS省市区三级联动

    JS地址:http://ip.qq.com/js/geo.js 实例如下: <!DOCTYPE html> <html> <head> <title>省 ...

  8. zabbix文档3.4-7配置

    zabbix文档3.4-7配置 1 主机和主机组 典型的Zabbix主机是您希望监视的设备(服务器,工作站,交换机等). 创建主机是Zabbix中首个监控任务之一.例如,如果要监视服务器"x ...

  9. SHOW SLAVE STATUS 详解

    MySQL同步功能由3个线程(master上1个,slave上2个)来实现.执行 DE>START SLAVEDE> 语句后,slave就创建一个I/O线程.I/O线程连接到master上 ...

  10. VMware下Centos6.4安装

    VMware(Virtual Machine ware)是一个“虚拟PC”软件公司,提供服务器.桌面虚拟化的解决方案. 小伙伴们网上下载VMware11,一路下一步自己安装吧!!! 打开 VMware ...