springboot mongodb简单教程

(1)依赖

compile('org.springframework.boot:spring-boot-starter-data-mongodb')

(2)application.properties配置文件

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

(3)User类

@Data
public class User {

	Integer id;
	String name;
	Integer age;
	Date birth;
	
	public User(Integer id, String name, Integer age, Date birth) {
		super();
		this.id = id;
		this.name = name;
		this.age = age;
		this.birth = birth;
	}
	
}

(4)UserService类

@Service
public class UserService {

	@Autowired
	MongoTemplate mongoTemplate;
	
	public void insert(User user) {
		mongoTemplate.insert(user);
	}
	
	public long update(String name, User user) {
		Query query = new Query();
		Criteria c = new Criteria();
		c.and("name").is(name);
		query.addCriteria(c);
		Update update= new Update();
		update.set("age", user.getAge());
		update.set("birth", user.getBirth());
		WriteResult result = mongoTemplate.upsert(query, update, User.class);
		return result.getN();
    }
	
	public long remove(String name) {
		Query query = new Query();
		Criteria c = new Criteria();
		c.and("name").is(name);
		query.addCriteria(c);
		WriteResult result = mongoTemplate.remove(query, User.class);
		return result.getN();
    }
	
    public User findOne(String name, Integer age) {
		Query query = new Query();
		Criteria c = new Criteria();
		c.and("name").is(name);
		c.and("age").gte(age);
		query.addCriteria(c);
		return mongoTemplate.findOne(query, User.class);
    }
	
    public List<User> find(Integer age) {
		Query query = new Query();
		Criteria c = new Criteria();
		c.and("age").gt(age);
		query.addCriteria(c);
		return mongoTemplate.find(query, User.class);
    }
    
    public long count(Integer age) {
		Query query = new Query();
		Criteria c = new Criteria();
		c.and("age").gte(age);
		query.addCriteria(c);
		return mongoTemplate.count(query, User.class);
    }
    
}

(5)测试和测试结果

User user1 = new User(1, "tom", 1, new Date());
User user2 = new User(2, "jerry", 2, new Date());
User user3 = new User(3, "diana", 3, new Date());
userService.insert(user1);
userService.insert(user2);
userService.insert(user3);
User user = userService.findOne("tom", 1);
log.info("user:{}", user);
List<User> list = userService.find(1);
log.info("list:{}", list);
long count = userService.count(1);
log.info("count:{}", count);
User tom = new User(1, "tom", 5, new Date());
long n1 = userService.update("tom", tom);
log.info("n1:{}", n1);
long n2 = userService.remove("tom");
log.info("n2:{}", n2);
2024-01-26 16:21:15 [http-nio-8080-exec-2] INFO  cn.hwd.controller.TestController - user:User(id=1, name=tom, age=1, birth=Fri Jan 26 16:21:15 CST 2024) 
2024-01-26 16:21:15 [http-nio-8080-exec-2] INFO  cn.hwd.controller.TestController - list:[User(id=2, name=jerry, age=2, birth=Fri Jan 26 16:21:15 CST 2024), User(id=3, name=diana, age=3, birth=Fri Jan 26 16:21:15 CST 2024)] 
2024-01-26 16:21:15 [http-nio-8080-exec-2] INFO  cn.hwd.controller.TestController - count:3 
2024-01-26 16:21:15 [http-nio-8080-exec-2] INFO  cn.hwd.controller.TestController - n1:1 
2024-01-26 16:21:15 [http-nio-8080-exec-2] INFO  cn.hwd.controller.TestController - n2:1 

相关推荐

  1. SQLMap简单注入教程

    2024-01-27 12:46:03       19 阅读
  2. Docker Zookeeper 安装 简单教程

    2024-01-27 12:46:03       36 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-01-27 12:46:03       16 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-01-27 12:46:03       16 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-01-27 12:46:03       15 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-01-27 12:46:03       18 阅读

热门阅读

  1. STL标准库(三)之forward_list

    2024-01-27 12:46:03       29 阅读
  2. PostgreSQL(十一)coalesce() 函数的用法

    2024-01-27 12:46:03       30 阅读
  3. 构建支持 gpu 的 jupyterlab docker 镜像

    2024-01-27 12:46:03       34 阅读