使用NoSQL数据库

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/qq_22314145/article/details/81712654

使用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;
    }

}

猜你喜欢

转载自blog.csdn.net/qq_22314145/article/details/81712654