接口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. Python 2.x和3.x不同点

    1.print和print() 2.yield 出现下面的错误Traceback (most recent call last): File “<pyshell#32>”, line 1, ...

  2. 使用Docx.dll插入图片在Centos 7 上报错:system.DllNotFound:libgdiplus.so

    熬了N天,终于把WORD 文档打开替换.插入图片完好,部署,本机测试没有问题 可是一放到服务器(Centos 7) 就提示下面的错误: 度娘一下: https://www.cnblogs.com/xi ...

  3. iis6.0 建立站点

    公司网站的服务器甚多 其中还包括早期的iis6.0 的网站服务器 由于之前没有接触过 特此记录建立站点过程和注意事项 1.每个站点最好都新建一个用户名 方便管理 这里操作系统是 winXP 现在运行界 ...

  4. logback的configuration

    logback的<configuration>只有三个属性: 1.scan[boolean]:当scan被设置为true时,当配置文件发生改变,将会被重新加载.默认值为true. 2.sc ...

  5. bt5 r3下metasploit连接postgresql数据库

    一.查看PostgreSQL使用的端口,默认为7337 #: netstat -tnpl |grep postgres 二.查看Msf配置,里面有默认的用户名和密码 默认配置文件:/opt/metas ...

  6. 巧用netsh命令实现端口转发(端口映射)不求人

    好处:即时生效,随意修改删除,不影响其他ip映射 记事本保存为bat格式批量添加后,并查看映射: netsh interface portproxy add v4tov4 listenport=701 ...

  7. 怎么旋转PDF文件的方向并保存成功

    http://jingyan.baidu.com/article/59a015e39d7802f79488651e.html PDF格式的文档是非常普遍的一种阅读电子书格式,基本上非常好用了,不过有时 ...

  8. hihoCoder hiho一下 第十二周 #1055 : 刷油漆 (树上DP)

    思路: 只能刷部分节点数m,总节点数n.如果m>=n那么就可以全刷了,那就不用任何算法了.如果m<n那么就要有取舍了.用DP思路,记录下每个节点如果获得到1~m个选择所能获得的最大权值.这 ...

  9. hive 报错FAILED: Error in metadata: java.lang.RuntimeException: Unable to instantiate org.apache.hadoop.hive.metastore.HiveMetaStoreClient FAILED: Execu

    使用hive一段时间以后,今天在使用的时候突然报错,如下: hive> show databases;FAILED: Error in metadata: java.lang.RuntimeEx ...

  10. 如何查看CRM WebUI,C4C和Hybris里的页面技术信息

    CRM 在WebClient UI页面上按F2,就能看到页面的技术信息, 可以找到当前页面是哪一个BSP component实现的: C4C 在浏览器url里添加debugMode=true,然后按住 ...