- 資訊首頁(yè) > 開(kāi)發(fā)技術(shù) >
- 教你怎么用Java操作Redis
首先讓我們創(chuàng )建一個(gè)普通的Maven工程,添加相應的依賴(lài)
<dependencies> <dependency> <groupId>redis.clients</groupId> <artifactId>jedis</artifactId> <version>3.3.0</version> </dependency> <dependency> <groupId>com.alibaba</groupId> <artifactId>fastjson</artifactId> <version>1.2.72</version> </dependency> </dependencies>
然后我們就可以是使用了
測試連接(這里我用的是本地的reids服務(wù))
//定義主機號、端口號 HostAndPort hostAndPort = new HostAndPort("127.0.0.1",6379); //連接redis服務(wù) Jedis jedis=new Jedis(hostAndPort); //ping一下 System.out.println("服務(wù)正在運行: "+jedis.ping()) //關(guān)閉 jedis.close();
控制臺輸出PONG代表連接成功
接下來(lái)讓我們看看Redis的五大數據類(lèi)型的基礎操作
System.out.println("存入一個(gè)數據:"+jedis.set("age", "20")); System.out.println("存入多個(gè)數據:"+jedis.mset("name","zhangsan","sex","男")); System.out.println("獲取一個(gè)數據:"+jedis.get("age")); System.out.println("獲取多個(gè)數據:"+jedis.mget("name","sex")); System.out.println("將指定的字符串拼接在指定數據之后:"+jedis.append("name",",你好")); System.out.println("查看某個(gè)數據的長(cháng)度:"+jedis.strlen("name")); System.out.println("修改某個(gè)數據的值并返回修改之前的值:"+jedis.getSet("name", "lisi")); System.out.println("判斷某個(gè)數據是否存在:"+jedis.exists("name")); System.out.println("為某個(gè)數據設置失效時(shí)間(單位/s):"+jedis.expire("name", 20)); System.out.println("查看某個(gè)數據的剩余生存時(shí)間(s):"+jedis.ttl("name")); System.out.println("刪除一個(gè)或多個(gè)數據:"+jedis.del("name","sex"));
查看打印結果
System.out.println("向集合添加一個(gè)或多個(gè)元素:"+jedis.sadd("key1", "v1","v2","v3")); System.out.println("獲取集合的元素個(gè)數:"+jedis.scard("key1")); System.out.println("返回集合中的所有元素:"+jedis.smembers("key1")); System.out.println("判斷指定元素是否存在集合中:"+jedis.sismember("key1", "v1")); System.out.println("移除集合中指定的元素:"+jedis.srem("key1", "v3")); //這里我們在創(chuàng )建一個(gè)集合 System.out.println("向集合添加一個(gè)或多個(gè)元素:"+jedis.sadd("key2", "v2","v3","v4")); System.out.println("返回集合key1與key2的差集:"+jedis.sdiff("key1","key2")); System.out.println("返回集合key1與key2的交集:"+jedis.sinter("key1","key2")); System.out.println("返回集合key1與key2的并集:"+jedis.sunion("key1","key2"));
查看結果
Map map=new HashMap<>(); map.put("name", "zhangsan"); map.put("age", "20"); map.put("sex", "男"); System.out.println("創(chuàng )建一個(gè)哈希表存儲一個(gè)用戶(hù)對象:"+jedis.hmset("user",map)); System.out.println("獲取哈希表中用戶(hù)的name:"+jedis.hget("user", "name")); System.out.println("查看哈希表中,指定的字段是否存在:"+jedis.hexists("user", "name")); System.out.println("獲取哈希表中字段的數量:"+jedis.hlen("user")); System.out.println("獲取哈希表中所有字段:"+jedis.hkeys("user")); System.out.println("獲取哈希表中所有字段的值:"+jedis.hvals("user")); System.out.println("獲取在哈希表中的所有字段和值:"+jedis.hgetAll("user")); System.out.println("刪除一個(gè)或多個(gè)哈希表字段:"+jedis.hdel("user","name","age","sex"));
查看結果
System.out.println("將一個(gè)值插入到列表頭部(可以多個(gè)值):"+jedis.lpush("city","北京","上海")); System.out.println("將一個(gè)值插入到列表尾部(可以多個(gè)值):"+jedis.rpush("city","濟南","南京")); System.out.println("獲取列表指定范圍內的元素:"+jedis.lrange("city", 0, -1)); System.out.println("獲取列表長(cháng)度:"+jedis.llen("city")); System.out.println("移出列表的第一個(gè)元素,并輸出值:"+jedis.lpop("city")); System.out.println("移除列表的最后一個(gè)元素,并輸出值:"+jedis.rpop("city")); System.out.println("修改列表中指定索引位置元素的值:"+jedis.lset("city", 0, "西藏")); System.out.println("讓列表只保留指定區間內的元素,不在指定區間之內的元素都將被刪除:"+jedis.ltrim("city", 1, 2));
查看結果
Map<String,Double> scoreMembers=new HashMap<>(); scoreMembers.put("member1", 1D); scoreMembers.put("member2", 2D); scoreMembers.put("member3", 3D); System.out.println("向有序集合添加一個(gè)或多個(gè)元素,或者更新已存在元素的分數:"+jedis.zadd("member", scoreMembers)); System.out.println("獲取有序集合的元素個(gè)數:"+jedis.zcard("member")); System.out.println("計算在有序集合中指定區間([socre1,socre2])分數的成員數:"+jedis.zcount("member", 0D, 3D)); System.out.println("通過(guò)索引區間返回有序集合指定區間內的元素,從低到高:"+jedis.zrange("member", 0,-1)); System.out.println("返回索引區間返回有序集合指定區間內的元素,從高到低:"+jedis.zrevrange("member", 0,-1)); System.out.println("返回有序集中指定元素的分數值:"+jedis.zscore("member", "member1")); System.out.println("移除有序集合中的一個(gè)或多個(gè)元素:"+jedis.zrem("member", "member1","member2")); System.out.println("返回有序集合中指定元素的索引:"+jedis.zrank("member", "member3"));
查看結果
最后我們簡(jiǎn)單看看如何操作數據庫
System.out.println("清空當前數據庫:"+jedis.flushDB()); System.out.println("清空所有數據庫:"+jedis.flushAll()); System.out.println("查看當前數據庫存儲數據的多少:"+jedis.dbSize()); Set<String> keys = jedis.keys("*"); System.out.println("查看當前數據庫存儲所有鍵值:"+keys); System.out.println("選擇某個(gè)數據庫:"+jedis.select(0));
查看結果
其實(shí)Redis還有三種特殊存儲類(lèi)型
主要用于存儲地理位置信息,并對存儲的信息進(jìn)行操作,基于Sorts Set有序集合
是用來(lái)做基數統計的
通過(guò)操作二進(jìn)制(0,1)來(lái)記錄只有兩種狀態(tài)的信息
這里老哥就不測試了,這三種類(lèi)型的使用在項目業(yè)務(wù)中也很常見(jiàn),想了解的小伙伴可以去Redis官網(wǎng)看一下:
最后總結一下
其實(shí)這些api方法的使用基本都是根據redis的命令封裝的,也就是說(shuō)什么樣的redis命令基本就對應一個(gè)什么樣的jedis的一個(gè)方法,很簡(jiǎn)單的!
所以說(shuō)學(xué)會(huì )掌握Redis的命令是多么的重要啊,要學(xué)會(huì )一通百通!
到此這篇關(guān)于教你怎么用Java操作Redis的文章就介紹到這了,更多相關(guān)Java操作Redis內容請搜索腳本之家以前的文章或繼續瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng )、來(lái)自互聯(lián)網(wǎng)轉載和分享為主,文章觀(guān)點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權請聯(lián)系QQ:712375056 進(jìn)行舉報,并提供相關(guān)證據,一經(jīng)查實(shí),將立刻刪除涉嫌侵權內容。
Copyright ? 2009-2021 56dr.com. All Rights Reserved. 特網(wǎng)科技 特網(wǎng)云 版權所有 珠海市特網(wǎng)科技有限公司 粵ICP備16109289號
域名注冊服務(wù)機構:阿里云計算有限公司(萬(wàn)網(wǎng)) 域名服務(wù)機構:煙臺帝思普網(wǎng)絡(luò )科技有限公司(DNSPod) CDN服務(wù):阿里云計算有限公司 中國互聯(lián)網(wǎng)舉報中心 增值電信業(yè)務(wù)經(jīng)營(yíng)許可證B2
建議您使用Chrome、Firefox、Edge、IE10及以上版本和360等主流瀏覽器瀏覽本網(wǎng)站