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,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 

相关文章

文章浏览阅读552次。com.mongodb.MongoQueryException: Quer...
文章浏览阅读635次,点赞9次,收藏8次。MongoDB 是一种 NoSQ...
文章浏览阅读2.1k次。和。_mongodb 日期类型
文章浏览阅读1.7k次。Scalestack等客户期待使用MongoDB Atla...
文章浏览阅读970次。SpringBoot整合中间件mongodb、ES_sprin...
文章浏览阅读673次。MongoDB 简介_尚医通sql