springboot集成MongoDB简单示例

 POM.XML

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

application.properties

spring.data.mongodb.host=127.0.0.1
spring.data.mongodb.port=27017
spring.data.mongodb.database=mongodb

 Controller

package com.controller;

import com.mongodb.client.result.UpdateResult;
import com.entity.User;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.mongodb.core.MongoTemplate;
import org.springframework.data.mongodb.core.query.Criteria;
import org.springframework.data.mongodb.core.query.Query;
import org.springframework.data.mongodb.core.query.Update;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;

import java.util.List;

@RestController
@RequestMapping("mongo")
public class MongoDBController {
    @Autowired
    private MongoTemplate mongoTemplate;

    //MongoDB表名
    private static final String collectionName = "user";

    /**
     * 插入
     * @return
     */
    @RequestMapping("insert")
    public String insert(User user){
        user.setName("cc");
        user.setUserId(1+"");
        user.setAge(1);
        User insert = mongoTemplate.insert(user);
        return insert.toString();
    }

    /**
     * 删除
     * @param userId
     * @throws Exception
     */
    @RequestMapping("delete")
    public void delete(@RequestParam("userId") String userId){
        Query query = Query.query(Criteria.where("userId").is(userId));//添加查询条件
        this.mongoTemplate.remove(query, collectionName);
    }

    /**
     * 更新
     * @param user
     */
    @RequestMapping("update")
    public void update(User user){
        Query query = Query.query(Criteria.where("userId").is(user.getUserId()));//添加查询条件
        Update update = new Update();
        update.set("age", user.getAge());
        update.set("name", user.getName());
        update.set("email", user.getEmail());
        UpdateResult updateResult = this.mongoTemplate.updateFirst(query, update, collectionName);
        System.out.println(updateResult.toString());
    }


    /**
     * 查询
     */
    @RequestMapping("query")
    public void query(){
        Query query = Query.query(Criteria.where("userId").is("1"));
        List<User> users = this.mongoTemplate.find(query, User.class);
        System.out.println(users);
    }
}

 

User.java

public class User {

    private String userId;

    private String name;

    private String email;

    private Date birthday;

    private int age;

    public User() {
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public String getUserId() {
        return userId;
    }

    public void setUserId(String userId) {
        this.userId = userId;
    }

    public String getEmail() {
        return email;
    }

    public void setEmail(String email) {
        this.email = email;
    }

    public Date getBirthday() {
        return birthday;
    }

    public void setBirthday(Date birthday) {
        this.birthday = birthday;
    }

    public int getAge() {
        return age;
    }

    public void setAge(int age) {
        this.age = age;
    }

    @Override
    public String toString() {
        return "User{" +
                "userId='" + userId + '\'' +
                ", name='" + name + '\'' +
                ", email='" + email + '\'' +
                ", birthday=" + birthday +
                ", age=" + age +
                '}';
    }
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

皮卡丘踢球

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值