Эта статья о Пагинация плагина 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. Возвращайте объект. Не выполняйте операции преобразования типов или передачи, чтобы избежать потери данных.