Redis支持五种数据类型:string(字符串),hash(哈希),list(列表),set(集合)及zset(sorted set:有序集合)。

String(字符串)(注意:一个键最大能存储512MB。)

  1. redis 127.0.0.1:6379> SET name "w3cschool.cc"
  2. OK
  3. redis 127.0.0.1:6379> GET name
  4. "w3cschool.cc"

Hash(哈希)

Redis hash 是一个键值对集合。

Redis hash是一个string类型的field和value的映射表,hash特别适合用于存储对象。

  1. redis 127.0.0.1:6379> HMSET user:1 username w3cschool.cc password w3cschool.cc points 200
  2. OK
  3. redis 127.0.0.1:6379> HGETALL user:1
  4. 1) "username"
  5. 2) "w3cschool.cc"
  6. 3) "password"
  7. 4) "w3cschool.cc"
  8. 5) "points"
  9. 6) "200"
  10. redis 127.0.0.1:6379>   

实例中我们使用了 Redis HMSET, HEGTALL 命令,user:1 为键值。

每个 hash 可以存储 232 - 1 键值对(40多亿)。

 

List(列表)

Redis 列表是简单的字符串列表,按照插入顺序排序。你可以添加一个元素导列表的头部(左边)或者尾部(右边)。

  1. redis 127.0.0.1:6379> lpush w3cschool.cc redis
  2. (integer) 1
  3. redis 127.0.0.1:6379> lpush w3cschool.cc mongodb
  4. (integer) 2
  5. redis 127.0.0.1:6379> lpush w3cschool.cc rabitmq
  6. (integer) 3
  7. redis 127.0.0.1:6379> lrange w3cschool.cc 0 10
  8. 1) "rabitmq"
  9. 2) "mongodb"
  10. 3) "redis"
  11. redis 127.0.0.1:6379>

Set(集合)

Redis的Set是string类型的无序集合。

集合是通过哈希表实现的,所以添加,删除,查找的复杂度都是O(1)。

sadd 命令

添加一个string元素到,key对应的set集合中,成功返回1,如果元素以及在集合中返回0,key对应的set不存在返回错误。

  1. redis 127.0.0.1:6379> sadd w3cschool.cc redis
  2. (integer) 1
  3. redis 127.0.0.1:6379> sadd w3cschool.cc mongodb
  4. (integer) 1
  5. redis 127.0.0.1:6379> sadd w3cschool.cc rabitmq
  6. (integer) 1
  7. redis 127.0.0.1:6379> sadd w3cschool.cc rabitmq
  8. (integer) 0
  9. redis 127.0.0.1:6379> smembers w3cschool.cc
  10.  
  11. 1) "rabitmq"
  12. 2) "mongodb"
  13. 3) "redis"

注意:以上实例中 rabitmq 添加了两次,但根据集合内元素的唯一性,第二次插入的元素将被忽略。

 

zset(sorted set:有序集合)

Redis zset 和 set 一样也是string类型元素的集合,且不允许重复的成员。

不同的是每个元素都会关联一个double类型的分数。redis正是通过分数来为集合中的成员进行从小到大的排序。

zset的成员是唯一的,但分数(score)却可以重复。

  1. redis 127.0.0.1:6379> zadd w3cschool.cc 0 redis
  2. (integer) 1
  3. redis 127.0.0.1:6379> zadd w3cschool.cc 0 mongodb
  4. (integer) 1
  5. redis 127.0.0.1:6379> zadd w3cschool.cc 0 rabitmq
  6. (integer) 1
  7. redis 127.0.0.1:6379> zadd w3cschool.cc 0 rabitmq
  8. (integer) 0
  9. redis 127.0.0.1:6379> ZRANGEBYSCORE w3cschool.cc 0 1000
  10.  
  11. 1) "redis"
  12. 2) "mongodb"
  13. 3) "rabitmq"

 

Java 使用 Redis

jar包下载地址:http://www.redis.net.cn/tutorial/8811.html

命令可以去官网查看:http://www.redis.net.cn/tutorial/3525.html

连接到 redis 服务

  1. import redis.clients.jedis.Jedis;
  2. public class RedisJava {
  3. public static void main(String[] args) {
  4. //连接本地的 Redis 服务
  5. Jedis jedis = new Jedis("localhost");
  6. System.out.println("Connection to server sucessfully");
  7. //查看服务是否运行
  8. System.out.println("Server is running: "+jedis.ping());
  9. }
  10. }

Redis Java String(字符串) 实例

  1. import redis.clients.jedis.Jedis;
  2. public class RedisStringJava {
  3. public static void main(String[] args) {
  4. //连接本地的 Redis 服务
  5. Jedis jedis = new Jedis("localhost");
  6. System.out.println("Connection to server sucessfully");
  7. //设置 redis 字符串数据
  8. jedis.set("w3ckey", "Redis tutorial");
  9. // 获取存储的数据并输出
  10. System.out.println("Stored string in redis:: "+ jedis.get("w3ckey"));
  11. }
  12. }

Redis Java List(列表) 实例

  1. import redis.clients.jedis.Jedis;
  2. public class RedisListJava {
  3. public static void main(String[] args) {
  4. //连接本地的 Redis 服务
  5. Jedis jedis = new Jedis("localhost");
  6. System.out.println("Connection to server sucessfully");
  7. //存储数据到列表中
  8. jedis.lpush("tutorial-list", "Redis");
  9. jedis.lpush("tutorial-list", "Mongodb");
  10. jedis.lpush("tutorial-list", "Mysql");
  11. // 获取存储的数据并输出
  12. List<String> list = jedis.lrange("tutorial-list", 0 ,5);
  13. for(int i=0; i<list.size(); i++) {
  14. System.out.println("Stored string in redis:: "+list.get(i));
  15. }
  16. }
  17. }

Redis Java Keys 实例

  1. import redis.clients.jedis.Jedis;
  2. public class RedisKeyJava {
  3. public static void main(String[] args) {
  4. //连接本地的 Redis 服务
  5. Jedis jedis = new Jedis("localhost");
  6. System.out.println("Connection to server sucessfully");
  7. // 获取数据并输出
  8. List<String> list = jedis.keys("*");
  9. for(int i=0; i<list.size(); i++) {
  10. System.out.println("List of stored keys:: "+list.get(i));
  11. }
  12. }
  13. }