spring - 限制一页上数据库结果的可见性-spring boot
问题描述
我使用 postgress 数据库在 Spring Boot 中创建 Web 应用程序。
我想限制每页的记录数(现在是 30,000 条记录 - 它正在加载很长时间),那么我应该怎么做才能限制呢?我用百里香叶。
模型:
@Entity(name="articles")
@JsonIgnoreProperties({"hibernateLazyInitializer", "handler"})
public class Articles {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
private Long article_id;
private String title;
private String issn;
private String eissn;
private String title2;
private String issn2;
private String eissn2;
private Integer points;
@ManyToMany
@JoinTable(
name = "articles_categories",
joinColumns = @JoinColumn(name = "article_id"),
inverseJoinColumns = @JoinColumn(name = "category_id"))
private List<Category> categories;
....
getters and setters
存储库:
public interface ArticlesRepository extends JpaRepository<Articles,Long> {
}
控制器:
@Controller
@RequestMapping("/articles")
public class ArticlesController {
private ArticleService articleService;
@Autowired
public void setArticleService(ArticleService articleService) {
this.articleService = articleService;
}
@GetMapping
public String getAll(Model model)
{
model.addAttribute("articles", articleService.list());
return "articles";
}
服务:
@Service
public class ArticleService {
@Autowired
private ArticlesRepository articlesRepository;
public ArticleService() {
}
public List<Articles> list(){
return articlesRepository.findAll();
}}
解决方案
使用Pageable限制文章的大小。
public List<Articles> list(int page, int limit){
Page<Articles> pageableArticales = articlesRepository.findAll(PageRequest.of(page, limit);
return pageableArticales.getContent();
}
请注意,它repository.findAll(pageable)
包装了Page上的数据列表,它提供getNumber()
, getSize()
, getNumberOfElements()
, getTotalPages()
,getTotalElements
等。
并考虑探索PageRequest和PagedResources。
推荐阅读
- reactjs - 如何在材质 ui select menuItem 中映射字符串数组?
- python - 如何使用curl命令使用python下载bitbucket中的文件
- postgresql - 我尝试将 SQLite 数据库转换为 Postgres,我不知道 postgres 数据库的 DATETIME 是否相等
- angular - 使用 FormArray 对反应式表单的有效性进行单元测试
- javascript - 简单的设置 react redux 与 next.js (React)
- spring-boot - Spring Kafka 项目的 Debezium 发件箱错误
- android - Arrarylist 大小为 0,在 android 中具有静态 recyclerview 列表
- socket.io - 如何从 socket.io>3ver. 发出 blob 视频?
- python - pycharm(python)以不同的颜色显示函数 - 有时是白色,有时是黄色 - 为什么会这样?
- sql - 如何从结果查询创建表?