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

springboot mongodb简单教程_第1张图片

你可能感兴趣的:(MongoDB,Spring,Boot,spring,boot,mongodb)