Redis是一种NOSQL数据库,Key-Value形式对数据进行存储,其中数据可以以内存形式存在,也可以持久化到文件系统。Spring data对Redis进行了很好的封装,用起来也是十分的得心应手。Redis 是一个开源(BSD许可)的,内存中的数据结构存储系统,它可以用作数据库、缓存和消息中间件。 它支持多种类型的数据结构,如 字符串(strings), 散列(hashes), 列表(lists), 集合(sets), 有序集合(sorted sets) 与范围查询, bitmaps, hyperloglogs 和 地理空间(geospatial) 索引半径查询。 Redis 内置了 复制(replication),LUA脚本(Lua scripting), LRU驱动事件(LRU eviction),事务(transactions) 和不同级别的 磁盘持久化(persistence), 并通过 Redis哨兵(Sentinel)和自动 分区(Cluster)提供高可用性(high availability)。
1. 系统配置,如果使用Maven进行开发,只需要在pom.xml文件中添加如下配置。
<dependencies> <dependency> <groupId>org.springframework.data</groupId> <artifactId>spring-data-redis</artifactId> <version>1.8.1.RELEASE</version> </dependency> </dependencies>
为了方面起见可以将Spring Data模板配置成 bean 方便在直接使用的地方直接注入。
<bean id="jedisConnFactory" class="org.springframework.data.redis.connection.jedis.JedisConnectionFactory" p:use-pool="true"/> <bean id="redisTemplate" class="org.springframework.data.redis.core.RedisTemplate" p:connection-factory-ref="jedisConnFactory"/>
2. Redis Template针对不同的需求分类封装了如下操作。
opsForValue() - Operations for working with entries having simple values opsForList() - Operations for working with entries having list values opsForSet() - Operations for working with entries having set values opsForZSet() - Operations for working with entries having ZSet (sorted set) values opsForHash() - Operations for working with entries having hash values boundValueOps(K) - Operations for working with simple values bound to a given key boundListOps(K) - Operations for working with list values bound to a given key boundSetOps(K) - Operations for working with set values bound to a given key boundZSet(K) - Operations for working with ZSet (sorted set) values bound to a given key boundHashOps(K) - Operations for working with hash values bound to a given key
3. 典型操作示例
3.1 Redis Template注入,可以直接模板注入,也可以以ops形式注入,如下示例中对两种方式都进行了说明。
public class Example { // inject the actual template @Autowired private RedisTemplate<String, String> template; // inject the template as ListOperations // can also inject as Value, Set, ZSet, and HashOperations @Resource(name="redisTemplate") private ListOperations<String, String> listOps; public void addLink(String userId, URL url) { listOps.leftPush(userId, url.toExternalForm()); // or use template directly template.boundListOps(userId).leftPush(url.toExternalForm()); } }
3.2 Bound系列操作示例,Bound系列操作的优势在于只需要绑定一次,然后可以进行一个系列的操作,代码十分精炼。
BoundListOperations<String, Product> mangoOps = redis.boundListOps("solidmango"); Product popped = mangoOps.rightPop(); mangoOps.rightPush(product1); mangoOps.rightPush(product2); mangoOps.rightPush(product3);
3.3 Serializer配置示例,通常情况下Key和Value都采用不同的方式进行持久化,如下示例中Key使用String进行持久化,Value使用Jackson格式进行持久化。
@Bean public RedisTemplate<String, Cart> redisTemplate(RedisConnectionFactory rcf) { RedisTemplate<String, Cart> redis = new RedisTemplate<String, Cart>(); redis.setConnectionFactory(rcf); redis.setKeySerializer(new StringRedisSerializer()); redis.setValueSerializer( new Jackson2JsonRedisSerializer<Product>(Product.class)); return redis; }
总结
本文对Spring Data操作Redis的配置和开发方式进行了详细的分析说明,配置部分给出了具体的配置方式,代码示例部分分三种情况给出了具体的解决方案,希望对大家有所帮助。
redis中的String在在内存中按照一个name对应一个value来存储 set() #在Redis中设置值,默认不存在则创建,存在则修改 r.set('name','zhangsan') '''参数: set(name, value, ex=None, px=None, nx=False, xx=False) ex,过期时间(秒) px,过期时间(
本文向大家介绍springdata jpa单表操作crud的实例代码详解,包括了springdata jpa单表操作crud的实例代码详解的使用技巧和注意事项,需要的朋友参考一下 1. 项目搭建 使用boot整合,导入springdata jap, mysql 驱动,lombok,web。 1.1 配置 1.2 实体类 1.3 继承JpaRepository接口 2. 批量新增 业务类 测试 3.
问题内容: 我用作spring Web应用程序的数据存储,并用作与之交互的客户端。 我用来存储一个具有多个字段的对象。我可以使用method 一次将所有字段放入,但是我无法一次获取整个对象,而是使用method 来获取每个字段。 我想知道有什么办法可以像支持中的操作那样吗? 问题答案: DefaultRedisMap.entrySet()或BoundHashOperations.entries()
本文向大家介绍node操作mysql数据库实例详解,包括了node操作mysql数据库实例详解的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了node操作mysql数据库的方法。分享给大家供大家参考,具体如下: 1、建立数据库连接:createConnection(Object)方法 该方法接受一个对象作为参数,该对象有四个常用的属性host,user,password,database。
本文向大家介绍Python操作MongoDb数据库流程详解,包括了Python操作MongoDb数据库流程详解的使用技巧和注意事项,需要的朋友参考一下 1.简介 MongoDB是一个基于分布式文件存储的文档数据库,可以说是非关系型(NoSQL,Not Only SQL)数据库中比较像关系型数据库的一个,具有免费、操作简单、面向文档、自动分片、可扩展性强、查询功能强大等特点,对大数据处理支持较好,旨
本文向大家介绍易语言读写数据库操作详解,包括了易语言读写数据库操作详解的使用技巧和注意事项,需要的朋友参考一下 1.实现效果 2.注意事项:我们先用SQLiteStudio建表以及表中字段(SQLiteStudio工具可百度下载);写程序之前对支持库进行配置,勾选Sqlite3数据库支持库而不是Sqlite数据库支持库,因为选用后者会出现一些打不开表之类的问题; 3.源码
本文向大家介绍php操作access数据库的方法详解,包括了php操作access数据库的方法详解的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了php操作access数据库的方法。分享给大家供大家参考,具体如下: 在PHP网站开发中,PHP与Mysql是最好的组合,但是当你想将其他平台的网站移植到PHP平台时,必然遇到移植性的问题,如ASP+ACCESS平台如何移植?首当其冲便是PHP连
本文向大家介绍Python操作mongodb数据库的方法详解,包括了Python操作mongodb数据库的方法详解的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了Python操作mongodb数据库的方法。分享给大家供大家参考,具体如下: 安装pymongo 下载pymongo: https://pypi.python.org/packages/82/26/f45f95841de5164c