Мысли о решениях по внутренней реализации сортировки методом перетаскивания
Мысли о решениях по внутренней реализации сортировки методом перетаскивания

Программное обеспечение Канбан, я думаю, большинство людей использовали подобное программное обеспечение, в основном предполагает перетаскивание карточек. Карты можно перетаскивать влево и вправо, вверх и вниз. Как можно реализовать серверную часть, чтобы не приходилось каждый раз переупорядочивать числа для повышения производительности? В корпоративном программном обеспечении в приложении также имеется множество деревьев и списков, которые поддерживают сортировку перетаскиванием. Такая конструкция может повысить эффективность по сравнению с традиционным прямым перемещением вверх и вниз, поэтому менеджеры по продуктам часто разумно рассматривают возможность использования сортировки перетаскиванием для улучшения взаимодействия с пользователем.

Сегодня подумаем, как реализовать бэкенд? Я считаю, что во внешнем интерфейсе есть готовые компоненты, которые можно использовать напрямую, поэтому я не буду искать их здесь~

Похоже на рекламный щит, как показано ниже:

Мысли о решениях по внутренней реализации сортировки методом перетаскивания
Мысли о решениях по внутренней реализации сортировки методом перетаскивания

Или такое перетаскивание списка:

Мысли о решениях по внутренней реализации сортировки методом перетаскивания
Мысли о решениях по внутренней реализации сортировки методом перетаскивания

Проектирование базы данных

В соответствии с фактическими потребностями определите как минимум 3 поля порядкового номера (идентификатор: первичный ключ, сортировка: номер сортировки, имя: отображаемое имя). Остальные поля разрабатываются в соответствии с потребностями вашего бизнеса. Для различных последующих планов будут внесены изменения. . Пожалуйста, ознакомьтесь с изменением конкретной базы данных.

Метод реализации

1. Полное обновление

Этот метод, вероятно, подойдет большинству людей. Он основан на идентификаторе перетаскивания и идентификаторе цели, переданных из внешнего интерфейса. Для удобства описания я покажу его в виде списка. перетаскивание вперед или движение вперед. После перетаскивания нам нужно только найти серийный номер после изменения после завершения перетаскивания, а затем изменить порядок всех полей сортировки.

2. Интервальный медианный метод

Этот метод оптимизирован на основе метода 1. В основном он предназначен для решения проблемы частого перетаскивания, из-за которого номер сортировки каждый раз обновляется. Для высокочастотных интерфейсов легко оказать сильное давление. базы данных, поэтому используется метод интервалов. Он предназначен для решения проблемы перестановки базы данных в определенной программе.

Сначала определите частоту перетаскивания бизнеса. Обычно достаточно интервала 1024–65535. В качестве примера я буду использовать интервал 1024. При добавлении новых данных серийный номер будет рассчитываться автоматически. Например, в настоящее время в базе данных имеется 10 данных. , затем вновь добавленная сортировка, рассчитанная в момент времени = (10+1) × 1024, а затем сохраненная как новая сортировка по времени.

При перетаскивании возможны три ситуации: 1. При настройке элемента на середину двух элементов просто обновите перетаскиваемые данные sort = sum of the two data ÷ 2 в базе данных. 2. При настройке элемента над первым элементом вы можете напрямую отсортировать перетаскиваемые данные = отсортировать первые данные ÷ 2, а затем сохранить их в базе данных. 3. При настройке элемента ниже последнего элемента напрямую отсортируйте перетаскиваемые данные = последняя сортировка данных + 1024 и сохраните их в базе данных.

Этот метод может в определенной степени облегчить проблему частого переупорядочения, но есть и некоторые крайние проблемы, которые требуют проверки того, достигается ли критическое значение каждый раз, поскольку каждый раз, когда берется медианное значение, значение интервала будет делиться поровну каждый раз. время, и оно будет продолжать тянуться. Движение приведет к тому, что это значение станет ближе и равным, поэтому необходимо также учитывать следующие ситуации.

1)Судить по самому маленькомуsortи максимумsortНе здесь 2 приезжать Максимальное значение типа, указанного в сортировке (Integer.MAX_VALUE или Long.MAX_VALUE) минус значение интервала. между временами,По данным все тяжело сортировать по порядку,В следующий раз, даже если перетащить первый, двух равных сортировок не будет.,Это приводит к сбою сортировки;

2) Определить, когда нужно отрегулировать элемент, располагаясь между двумя элементами.,Наконец, нам нужно обновить, является ли переноссорт плюс или минус 1 значением двух элементов.,еслиравныйПрямо сейчасданныепереставить;

3. Сортировка строк

Этот метод можно использовать только в том случае, если уникальный первичный ключ базы данных относительно короткий, объем данных невелик и разделен на основную и подтаблицы. Окончательно отсортированные записи сохраняются непосредственно в полях основной. таблица с запятыми или | символами и каждым перетаскиванием. При запросе вы можете напрямую передать строку из внешнего интерфейса и сохранить ее. Сортировка выполняется после каждого запроса. нет необходимости переупорядочивать. Интерфейс в основном обновляет поле сортировки.

4. Двусвязный список

Этот метод требует базы data добавляет 2 поля, pre_sort, next_sort, записывает значения двух узлов до и после, а затем при каждом изменении нужно только изменить значения трех элементов, участвующих в прибытии, операции базы Максимальное количество операций с данными — 6 раз, минимальное — 4 раза. Однако это решение ограничено невозможностью управления базой. данныхвыполнить нумерацию страниц исортировать。

Дизайн интерфейса

Для разных методов и решений Дизайн Интерфейсы не согласованы. Нам нужно только разрешить интерфейсу передавать необходимые параметры. Если вы не доверяете значению, переданному пользователем интерфейса, вам лучше начать с базы самостоятельно. данные для проверки и запроса.

Здесь я дам вам традиционное решение №2: Дизайн. интерфейса,Обязательны три поля: dragId: идентификатор перетаскиваемого элемента, targetId, переносприезжать идентификатор целевой позиции, moveType: тип перемещения (ВВЕРХ/ВНИЗ).,Это позволяет гибко перемещать целевую позицию прибытия вверх или вниз.

Подвести итог

Конкретный план выбора основан на нашем количестве данных.,Например, приоритет быстрого перетаскивания способов оплаты Alipay и Taobao.,Способы оплаты ограничены, а операции перетаскивания выполняются не очень часто.,Не имеет значения, если мы просто обновляем его каждый раз,А вот если это древовидный иерархический список, который нужно отобразить пользователю спереди и т.д.,Мы стараемся приезжать как можно меньше, чтобы очистить базу данных.,Тогда нет необходимости в дополнительной обработке в памяти при запросе,Поддержка схемы пейджинга,Я использую его здесь для личного малого и среднего бизнеса.Интервальный медианный методОчень подходит,Если вы используете интервал 65535, вам не придется его долго обновлять., если вы хотите уменьшить количество обновлений при большом количестве пользователей, база данныеданные, то вы можете еще больше сократить их, перезагрузив все запланированные на ночь задачи. В Интернете есть множество решений. Если вам нужно узнать об этом больше, вы можете прочитать «Справочник» в конце статьи. ссылка, если у вас есть лучшее решение, оставьте сообщение в области комментариев, чтобы обсудить его вместе.

Справочная ссылка

тащить Проектирование базы Краткое описание решения для обработки данных — Сообщество разработчиков Tencent Cloud — Tencent Cloud Сортировка карточек задач Teambition, как хранятся данные? - Чжиху Проектирование и реализация серверной части сортировки методом перетаскивания - Простая книга Рабочая практика: серверная реализация сортировки перетаскиванием - наггетсы Разработайте общую схему сортировки и вычислите нечеткие промежуточные числа. - наггетсы Использование Реагирования В DnD реализована сортировка списков методом перетаскивания-Tencent Cloud Developer Community-Tencent Cloud

boy illustration
Неразрушающее увеличение изображений одним щелчком мыши, чтобы сделать их более четкими артефактами искусственного интеллекта, включая руководства по установке и использованию.
boy illustration
Копикодер: этот инструмент отлично работает с Cursor, Bolt и V0! Предоставьте более качественные подсказки для разработки интерфейса (создание навигационного веб-сайта с использованием искусственного интеллекта).
boy illustration
Новый бесплатный RooCline превосходит Cline v3.1? ! Быстрее, умнее и лучше вилка Cline! (Независимое программирование AI, порог 0)
boy illustration
Разработав более 10 проектов с помощью Cursor, я собрал 10 примеров и 60 подсказок.
boy illustration
Я потратил 72 часа на изучение курсорных агентов, и вот неоспоримые факты, которыми я должен поделиться!
boy illustration
Идеальная интеграция Cursor и DeepSeek API
boy illustration
DeepSeek V3 снижает затраты на обучение больших моделей
boy illustration
Артефакт, увеличивающий количество очков: на основе улучшения характеристик препятствия малым целям Yolov8 (SEAM, MultiSEAM).
boy illustration
DeepSeek V3 раскручивался уже три дня. Сегодня я попробовал самопровозглашенную модель «ChatGPT».
boy illustration
Open Devin — инженер-программист искусственного интеллекта с открытым исходным кодом, который меньше программирует и больше создает.
boy illustration
Эксклюзивное оригинальное улучшение YOLOv8: собственная разработка SPPF | SPPF сочетается с воспринимаемой большой сверткой ядра UniRepLK, а свертка с большим ядром + без расширения улучшает восприимчивое поле
boy illustration
Популярное и подробное объяснение DeepSeek-V3: от его появления до преимуществ и сравнения с GPT-4o.
boy illustration
9 основных словесных инструкций по доработке академических работ с помощью ChatGPT, эффективных и практичных, которые стоит собрать
boy illustration
Вызовите deepseek в vscode для реализации программирования с помощью искусственного интеллекта.
boy illustration
Познакомьтесь с принципами сверточных нейронных сетей (CNN) в одной статье (суперподробно)
boy illustration
50,3 тыс. звезд! Immich: автономное решение для резервного копирования фотографий и видео, которое экономит деньги и избавляет от беспокойства.
boy illustration
Cloud Native|Практика: установка Dashbaord для K8s, графика неплохая
boy illustration
Краткий обзор статьи — использование синтетических данных при обучении больших моделей и оптимизации производительности
boy illustration
MiniPerplx: новая поисковая система искусственного интеллекта с открытым исходным кодом, спонсируемая xAI и Vercel.
boy illustration
Конструкция сервиса Synology Drive сочетает проникновение в интрасеть и синхронизацию папок заметок Obsidian в облаке.
boy illustration
Центр конфигурации————Накос
boy illustration
Начинаем с нуля при разработке в облаке Copilot: начать разработку с минимальным использованием кода стало проще
boy illustration
[Серия Docker] Docker создает мультиплатформенные образы: практика архитектуры Arm64
boy illustration
Обновление новых возможностей coze | Я использовал coze для создания апплета помощника по исправлению домашних заданий по математике
boy illustration
Советы по развертыванию Nginx: практическое создание статических веб-сайтов на облачных серверах
boy illustration
Feiniu fnos использует Docker для развертывания личного блокнота Notepad
boy illustration
Сверточная нейронная сеть VGG реализует классификацию изображений Cifar10 — практический опыт Pytorch
boy illustration
Начало работы с EdgeonePages — новым недорогим решением для хостинга веб-сайтов
boy illustration
[Зона легкого облачного игрового сервера] Управление игровыми архивами
boy illustration
Развертывание SpringCloud-проекта на базе Docker и Docker-Compose