Spring Boot 中 MongoDB 的使用

MongoDB 是最早熱門非關係數據庫的之一,使用也比較普遍,一般會用做離線數據分析來使用,放到內網的居多。由於很多公司使用了雲服務,服務器默認都開放了外網地址,導致前一陣子大批 MongoDB 因配置漏洞被攻擊,數據被刪,引起了人們的注意,感興趣的可以看看這篇文章:場屠戮MongoDB的盛宴反思:超33000個數據庫遭遇入侵勒索,同時也說明了很多公司生產中大量使用mongodb。

MongoDB 簡介

MongoDB(來自於英文單詞“Humongous”,中文含義為“龐大”)是可以應用於各種規模的企業、各個行業以及各類應用程序的開源數據庫。基於分佈式文件存儲的數據庫。由C++語言編寫。旨在為 WEB 應用提供可擴展的高性能數據存儲解決方案。MongoDB 是一個高性能,開源,無模式的文檔型數據庫,是當前 NoSql 數據庫中比較熱門的一種。

MongoDB 是一個介於關係數據庫和非關係數據庫之間的產品,是非關係數據庫當中功能最豐富,最像關係數據庫的。他支持的數據結構非常鬆散,是類似 json 的 bjson 格式,因此可以存儲比較複雜的數據類型。MongoDB 最大的特點是他支持的查詢語言非常強大,其語法有點類似於面向對象的查詢語言,幾乎可以實現類似關係數據庫單表查詢的絕大部分功能,而且還支持對數據建立索引。

傳統的關係數據庫一般由數據庫(database)、表(table)、記錄(record)三個層次概念組成,MongoDB 是由數據庫(database)、集合(collection)、文檔對象(document)三個層次組成。MongoDB 對於關係型數據庫裡的表,但是集合中沒有列、行和關係概念,這體現了模式自由的特點。

MongoDB 中的一條記錄就是一個文檔,是一個數據結構,由字段和值對組成。MongoDB 文檔與 JSON 對象類似。字段的值有可能包括其它文檔、數組以及文檔數組。MongoDB 支持 OS X、Linux 及 Windows 等操作系統,並提供了 Python,PHP,Ruby,Java及 C++ 語言的驅動程序,社區中也提供了對 Erlang 及 .NET 等平臺的驅動程序。

MongoDB 的適合對大量或者無固定格式的數據進行存儲,比如:日誌、緩存等。對事物支持較弱,不適用複雜的多文檔(多表)的級聯查詢。文中演示 Mongodb 版本為 3.5。

MongoDB 的增刪改查

Spring Boot 對各種流行的數據源都進行了封裝,當然也包括了 Mongodb,下面給大家介紹如何在 Spring Boot 中使用 Mongodb:

1、pom 包配置

pom 包裡面添加 spring-boot-starter-data-mongodb 包引用

<code><dependencies><dependency>     <groupid>org.springframework.boot/<groupid>    <artifactid>spring-boot-starter-data-mongodb/<artifactid>/<dependency> /<dependencies>/<code>

2、在 application.properties 中添加配置

<code>spring.data.mongodb.uri=mongodb://name:pass@localhost:27017/test/<code>

多個 IP 集群可以採用以下配置:

<code>spring.data.mongodb.uri=mongodb://user:pwd@ip1:port1,ip2:port2/database/<code>

2、創建數據實體

<code>public class User implements Serializable {        private static final long serialVersionUID = -3258839839160856613L;        private Long id;        private String userName;        private String passWord;      //getter、setter省略}/<code>

3、創建實體的增刪改查操作

Repository 層實現了 User 對象的增刪改查

<code>@Componentpublic class UserRepositoryImpl implements UserRepository {    @Autowired    private MongoTemplate mongoTemplate;    /**     * 創建對象     * @param user     */    @Override    public void saveUser(User user) {        mongoTemplate.save(user);    }    /**     * 根據用戶名查詢對象     * @param userName     * @return     */    @Override    public User findUserByUserName(String userName) {        Query query=new Query(Criteria.where("userName").is(userName));        User user =  mongoTemplate.findOne(query , User.class);        return user;    }    /**     * 更新對象     * @param user     */    @Override    public long updateUser(User user) {        Query query=new Query(Criteria.where("id").is(user.getId()));        Update update= new Update().set("userName", user.getUserName()).set("passWord", user.getPassWord());        //更新查詢返回結果集的第一條        UpdateResult result =mongoTemplate.updateFirst(query,update,User.class);        //更新查詢返回結果集的所有        // mongoTemplate.updateMulti(query,update,UserEntity.class);        if(result!=null)            return result.getMatchedCount();        else            return 0;    }    /**     * 刪除對象     * @param id     */    @Override    public void deleteUserById(Long id) {        Query query=new Query(Criteria.where("id").is(id));        mongoTemplate.remove(query,User.class);    }}/<code> 

4、開發對應的測試方法

<code>@RunWith(SpringRunner.class)@SpringBootTestpublic class UserDaoTest {    @Autowired    private UserDao userDao;    @Test    public void testSaveUser() throws Exception {        UserEntity user=new UserEntity();        user.setId(2l);        user.setUserName("小明");        user.setPassWord("fffooo123");        userDao.saveUser(user);    }    @Test    public void findUserByUserName(){       UserEntity user= userDao.findUserByUserName("小明");       System.out.println("user is "+user);    }    @Test    public void updateUser(){        UserEntity user=new UserEntity();        user.setId(2l);        user.setUserName("天空");        user.setPassWord("fffxxxx");        userDao.updateUser(user);    }    @Test    public void deleteUserById(){        userDao.deleteUserById(1l);    }}/<code>

5、查看驗證結果

可以使用工具 MongoVUE 工具來連接後直接圖形化展示查看,也可以登錄服務器用命令來查看

1.登錄 mongos

bin/mongo -host localhost -port 20000

2、切換到 test 庫

use test

3、查詢 user 集合數據

db.user.find()

根據3查詢的結果來觀察測試用例的執行是否正確。

到此 Spring Boot 對應 MongoDB 的增刪改查功能已經全部實現。

多數據源 MongoDB 的使用

接下來實現 MongoDB 多數據源的使用

1、pom 包配置

<code><dependencies>    <dependency>        <groupid>org.springframework.boot/<groupid>        <artifactid>spring-boot-starter-data-mongodb/<artifactid>    /<dependency>    <dependency>        <groupid>org.springframework.boot/<groupid>        <artifactid>spring-boot-starter-test/<artifactid>    /<dependency>/<dependencies>/<code>

2、配置兩條數據源,如下:

<code>mongodb.primary.uri=mongodb://192.168.0.75:20000mongodb.primary.database=primarymongodb.secondary.uri=mongodb://192.168.0.75:20000mongodb.secondary.database=secondary/<code> 

3、配置兩個庫的數據源

封裝讀取以 Mongodb 開頭的兩個配置文件

<code>@Data@ConfigurationProperties(prefix = "mongodb")public class MultipleMongoProperties {private MongoProperties primary = new MongoProperties();private MongoProperties secondary = new MongoProperties();}/<code>

配置不同包路徑下使用不同的數據源

第一個庫的封裝

<code>@Configuration@EnableMongoRepositories(basePackages = "com.neo.model.repository.primary",mongoTemplateRef = PrimaryMongoConfig.MONGO_TEMPLATE)public class PrimaryMongoConfig {protected static final String MONGO_TEMPLATE = "primaryMongoTemplate";}/<code>

第二個庫的封裝

<code>@Configuration@EnableMongoRepositories(basePackages = "com.neo.model.repository.secondary",mongoTemplateRef = SecondaryMongoConfig.MONGO_TEMPLATE)public class SecondaryMongoConfig {protected static final String MONGO_TEMPLATE = "secondaryMongoTemplate";}/<code>

讀取對應的配置信息並且構造對應的 MongoTemplate

<code>@Configurationpublic class MultipleMongoConfig {@Autowiredprivate MultipleMongoProperties mongoProperties;@Primary@Bean(name = PrimaryMongoConfig.MONGO_TEMPLATE)public MongoTemplate primaryMongoTemplate() throws Exception {return new MongoTemplate(primaryFactory(this.mongoProperties.getPrimary()));}@Bean@Qualifier(SecondaryMongoConfig.MONGO_TEMPLATE)public MongoTemplate secondaryMongoTemplate() throws Exception {        return new MongoTemplate(secondaryFactory(this.mongoProperties.getSecondary()));}@Bean    @Primarypublic MongoDbFactory primaryFactory(MongoProperties mongo) throws Exception {return new SimpleMongoDbFactory(new MongoClient(mongo.getHost(), mongo.getPort()),mongo.getDatabase());}@Beanpublic MongoDbFactory secondaryFactory(MongoProperties mongo) throws Exception {return new SimpleMongoDbFactory(new MongoClient(mongo.getHost(), mongo.getPort()),mongo.getDatabase());}}/<code>

兩個庫的配置信息已經完成。

4、創建兩個庫分別對應的對象和 Repository

對應可以共用

<code>public class User implements Serializable {        private static final long serialVersionUID = -3258839839160856613L;        private String  id;        private String userName;        private String passWord;        public User(String userName, String passWord) {                this.userName = userName;                this.passWord = passWord;        }}/<code>

對應的 Repository

<code>public interface PrimaryRepository extends MongoRepository<primarymongoobject> {}/<primarymongoobject>/<code>

繼承了 MongoRepository 會默認實現很多基本的增刪改查,省了很多自己寫 Repository 層的代碼

Secondary 和上面的代碼類似就不貼出來了

5、最後測試

<code>@RunWith(SpringRunner.class)@SpringBootTestpublic class MuliDatabaseTest {    @Autowired    private PrimaryRepository primaryRepository;    @Autowired    private SecondaryRepository secondaryRepository;    @Test    public void TestSave() {        System.out.println("************************************************************");        System.out.println("測試開始");        System.out.println("************************************************************");        this.primaryRepository                .save(new PrimaryMongoObject(null, "第一個庫的對象"));        this.secondaryRepository                .save(new SecondaryMongoObject(null, "第二個庫的對象"));        List<primarymongoobject> primaries = this.primaryRepository.findAll();        for (PrimaryMongoObject primary : primaries) {            System.out.println(primary.toString());        }        List<secondarymongoobject> secondaries = this.secondaryRepository.findAll();        for (SecondaryMongoObject secondary : secondaries) {            System.out.println(secondary.toString());        }        System.out.println("************************************************************");        System.out.println("測試完成");        System.out.println("************************************************************");    }}/<secondarymongoobject>/<primarymongoobject>/<code>

到此,MongoDB 多數據源的使用已經完成。


分享到:


相關文章: