使用NoSQL数据库

使用NoSQL数据库

Spring Data还提供了对多种NoSQL数据库的支持,包括MongoDB、Neo4j和Redis。它不仅支持自动化的Repository,还支持基于模板的数据访问和映射注解。

此博客的主要内容是针对这些数据库在Spring中的配置以支持其使用。

一. 启用MongoDB

1.1Java配置方法1

为了有效使用Spring Data MongoDB,我们需要在Spring配置中添加几个必要的bean。首先,我们需要配置MongoClient,以便于访问MongoDB数据库。同时,我们还需要一个MongoTemplate bean,实现基于模板的数据库访问。此外,不是必须,但是强烈推荐启用Spring Data MongoDB的自动化Repository生成功能。

配置代码示例:

@Configuration
@EnableMongoRepositories(basePackages = "orders.db") //启用MongoDB的Repository功能
public class MongoConfig{
    @Bean
    public MongoFactoryBean mongo(){
        MongoFactoryBean mongo = new MongoFactoryBean();
        mongo.setHost("localhost");
        return mongo;
    }

    @Bean
    public MongoOperations mongoTemplate(Mongo mongo){
        return new MongoTemplate(mongo, "OrderDB");
    }
}

1.2 Java配置方法2

除了直接声明这些bean,我们还可以让配置类拓展AbstractMongoConfiguration并重载getDatabaseName()和mongo()方法。

配置代码示例(JavaConfig):

package orders.config;

import org.springframework.context.annotation.Configuration;
import org.springframework.data.mongodb.config.AbstractMongoConfiguration;
import org.springframework.data.mongodb.repository.config.EnableMongoRepositories;

import com.mongodb.Mongo;
import com.mongodb.MongoClient;

@Configuration
@EnableMongoRepositories(basePackages = "orders.db") //启用MongoDB的Repository功能
public class MongoConfig extends AbstractMongoConfiguration {
    //只当数据库名称
    @Override
    protected String getDatabaseName() {
        return "OrdersDB";
    }

    //创建MongoDB客户端
    @Override
    public Mongo mongo() throws Exception {
        return new MongoClient();
    }
}

如果MongoDB服务器运行在其它的机器上,那么可以在创建MongoClient的时候进行指定:

public Mongo mongo() throws Exception {
    return new MongoClient("mongodbserver");
}

如果MongoDB服务器监听的端口不是默认的27017,在创建MongoClient的时候,还需要制定端口:

public Mongo mongo() throws Exception {
    return new MongoClient("mongodbserver", 37017);
}

如果MongoDB服务器运行在生产配置上,我认为你可能还启用了认证功能。在这种情况下,为了访问数据库,我们还需要提供应用的凭证。

@Autowired
private Environment dev;

public Mongo mongo() throws Exception {
    MongoCredential credential = MongoCredential .createMongoCRCredential(
        env.getProperty("mongo.username"), "OrdersDB", env.getProperty("mongo.password").toCharArray());

    return new MongoClient(new ServerAddress("localhost", 37017), Arrays.asList(credential));
}

1.3 xml配置

核心代码:

<mongo:repositories base-package="order.db" />
<mongo:mongo />
<bean id="mongoTemplate" class="org.springframework.data.mongodb.core.MongoTemplate">
    <constructor-arg ref="mongo" />
    <constructor-arg value="OrdersDB" />
</bean>

二. Neo4j的配置

配置Spring Data Neo4j的关键在于声明GraphDatabaseService bean和启用Neo4j Repository自动生成功能。

2.1 Java配置示例

package orders.config;

import org.neo4j.graphdb.GraphDatabaseService;
import org.neo4j.graphdb.factory.GraphDatabaseFactory;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.data.neo4j.config.EnableNeo4jRepositories;
import org.springframework.data.neo4j.config.Neo4jConfiguration;

@Configuration
@EnableNeo4jRepositories(basePackages = "orders.db") //启用Repository自动生成功能
public class Neo4jConfig extends Neo4jConfiguration {

    //设置模型的基础包
    public Neo4jConfig() {
        setBasePackage("orders");
    }

    //配置嵌入式数据库
    @Bean(destroyMethod="shutdown")
    public GraphDatabaseService graphDatabaseService() {    
        return new GraphDatabaseFactory()
                .newEmbeddedDatabase("/tmp/graphdb");
    }
}

配置远程需要认证的数据库

@Bean(destroyMethod="shutdown")
public GraphDatabaseService graphDatabaseService(Enviroment env) {
    return new SpringRestGraphDatabase("http://graphdbserver:7474/db/data/", env.getProperty("db.username"), env.getProperty("db.password"));
}

2.2 xml配置

xml配置文件核心代码:

<neo4j:config storeDirectory="tmp/graphdb" base-package="orders" />

<neo4j:repositories base-package="orders.db" />

如果要配置远程Spring Data Neo4j访问远程的Neo4j服务器:

<neo4j:config base-backage="orders" graphDatabaseService="graphDatabaseService" />

<bean id="graphDatabaseService" class="org.springframework.data.neo4j.rest.SpringRestGraphDatabase">
    <constructor-arg value="http://graphdbserver:7474/db/data/" />
    <constructor-arg value="db.username" />
    <constructor-arg value="db.password" />
</bean>

三. 连接到Redis

配置代码:

package cart;

import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.data.redis.connection.RedisConnectionFactory;
import org.springframework.data.redis.connection.jedis.JedisConnectionFactory;
import org.springframework.data.redis.core.RedisTemplate;

@Configuration
public class RedisConfig {

    @Bean
    public RedisConnectionFactory redisCF() {
        return new JedisConnectionFactory();
    }

    @Bean
    public RedisTemplate<String, Product> redisTemplate(RedisConnectionFactory cf) {
        RedisTemplate<String, Product> redis = new RedisTemplate<String, Product>();
        redis.setConnectionFactory(cf);
        return redis;
    }

}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值