|
0 / 0 / 0
Регистрация: 02.05.2012
Сообщений: 13
|
|
Оптимизация разницы множеств16.08.2006, 22:34. Показов 2621. Ответов 2
Метки нет (Все метки)
Запрос просит что-то вроде
Select contactid from contact where (contactid in ('id1', 'id2')) and (contactid not in ('id2', 'id3')) при чём множества в скобках имеют по 13000 элементов шириной в 12 символов. Такой запрос сервер пытался обработать 45 минут, но потом мне надоело ждать. Аналогичный запрос с таким же количеством элементов, но только на пересечение или на дополнение множеств срабатывает за 2-3 минуты. Как оптимизировать этот запрос? Или в чём тут проблема? Contactid - это non-clustered primary key index field. Теоретически можно было бы вообще не отправлять запрос потому что все ключи есть, но вроде в T-SQL нельзя делать запросы с голыми множествами без таблицы (или можно?), но клиентская машина наверно будет работать очень долго, это ж максимум 13000^2 сравнений данных типа char(12). Какие ещё есть способы?
0
|
|
| 16.08.2006, 22:34 | |
|
Ответы с готовыми решениями:
2
Уменьшение изображения путем разницы + отрисовка этой разницы Типы оптимизация: черная оптимизация, серая оптимизация и белая оптимизация Поменять местами значения множеств a и b без использования дополнительных множеств |
|
2 / 2 / 1
Регистрация: 18.10.2007
Сообщений: 1,748
|
|
| 16.08.2006, 22:55 | |
|
Предлагаю сначала запихнуть данные в таблицы. А затем использовать запрос следующего вида:
SELECT ID FROM Contact WHERE ID IN (SELECT ID FROM TblYes WHERE ID NOT IN (SELECT ID FROM tblNo)) Или использовать JOIN. Но в IN неоптимально в данном случае это пихать.
0
|
|
|
2 / 2 / 1
Регистрация: 18.10.2007
Сообщений: 1,748
|
|
| 16.08.2006, 23:00 | |
|
Кстати, если сервер 2005, то используй EXCEPT & INTERCEPT.
0
|
|
| 16.08.2006, 23:00 | |
|
Помогаю со студенческими работами здесь
3
Доказать равенство множеств с помощью основных законов алгебры множеств
Для заданного набора множеств определить, какая группа множеств представляет их пересечение и объединение Найти объединение, разность, мощности каждого из множеств, для равномощных множеств задать биекции Доказать, что симметрическая разность множеств равна симметрической разности дополнений этих множеств Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
SDL3 для Web (WebAssembly): Работа со звуком через SDL3_mixer
8Observer8 08.02.2026
Содержание блога
Пошагово создадим проект для загрузки звукового файла и воспроизведения звука с помощью библиотеки SDL3_mixer. Звук будет воспроизводиться по клику мышки по холсту на Desktop и по. . .
|
SDL3 для Web (WebAssembly): Основы отладки веб-приложений на SDL3 по USB и Wi-Fi, запущенных в браузере мобильных устройств
8Observer8 07.02.2026
Содержание блога
Браузер Chrome имеет средства для отладки мобильных веб-приложений по USB. В этой пошаговой инструкции ограничимся работой с консолью. Вывод в консоль - это часть процесса. . .
|
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога
Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
|
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
|
|
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога
В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
|
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога
Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
|
SDL3 для Web (WebAssembly): Установка Emscripten SDK (emsdk) и CMake для сборки C и C++ приложений в Wasm
8Observer8 30.01.2026
Содержание блога
Для того чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. . . .
|
SDL3 для Android: Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога
Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
|