Home > Java > javaTutorial > How SpringBoot integrates Mongodb to implement additions, deletions, and changes

How SpringBoot integrates Mongodb to implement additions, deletions, and changes

王林
Release: 2023-05-13 14:07:16
forward
1177 people have browsed it

1. What is MongoDB

MongoDB is different from the relational databases (MySQL, Oracle) we are familiar with before. MongoDB is a document database, which has the required scalability and flexibility, as well as all Required queries and indexes.

MongoDB stores data in flexible, JSON-like documents, which means that the fields of a document can vary from document to document and the data structure can change over time. The document model maps to objects in application code, making the data easy to work with. MongoDB is a distributed database at its core, so high availability, scale-out, and geographic distribution are built-in and easy to use. Moreover, MongoDB is free and open source.

2. Install MongoDB on Window10

Open the MongoDB official website

How SpringBoot integrates Mongodb to implement additions, deletions, and changes

Download the MSI version (installation version)

How SpringBoot integrates Mongodb to implement additions, deletions, and changes

When downloading, select Custom

How SpringBoot integrates Mongodb to implement additions, deletions, and changes

When installing, be careful not to check the installation visual plug-in, otherwise the installation will be very slow ( Unless your Internet speed is fast enough)

How SpringBoot integrates Mongodb to implement additions, deletions, and changes

3. Configure MongoDB service

Configure environment variables

Copy the current path

How SpringBoot integrates Mongodb to implement additions, deletions, and changes

My Computer->Right-click->Advanced System Settings->Environment Variables->System Variables

Find Path in the system variables, edit, Add the path copied above

How SpringBoot integrates Mongodb to implement additions, deletions, and changes

4. Start the service

win R->Enter services.msc

How SpringBoot integrates Mongodb to implement additions, deletions, and changes

How SpringBoot integrates Mongodb to implement additions, deletions, and changes

After the service is started, enter 127.0.0.1:2701

How SpringBoot integrates Mongodb to implement additions, deletions, and changes

in the browser and it will appear This line of English means that the service was successfully started.

5. SpringBoot integrates MongoDB

Environment preparation

Operating system: Window10

IDE: IntelliJ IDEA 2018.2.4

Database: MongoDB

1) Introduce dependencies

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

2) Add the following configuration in application.yml

spring:
  data:
    mongodb:
      uri: mongodb://localhost/test_mongodb
Copy after login

The complete configuration information is as follows:

spring:
  data:
    mongodb:
      authentication-database: # Authentication database name.
      database: # Database name.
      field-naming-strategy: # Fully qualified name of the FieldNamingStrategy to use.
      grid-fs-database: # GridFS database name.
      host: # Mongo server host. Cannot be set with URI.
      password: # Login password of the mongo server. Cannot be set with URI.
      port: # Mongo server port. Cannot be set with URI.
      repositories:
        type: # Type of Mongo repositories to enable.
      uri: # Mongo database URI. Cannot be set with host, port and credentials.
      username: # Login user of the mongo server. Cannot be set with URI.
Copy after login

3) Add entity class UserEntity

public class UserEntity {
    @Id
    private String uid;
    private String username;
    private String password;
    public String getUid() {
        return uid;
    }
    public void setUid(String uid) {
        this.uid = uid;
    }
    public String getUsername() {
        return username;
    }
    public void setUsername(String username) {
        this.username = username;
    }
    public String getPassword() {
        return password;
    }
    public void setPassword(String password) {
        this.password = password;
    }
    @Override
    public String toString() {
        return "UserEntity{" +
                "uid=&#39;" + uid + &#39;\&#39;&#39; +
                ", username=&#39;" + username + &#39;\&#39;&#39; +
                ", password=&#39;" + password + &#39;\&#39;&#39; +
                &#39;}&#39;;
    }
}
Copy after login

4) Create new test. Here I use navicat as a visualization tool for MongoDB to view.

Test 1: Insert operation

    @Autowired
    private MongoTemplate mongoTemplate;
    @Test
    public void saveUser(){
        UserEntity userEntity1 = new UserEntity();
        UserEntity userEntity2 = new UserEntity();
        UserEntity userEntity3 = new UserEntity();
        userEntity1.setUid("111");
        userEntity1.setUsername("用户1");
        userEntity1.setPassword("密码1");
        userEntity2.setUid("222");
        userEntity2.setUsername("用户2");
        userEntity2.setPassword("密码2");
        userEntity3.setUid("333");
        userEntity3.setUsername("用户3");
        userEntity3.setPassword("密码3");
        mongoTemplate.save(userEntity1);
        mongoTemplate.save(userEntity2);
        mongoTemplate.save(userEntity3);
    }
Copy after login

Database information:

How SpringBoot integrates Mongodb to implement additions, deletions, and changes

As you can see, MongoDB automatically creates the database and generates it through entity classes The collection (which is what we often call the data table), and we have inserted several documents (that is, inserted several records) into the userEntity collection of the database through MongoTemplate. _id is the primary key, _class is the entity class package name and class name

Test 2: Query operation

    @Autowired
    private MongoTemplate mongoTemplate;
	@Test
    public void findUserByUserName(){
        String username = "用户1";
        Query query=new Query(Criteria.where("username").is(username));
        UserEntity user =  mongoTemplate.findOne(query , UserEntity.class);
        System.out.println(user);
    }
Copy after login

Output result:

UserEntity{uid='111', username='User 1', password='Password 1'}

Test 3: Update operation

  @Autowired
    private MongoTemplate mongoTemplate;    
	@Test
    public void updateUser(){
        UserEntity userEntity = new UserEntity();
        userEntity.setUid("111");
        userEntity.setUsername("更新后的用户名");
        userEntity.setPassword("更新后的密码");
        Query query = new Query(Criteria.where("_id").is(userEntity.getUid()));
        Update update = Update.update("username",userEntity.getUsername()).set("password",userEntity.getPassword());
        //更新返回结果集的第一条
        mongoTemplate.updateFirst(query,update,UserEntity.class);
        //更新返回结果集的所有
        //mongoTemplate.updateMulti(query,update,UserEntity.class);
    }
Copy after login

Update The database after deletion is as shown in the figure:

How SpringBoot integrates Mongodb to implement additions, deletions, and changes

Test 4: Delete operation

    @Autowired
    private MongoTemplate mongoTemplate; 
	@Test
    public  void DeleteByUserId(){
        String id = "222";
        Query query=new Query(Criteria.where("_id").is(id));
        mongoTemplate.remove(query,UserEntity.class);
    }
Copy after login

The database after deletion is as shown in the figure:

How SpringBoot integrates Mongodb to implement additions, deletions, and changes

The above is the detailed content of How SpringBoot integrates Mongodb to implement additions, deletions, and changes. For more information, please follow other related articles on the PHP Chinese website!

Related labels:
source:yisu.com
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template