NoSQL数据库redis和mongo使用

本文介绍如何在Spring框架中集成Redis与MongoDB数据库,包括依赖引入、参数配置、实体类创建、数据库访问实现及测试方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

依赖引入

对于redis数据库spring提供了基于jedis的数据访问框架Spring Data Redis,可以直接使用以下方式引入:
compile("org.springframework.session:spring-session-data-redis")
对于mongo数据库spring同样提供了访问框架,依然是Spring Data下,引入方式:
compile("org.springframework.session:spring-session-data-mongo")

参数配置

redis参数配置
#Redis配置
#数据库索引(默认为0)可以理解为DB2中等schema
spring.redis.database=0
#服务器地址
spring.redis.host=172.16.1.230
#服务器连接端口
spring.redis.port=6379
#服务器连接密码(默认为空)
spring.redis.password=
#连接池最大连接数(使用负值表示没有限制)
spring.redis.pool.max-active=8
#拦截池最大阻塞等待时间(使用负值表示没有限制)
spring.redis.pool.max-wait=-1
#连接池中最大空闲连接
spring.redis.pool.max-idle=8
#连接池中最小空闲连接
spring.redis.pool.min-idle=0
#连接超时时间(毫秒)
spring.redis.timeout=0
spring.session.store-type=none
mongo参数配置
spring.data.mongodb.uri=mongodb://test:test@172.16.1.230:27017/test

创建要操作的实体

public class Customer{

    private long id;
    private String name;
    private int age;
    ...省略构造方法、setget、toString方法
}

其中redis操作由于需要序列化,实现Serializable接口。

redis数据库访问实现

@Configuration
public class RedisConfig {  
    @Bean
    public RedisTemplate<String, Customer> redisTemplate(RedisConnectionFactory factory) {
        RedisTemplate<String, Customer> template = new RedisTemplate<String, Customer>();
        template.setConnectionFactory(factory);
        template.setKeySerializer(new StringRedisSerializer());
        template.setValueSerializer(new RedisObjectSerializer());
        return template;
    }
}

需要注意的是,这里不需要在注入RedisConnectionFactory,spring会为我自动读取配置文件中的配置,生成bean。

mongo数据库访问实现

相较于redis需要自己实现序列化和序列化,mongodb的访问要简单的多。只需要继承MongoRepository并添加自己需要的方法即可。

public interface CustomerRepository extends MongoRepository<Customer, Long> {

    Customer findByName(String name);

}

其中CustomerRepository提供了新增,查询,删除等基本操作。

测试

redis测试
@Test
    public void test() {
        Customer customer = new Customer(1, "siva", 18);
        redisTemplate.opsForValue().set(String.valueOf(customer.getId()), customer);

        customer = new Customer(2, "zhourui", 24);
        redisTemplate.opsForValue().set(String.valueOf(customer.getId()), customer);

        Assert.assertEquals("siva", redisTemplate.opsForValue().get("1").getName());
    }
mongo测试

    @Before
    public void setUp() {
        customerRepository.deleteAll();
    }

    @Test
    public void test() throws Exception {

        customerRepository.save(new Customer(1L, "siva", 18));
        customerRepository.save(new Customer(2L, "zhour", 24));
        customerRepository.save(new Customer(4L, "xingm", 40));
        Assert.assertEquals(3, customerRepository.findAll().size());
    }

最后吐槽下mongo2.x和mongo3.x差距太大了,连创建用户等函数都不一样了,简直是丧心病狂。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值