В этой статье обсуждается проблема, возникшая при использовании подключаемого модуля подкачки PageHelper. Когда автор использовал PageHelper для разбивки данных по страницам, он обнаружил ошибку в общем количестве возвращаемых записей. В статье сначала анализируются возможные причины проблемы, а затем подробно описываются шаги по воспроизведению проблемы на реальных примерах. В то же время в статье также представлены решения и предложения по оптимизации этой проблемы. Прочтите эту статью, чтобы узнать, как использовать подключаемый модуль подкачки PageHelper и как быстро находить и решать подобные проблемы в реальных проектах, чтобы повысить качество кода и эффективность разработки. Это имеет определенную справочную ценность и вдохновляет разработчиков, использующих подключаемые модули подкачки.
В ходе формирования команды по гибкому подходу в этом году я внедрил автоматическое модульное тестирование в один клик с помощью Suite executor. Кроме экзекьютора Suite, какие еще экзекьюторы есть у Juint? Здесь начинается мое путешествие по исследованию Раннера!
Общее количество записей, возвращаемых при разбиении по страницам, соответствует количеству страниц на странице. PageSize. Количество статистических данных базы данных превышает общее количество возвращаемых в данный момент записей. Ниже приведен соответствующий код.
Прежде всего, MCube определит, нужно ли ему получать последний шаблон из сети, на основе состояния кэша шаблонов. Когда шаблон будет получен, он будет загружен. На этапе загрузки продукт будет преобразован в структуру. дерева представления. После завершения преобразования выражение будет проанализировано с помощью механизма выражений. Получите правильное значение, проанализируйте определяемое пользователем событие с помощью механизма анализа событий и завершите привязку события. После завершения назначения синтаксического анализа и события. привязка, представление визуализируется, и, наконец, целевая страница отображается на экране.
1. Ошибка SQL приводит к неправильной возвращаемой информации? Результаты проверки: После передачи SQL, сгенерированного в журнале выполнения данных, SQL нормальный и общее количество данных также правильное.
2.PageHelper используется неправильно, что приводит к ошибкам в данных. Результаты проверки: путем сравнения с записями использования в других частях проекта метод использования является правильным.
3. После возврата результата происходит промежуточная обработка, в результате чего общее количество уменьшается. Результаты проверки: Кто-то в Интернете столкнулся с ситуацией, когда возвращаемый результат был преобразован по типу, что привело к тотальной ошибке. обнаружил, что, хотя текущий код не выполнил преобразование типа возвращаемого результата, он вернул преобразователь. В результате объект экземпляра заменяется, а замененный объект упаковывается.
Подробнее об упаковкеPageInfo<T>
Исходный код не имеет ничего общего сtotalОбработка параметров,
PageInfo<T>
Конструктор
public class PageInfo<T> extends PageSerializable<T> {
/**
* Упаковка Страницаобъект
*
* @param list результаты страницы
* @param navigatePages Количество страниц
*/
public PageInfo(List<T> list, int navigatePages) {
super(list);
if (list instanceof Page) {
Page page = (Page) list;
this.pageNum = page.getPageNum();
this.pageSize = page.getPageSize();
this.pages = page.getPages();
this.size = page.size();
//Поскольку результат>startRowиз,Так что реальная необходимость +1
if (this.size == 0) {
this.startRow = 0;
this.endRow = 0;
} else {
this.startRow = page.getStartRow() + 1;
//Вычисляем фактическую endRow (специально на последней странице)
this.endRow = this.startRow - 1 + this.size;
}
} else if (list instanceof Collection) {
this.pageNum = 1;
this.pageSize = list.size();
this.pages = this.pageSize > 0 ? 1 : 0;
this.size = list.size();
this.startRow = 0;
this.endRow = list.size() > 0 ? list.size() - 1 : 0;
}
if (list instanceof Collection) {
this.navigatePages = navigatePages;
//Рассчитать страницу навигации
calcNavigatepageNums();
//Рассчитываем предыдущую и следующую страницы, первую и последнюю страницы
calcPage();
//Оцениваем границы страницы
judgePageBoudary();
}
}
}
Продолжайте рассматривать родительский класс PageSerializable и узнайте об обработке параметра total, то есть, когда список, возвращаемый сопоставителем, не является экземпляром Page, total будет установлен в размер возвращаемого списка.
Конструктор PageSerializable
public PageSerializable(List<T> list) {
this.list = list;
if(list instanceof Page){
this.total = ((Page)list).getTotal();
} else {
this.total = list.size();
}
}
После дальнейшей отладки было обнаружено, что возвращенный список действительно не является экземпляром класса Page, поэтому был сделан вывод, что этот результат был вызван заменой объекта экземпляра результатом списка, возвращенным картографом.
Еще раз подтвердите, что результат, возвращаемый картографом, является экземпляром Page
Прежде всего, MCube определит, нужно ли ему получать последний шаблон из сети, на основе состояния кэша шаблонов. Когда шаблон будет получен, он будет загружен. На этапе загрузки продукт будет преобразован в структуру. дерева представления. После завершения преобразования выражение будет проанализировано с помощью механизма выражений. Получите правильное значение, проанализируйте определяемое пользователем событие с помощью механизма анализа событий и завершите привязку события. После завершения назначения синтаксического анализа и события. привязка, представление визуализируется, и, наконец, целевая страница отображается на экране. 1. Принцип растрового изображения
Используйте объект, возвращаемый картографом, для непосредственного создания объекта PageInfo и получения информации о подкачке на основе этого.
Исправленный код выглядит следующим образом:
лучшие практики
в использовании PageInfo pageInfo = new PageInfo<>(T); Используйте картограф непосредственно при создании PageInfo Возвращайте объект. Не выполняйте операции преобразования типов или передачи, чтобы избежать потери данных.