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

这样就可以获取到一个分页结果了。

posted @ 2024-03-15 21:29  IT终结者  阅读(18)  评论(0编辑  收藏  举报