Redis之Hash类型操作
接口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类型操作的更多相关文章
- Redis - hash类型操作
hash 类型操作设置操作:hset: hset key filed value 创建指定key的filed-value名值对 hsetnx: hsetnx key file ...
- redis之Hash类型常用方法总结
redis之Hash类型常用方法总结 格式: 存--HMGET key field [field ...] 取--HMGET key field [field ...] M:表示能取多个值,many ...
- redis的Hash类型以及其操作
hashes类型 hashes类型及操作Redis hash是一个string类型的field和value的映射表.它的添加.删除操作都是0(1)(平均).hash特别适合用于存储对象.相较于将对象的 ...
- 二:redis 的hash类型相关操作
=====================二种:hash类型================== 介绍:redis -> hash是一个string类型的field和value的映射表 hash ...
- python - hash类型操作
Redis在内存中存储hash类型是以name对应一个字典形式存储的 常用操作 在name对应的hash中获取根据key获取valuehget(name,key) 在name 对应的hash 中设备键 ...
- StackExchange.Redis 之 hash 类型示例
StackExchange.Redis 的组件封装示例网上有很多,自行百度搜索即可. 这里只演示如何使用Hash类型操作数据: // 在 hash 中存入或修改一个值 并设置order_hashkey ...
- redis的hash类型
1.简单描述 hash是一个string类型的field和value的映射表.添加和删除操作都是O(1)(平均)的复杂度.hash类型特别适合用于存储对象.在field的数量在限制的范围内以及valu ...
- redis的hash类型!!!!
Hash类型 redsi的hash是基本类型之一,键值本身又是一对键值结构,是string类型的field和value的映射表,或者说是集合,适合存储对象. Hash的增操作 127.0.0.1:63 ...
- python之Redis的字符串类型操作
redis的数据类型: 字符串型 哈希 列表 集合 有序集合 1.String(字符串类型) set 命令: 设置一个键和值,键存在则只覆盖,返回ok > s ...
随机推荐
- Kotlin容器
1. 容器 可变/不可变 List<out T> 只读list; MutableList<T>; Set<out T>/MutableSet<T> Ma ...
- C#语言使用习惯
1.使用属性而不是可访问的数据成员 2.用运行时常量(readonly)而不是编译期常量(const) 编译期常量与运行时常量行为的不同之处在于对他们的访问方式不同,编译期常量的值是在目标代码中进行替 ...
- C#数据库(MSSQL)帮助类
/// <summary> /// 数据库帮助类 /// <author>Devin</author> /// </summary> public se ...
- 关于wav文件fft处理后x,y轴坐标数据的问题
1.关于横坐标的频率的最大值是采样频率,那么每个点对应的频率值就很好算了:f(n) = [Fs/(N/2)]*n (Fs是采样频率,常见的是44.1KHz(44100),N是采样点数,k表是第k个点 ...
- OS进程同步与通信
信号量机制 信号量用于互斥 P(S) 临界区 V(S) ----- P(S) 临界区 V(S) 生产者消费者: typedef int semaphore //信号量值设置为1就是互斥量 semaph ...
- 学习笔记:MDN的JavaScript
JavaScript 第一步 什么是JavaScript? 每次当你浏览网页时不只是显示静态信息—— 显示即时更新的内容, 或者交互式的地图,或 2D/3D 图形动画,又或者自动播放视频等,你可以确信 ...
- 构建第一个Spring Boot2.0应用之application.properties和application.yml(八)
本节学习在项目中配置文件配置的方式,一种是通过applicaiton.properties,一种是通过application.yml方式. 一.环境: IDE:IntelliJ IDEA 2017.1 ...
- Hibernate数据库的操作
参考网址: https://www.cnblogs.com/jack1995/p/6952704.html 1.最简单的查询 List<Special> specials = (List& ...
- Spring mvc + maven + tomcat配置问题
在用maven搭建spring mvc时候, 个人遇到过很多的问题, 现在把遇到的问题总结下: 1. 首先点击项目->Run As->Maven clean, 这一步把之前不管有没有ma ...
- 【Android开发笔记】底部菜单栏 FragmentTabHost
公司项目,需求本来是按照谷歌官方指南写的,菜单栏设计成在导航栏下方 结果呢,审评时,BOSS为了和iOS统一,改成了底部菜单栏(标准结局),我只能呵呵呵呵呵呵呵 查了查资料发现实现底部菜单栏用的是Fr ...