麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 數據庫 > MongoDB > 正文

Spring Boot中使用MongoDB數據庫的方法

2020-03-14 12:51:09
字體:
來源:轉載
供稿:網友

MongoDB數據庫簡介

簡介

  MongoDB是一個高性能,開源,無模式的,基于分布式文件存儲的文檔型數據庫,由C++語言編寫,其名稱來源取自“humongous”,是一種開源的文檔數據庫──NoSql數據庫的一種。NoSql,全稱是 Not Only Sql,指的是非關系型的數據庫。

特點

  MongoDB數據庫的特點是高性能、易部署、易使用,存儲數據非常方便。主要功能特性有:

  * 面向集合存儲,易存儲對象類型的數據。
  * 模式自由。
  * 支持動態查詢。
  * 支持完全索引,包含內部對象。
  * 支持查詢。
  * 支持復制和故障恢復。
  * 使用高效的二進制數據存儲,包括大型對象(如視頻等)。
  * 自動處理碎片,以支持云計算層次的擴展性
  * 支持RUBY,PYTHON,JAVA,C++,PHP等多種語言。
  * 文件存儲格式為BSON(一種JSON的擴展)
  * 可通過網絡訪問

MongoDB是一個開源的NoSQL文檔數據庫,它使用一個JSON格式的模式(schema)替換了傳統的基于表的關系數據。Spring Boot為使用MongoDB提供了很多便利,包括spring-boot-starter-data-mongodb 'Starter POM'。

引入spring-boot-starter-data-mongodb包,在pom.xml配置文件中增加如下內容(基于之前章節“Spring Boot 構建框架”中的pom.xml文件):

<dependency>   <groupId>org.springframework.boot</groupId>  <artifactId>spring-boot-starter-data-mongodb</artifactId></dependency>

注入一個自動配置的org.springframework.data.mongodb.MongoDbFactory來訪問Mongo數據庫。默認情況下,該實例將嘗試使用URL: mongodb://localhost/test連接一個MongoDB服務器。

import org.springframework.data.mongodb.MongoDbFactory;import com.mongodb.DB;@Componentpublic class MyBean {  private final MongoDbFactory mongo;  @Autowired  public MyBean(MongoDbFactory mongo) {    this.mongo = mongo;  }  // ...  public void example() {  DB db = mongo.getDb();    // ...  }}

可以通過設置spring.data.mongodb.uri來改變該url,或指定一個host/port。在application.properties中設置如下的屬性:

spring.data.mongodb.host=mongoserverspring.data.mongodb.port=27017

注意:如果沒有指定spring.data.mongodb.port,那將使用默認的端口27017。可以簡單的從上面的示例中刪除這一行。如果不使用Spring Data Mongo,可以注入com.mongodb.Mongo beans而不是使用MongoDbFactory。如果想全面控制MongoDB連接的建立,也可以聲明自己的MongoDbFactory或Mongo,@Beans。

MongoDBTemplate

Spring Data Mongo提供了一個MongoTemplate類,它的設計和Spring的JdbcTemplate很相似。正如JdbcTemplate一樣,Spring Boot會自動配置一個bean,你只需簡單的注入它即可:

import org.springframework.beans.factory.annotation.Autowired;import org.springframework.data.mongodb.core.MongoTemplate;import org.springframework.stereotype.Component;@Componentpublic class MyBean {  private final MongoTemplate mongoTemplate;    @Autowired  public MyBean(MongoTemplate mongoTemplate) {    this.mongoTemplate = mongoTemplate;  }  // ...}

應用集成MongoDB案例

在application.properties配置文件中添加內容如下:

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

多個IP集群采用以下配置:

spring.data.mongodb.uri=mongodb://user:pass@ip1:port1,ip2:port2/database

創建數據實體類,具體代碼如下:

public class UserInfo implements Serializable {  private Long id;  private String userName;  private String passWord;  //getter、setter省略}

創建實體類對應dao層,實現增刪改查操作,具體代碼如下:

@Componentpublic class UserInfoDaoImpl implements UserInfoDao {// UserInfoDao 自定義接口  @Autowired  private MongoTemplate mongoTemplate;  /**   * 創建對象   * @param user   */  @Override  public void saveUser(UserInfo user) {    mongoTemplate.save(user);  }  /**   * 根據用戶名查詢對象   * @param userName   * @return   */  @Override  public UserInfo findUserByUserName(String userName) {    Query query=new Query(Criteria.where("userName").is(userName));    UserInfo user = mongoTemplate.findOne(query , UserInfo.class);    return user;  }  /**   * 更新對象   * @param user   */  @Override  public void updateUser(UserInfo user) {    Query query=new Query(Criteria.where("id").is(user.getId()));    Update update= new Update().set("userName", user.getUserName()).set("passWord", user.getPassWord());    //更新查詢返回結果集的第一條    mongoTemplate.updateFirst(query,update,UserInfo.class);    //更新查詢返回結果集的所有    // mongoTemplate.updateMulti(query,update,UserInfo.class);  }  /**   * 刪除對象   * @param id   */  @Override  public void deleteUserById(Long id) {    Query query=new Query(Criteria.where("id").is(id));    mongoTemplate.remove(query,UserInfo.class);  }}

簡單測試方法,具體代碼如下:

@RunWith(SpringRunner.class)@SpringBootTestpublic class UserDaoTest {  @Autowired  private UserDao userDao;  @Test  public void testSaveUser() throws Exception {    UserInfo user=new UserInfo();    user.setId(2);    user.setUserName("路人甲");    user.setPassWord("123456");    userDao.saveUser(user);  }  @Test  public void findUserByUserName(){    UserInfo user= userDao.findUserByUserName("路人甲");    System.out.println("user is "+user);  }  @Test  public void updateUser(){    UserInfo user=new UserInfo();    user.setId(3);    user.setUserName("路人乙");    user.setPassWord("123456");    userDao.updateUser(user);  }  @Test  public void deleteUserById(){    userDao.deleteUserById(3);  }}

登錄MongoDB驗證數據

使用mongoVUE工具來連接后直接圖形化查看或登錄服務器用命令來查看登錄mongodb服務端,執行命令bin/mongo -host localhost -port 27017,切換至test庫執行use test命令,查詢userInfo集合數據,執行db.userInfo.find()查詢數據。

總結

以上所述是小編給大家介紹的Spring Boot中使用MongoDB數據庫的方法,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對VEVB武林網網站的支持!


注:相關教程知識閱讀請移步到MongoDB頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 日韩在线播放第一页 | 性盈盈盈影院 | 亚洲电影在线观看高清免费 | 中文字幕爱爱视频 | 国产亚洲精品久久久久久久久 | 黄www片| 在线亚洲播放 | 黄色免费电影网址 | 成人毛片网站 | 国产精品一区二区三区在线播放 | 在线观看一二区 | 国产做爰全免费的视频黑人 | 夜夜夜影院 | 国内精品久久久久久久久久久久 | 思思久而久而蕉人 | 日本精品一二区 | 成人在线免费视频播放 | 精品久久久久久国产 | 国产91丝袜在线播放 | 一级黄色影片在线观看 | 色蜜桃av | 在线免费黄色网 | 成人性视频在线 | 久久精品a一级国产免视看成人 | 成人国产精品齐天大性 | 黄色毛片一级视频 | 88xx成人精品视频 | 蜜桃成品人免费视频 | 欧美 亚洲 视频 | 午夜国内精品a一区二区桃色 | 欧美日韩成人一区二区 | 精选久久 | 国产免费视频一区二区裸体 | 一级免费 | 亚洲午夜激情网 | 国产精品视频一区二区三区综合 | 国产99久久久久久免费看 | 欧美一级成人 | 毛片在线免费观看完整版 | 精品xxxx户外露出视频 | 久久中出|