Redis学习笔记(3)-Hash
package cn.com; import java.util.HashMap;
import java.util.List;
import java.util.Map;
import java.util.Set; import ch.qos.logback.core.net.SyslogOutputStream;
import redis.clients.jedis.Jedis; public class Redis_Hash { public static Jedis redis = new Jedis("localhost", 6379);// 连接redis public static void main(String [] args){
hdel();
} /**
* HDEL key field [field ...]
* 删除哈希表 key 中的一个或多个指定域,不存在的域将被忽略。
* */
public static void hdel(){
redis.flushDB();//清除数据 redis.hset("user", "id", "1");
redis.hset("user", "name", "liliang");
redis.hset("user", "age", "18");
System.out.println("==========删除key前数据===========");
List<String> users=redis.hvals("user");
for(String u:users){
System.out.println(u);
} System.out.println("==========删除key后数据===========");
redis.hdel("user","age");//删除key;可以是多个key
List<String> users2=redis.hvals("user");
for(String u:users2){
System.out.println(u);
}
}
/**
* 返回哈希表 key 中所有域的值。
* 返回值:key 不存在返回空
* */
public static void hvals(){
redis.flushDB();//清除数据
redis.hset("user", "id", "1");
redis.hset("user", "name", "liliang");
redis.hset("user", "age", "18");
List<String> users=redis.hvals("user");
for(String u:users){
System.out.println(u);
}
} /**将哈希表 key 中的域 field 的值设置为 value ,当且仅当域 field 不存在。
*若域 field 已经存在,该操作无效。
*如果 key 不存在,一个新哈希表被创建并执行 HSETNX 命令
**/
public static void hsetnx(){
redis.flushDB();//清除数据
redis.hsetnx("user","age", "18");
String age1=redis.hget("user", "age");
System.out.println("age1:"+age1); //key=user;field=age ;存在在这是则无效
redis.hsetnx("user","age", "19");
String age2=redis.hget("user", "age");
System.out.println("age2:"+age2);
}
/**
*为哈希表 key 中的域 field 的值加上增量 increment 。
*增量也可以为负数,相当于对给定域进行减法操作。
*如果 key 不存在,一个新的哈希表被创建并执行 HINCRBY 命令。
*如果域 field 不存在,那么在执行命令前,域的值被初始化为 0 。
*对一个储存字符串值的域 field 执行 HINCRBY 命令将造成一个错误。
*本操作的值被限制在 64 位(bit)有符号数字表示之内。
* */
public static void hincrby(){
redis.flushDB();//清除数据 //field 不存在初始化field 为0
redis.hincrBy("user", "age", 18);
String age1=redis.hget("user", "age");
System.out.println("age1:"+age1); //对age field 进行crby 1操作
redis.hincrBy("user", "age", 1);
String age2=redis.hget("user", "age");
System.out.println("age1:"+age2);
} /**
* 方法与hincrBy 用户法一样;
* 此方法是操作Float 类型数据
*
* */
public static void hincrByFloat(){
redis.flushDB();//清除数据 //field 不存在初始化field 为0
redis.hincrByFloat("user", "age", 18);
String age1=redis.hget("user", "age");
System.out.println("age1:"+age1); //对age field 进行crby 1操作
redis.hincrByFloat("user", "age", 1.5);
String age2=redis.hget("user", "age");
System.out.println("age1:"+age2);
} /**
* hset 将哈希表 key 中的域 field 的值设为 value 。
* hget 返回哈希表 key 中给定域 field 的值。
* hgetAll 返回哈希表 key 中,所有的域和值。
*
* */
public static void hset_hget_hgetAll(){
redis.flushDB();//清除数据
redis.hset("user", "id", "1");
redis.hset("user", "name", "liliang");
redis.hset("user", "age", "18"); System.out.println("==========hget============");
System.out.println(redis.hget("user", "id"));
System.out.println(redis.hget("user", "name"));
System.out.println(redis.hget("user", "age")); System.out.println("=========hgetAll===========");
Map<String,String> map=redis.hgetAll("user");
System.out.println("id:"+map.get("id"));
System.out.println("name:"+map.get("name"));
System.out.println("age:"+map.get("age"));
} /**
* HMSET key field value [field value ...]
* 同时将多个 field-value (域-值)对设置到哈希表 key 中。
* 此命令会覆盖哈希表中已存在的域。
* 如果 key 不存在,一个空哈希表被创建并执行 HMSET 操作。
* */
public static void hmset_hmget(){
redis.flushDB();//清除数据
Map<String,String> map=new HashMap<String,String>();
map.put("id","1");
map.put("name","liliang");
map.put("age","18");
redis.hmset("user", map); System.out.println("======HMGET==========");
List<String> list=redis.hmget("user","id","name","age");
for(String s:list){
System.out.println("s:"+s);
}
} /**
* HLEN key
* 返回哈希表 key 中域的数量。
* */
public static void hlen(){
redis.flushDB();//清除数据
Map<String,String> map=new HashMap<String,String>();
map.put("id","1");
map.put("name","liliang");
map.put("age","18");
redis.hmset("user", map); Long length=redis.hlen("user");
System.out.println("length:"+length);
} /**
* HKEYS key
*返回哈希表 key 中的所有域。
* */
public static void hkeys(){
redis.flushDB();//清除数据
Map<String,String> map=new HashMap<String,String>();
map.put("id","1");
map.put("name","liliang");
map.put("age","18");
redis.hmset("user", map); Set<String> set=redis.hkeys("user");
for(String s:set){
System.out.println("s:"+s);
}
}
}
Redis学习笔记(3)-Hash的更多相关文章
- Redis学习笔记(二)Redis支持的5种数据类型的总结之String和Hash
引言 在Redis学习笔记(一)中我们已经会安装并且简单使用Redis了,接下来我们一起来学习下Redis支持的5大数据类型. 简介 Redis是REmote DIctionary Server(远程 ...
- redis 学习笔记(6)-cluster集群搭建
上次写redis的学习笔记还是2014年,一转眼已经快2年过去了,在段时间里,redis最大的变化之一就是cluster功能的正式发布,以前要搞redis集群,得借助一致性hash来自己搞shardi ...
- Redis学习笔记4-Redis配置详解
在Redis中直接启动redis-server服务时, 采用的是默认的配置文件.采用redis-server xxx.conf 这样的方式可以按照指定的配置文件来运行Redis服务.按照本Redi ...
- Redis学习笔记(二)-key相关命令【转载】
转自 Redis学习笔记(二)-key相关命令 - 点解 - 博客园http://www.cnblogs.com/leny/p/5638764.html Redis支持的各种数据类型包括string, ...
- Redis学习笔记(三)Redis支持的5种数据类型的总结
继续Redis学习笔记(二)来说说剩余的三种数据类型. 三.列表类型(List) 1.介绍 列表类型可以存储一个有序的字符串列表,常用的操作是向列表两端添加元素,或者获得列表的一段片段.列表类型内部是 ...
- Redis 学习笔记4: Redis 3.2.1 集群搭建
在CenOS 6.7 linux环境下搭建Redis 集群环境 1.下载最新的Redis版本 本人下载的Redis版本是3.2.1版本,下载之后,解压,编译(make): 具体操作可以参考我的博文:R ...
- Redis学习笔记(1)——Redis简介
一.Redis是什么? Remote Dictionary Server(Redis) 是一个开源的使用ANSI C语言编写.遵守BSD协议.支持网络.可基于内存亦可持久化的日志型.Key-Value ...
- redis 学习笔记-cluster集群搭建
一.下载最新版redis 编译 目前最新版是3.0.7,下载地址:http://www.redis.io/download 编译很简单,一个make命令即可,不清楚的同学,可参考我之前的笔记: red ...
- Redis学习笔记(二) Redis 数据类型
Redis 支持五种数据类型:string(字符串).list(列表).hash(哈希).set(集合)和 zset(有序集合),接下来我们讲解分别讲解一下这五种类型的的使用. String(字符串) ...
随机推荐
- Excel 相对引用与绝对引用
相对引用与绝对引用 相对引用与绝对引用的区别在于,当将公式复制到其它单元格时,公式中单元格或单元格区域的地址是否有变化. 相对引用在复制公式时地址跟着发生变化,而绝对引用不会发生变化!绝对引用的方 ...
- 4.EasyUI学习总结(四)——EasyUI组件使用 (通过用户登录来演示dialog、ajax的使用,serialize方法的使用,前后台怎样交互等)
一.EasyUI组件的简单介绍 详细可看api: http://www.jeasyuicn.com/api/docTtml/index.htm easyUI提供了很多组件让我们使用,如下图所示: 很多 ...
- yii框架中验证器声明一组内置验证器可以使用短名称引用
1.内置验证器的短名称分别有: boolean: yii\validators\BooleanValidator captcha: yii\captcha\CaptchaValidator compa ...
- nodeJS搭建本地服务器
准备工作: 安装Node JS: 1:安装全局express:在express4.x版本中,安装时语句变为了这样: npm install -g express-generator 2:创建项目: 选 ...
- 【Java EE 学习 48】【Hibernate学习第五天】【抓取策略】【二级缓存】【HQL】
一.抓取策略. 1.hibernate中提供了三种抓取策略. (1)连接抓取(Join Fetch):这种抓取方式是默认的抓取方式.使用这种抓取方式hibernate会在select中内连接的方式获取 ...
- [.NET]二维码生成
又好一段时间没有写写东西了,继续回归原来的模式,多做记录,最近要实现个unity的二维码方面的功能,首先就要解决生成二维码的问题,这个倒是有这方面的组件,然后我通过强大的反编译工具Reflector( ...
- [参考]wget下载整站
wget -m -e robots=off -U "Mozilla/5.0 (Windows; U; Windows NT 5.1; zh-CN; rv:1.9.1.6) Gecko/200 ...
- 浅析python 中__name__ = '__main__' 的作用
引用http://www.jb51.net/article/51892.htm 很多新手刚开始学习python的时候经常会看到python 中__name__ = \'__main__\' 这样的代码 ...
- UITableView在设置contentOffset的同时也reload,造成tableView的contentOffset偏差
最近在写一个聊天的框架,遇到一个奇葩的问题,就是发送聊天记录的时候(需要tableView上移,显示出最新的记录),增加一条记录无疑需要reload一下(大家都明白的),这是就会出现头疼的问题,页面显 ...
- 微信开发笔记:公众号获取access_token
微信开发中,access_token的获取是一种非常常见的功能,通过公众号的appid和appsecret来向微信公众平台请求一个临时通行凭证:access_token.公众平台上的绝大部分操作都会需 ...