MongoTemplate的CRUD的操作示例:
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.data.domain.Page;
import org.springframework.data.domain.Pageable;
import org.springframework.data.mongodb.core.MongoPage;
import org.springframework.data.mongodb.core.mapping.Document;
@Service
public class UserService {
@Autowired
private MongoTemplate mongoTemplate;
// 插入操作
public void addUser(User user) {
mongoTemplate.save(user);
}
// 查询操作(根据ID查询)
public User getUserById(String id) {
return mongoTemplate.findById(id, User.class);
}
// 查询所有用户(分页示例)
public MongoPage<User> getAllUsers(Pageable pageable) {
Query query = Query.query(Criteria.where("id").ne(null));
query.with(pageable);
return mongoTemplate.find(query, User.class, new MongoPageRequestAdapter<>(pageable));
}
// 更新操作
public void updateUser(String id, String newName) {
Query query = new Query(Criteria.where("id").is(id));
Update update = new Update().set("name", newName);
mongoTemplate.updateFirst(query, update, User.class);
}
// 删除操作
public void deleteUser(String id) {
Query query = new Query(Criteria.where("id").is(id));
mongoTemplate.remove(query, User.class);
}
}
在这个示例中,我们引入了 Pageable 接口和 MongoPage 类,用于实现分页查询。getAllUsers 方法接收一个 Pageable 对象作为参数,然后构建一个查询条件(排除 id 为空的文档),并使用 with 方法将分页信息应用到查询中。最后,使用 find 方法执行查询,并返回一个 MongoPage 对象,其中包含了分页信息和查询结果。
注意,这里使用了 MongoPageRequestAdapter 将 Pageable 对象转换为 org.springframework.data.mongodb.core.query.Pageable 对象,因为 mongoTemplate 需要的是后者的类型。
客户端调用时,可以使用 PageRequest 构造一个分页对象,然后传递给 getAllUsers 方法:
Pageable pageable = PageRequest.of(0, 10); // 第一页,每页10条记录
MongoPage<User> users = userService.getAllUsers(pageable);
这样就可以获取到一个分页结果了。