Этот баннер — требование Роскомнадзора для исполнения 152 ФЗ.
«На сайте осуществляется обработка файлов cookie, необходимых для работы сайта, а также для анализа использования сайта и улучшения предоставляемых сервисов с использованием метрической программы Яндекс.Метрика. Продолжая использовать сайт, вы даёте согласие с использованием данных технологий».
Политика конфиденциальности

Новые сообщения [новые:0]
Дайджест
Горячие темы
Избранное [новые:0]
Форумы
Пользователи
Статистика
Статистика нагрузки
Мод. лог
Поиск
|
|
06.02.2021, 10:55
|
|||
|---|---|---|---|
|
|||
DELETE FROM TABLE1 T1 WHERE ID2 in (SELECT ID2 FROM TABLE2 BL WHERE T2_id = ?) |
|||
|
#18+
День добрый, Есть таблицы TABLE1 и TABLE2 (условно), TABLE2 небольшая таблица, по списку значений в которой надо удалить строки из большой таблицы TABLE1: Код: plsql 1. 2. 3. Нормальный план выглядит так, т.е. выборка небольшого количества(100-5000) строк из TABLE2 и удаление по ним из T1 : Код: plsql 1. 2. 3. 4. 5. 6. 7. 8. И этот план я вижу сейчас, но в логах программы, идет такой план, где всё вывернуто наизнанку, и запрос работает неэффективно и долго: Код: plsql 1. 2. 3. 4. 5. 6. 7. 8. 9. 10. 11. Можно принудительно получить правильный план с помощью хинтов: Код: plsql 1. 2. 3. Но хотелось бы разобраться как такое возможно. К сожалению у меня нет доступа к серверу(linux), с которого запускалась программа. Информацию получил по предоставленным логам, анализируя производительность(жалобы на медленную работу). Может ли быть такое, что на момент работы программы были одни настройки в Init.ora(OPTIMIZER_INDEX_CACHING....), а сейчас поменяли, и поэтому не могу получить "плохой" план, или тут есть еще какие-то варианты? Например влияние клиента Oracle и его настроек(sqlnet.ora, переменные среды, ...) , или нет такого? В самой программе нет ALTER SESSION.... для изменения параметров CBO. У меня доступ только к логам, а повторно программу будут запускать через несколько недель. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
|
|
|
06.02.2021, 12:21
|
|||
|---|---|---|---|
DELETE FROM TABLE1 T1 WHERE ID2 in (SELECT ID2 FROM TABLE2 BL WHERE T2_id = ?) |
|||
|
#18+
412M ... |
|||
|
:
Нравится:
Не нравится:
|
|||
|
|
|

start [/forum/topic.php?fid=52&mobile=1&tid=1880461]: |
0ms |
get settings: |
10ms |
get forum list: |
11ms |
check forum access: |
3ms |
check topic access: |
3ms |
track hit: |
54ms |
get topic data: |
9ms |
get forum data: |
2ms |
get page messages: |
32ms |
get tp. blocked users: |
1ms |
| others: | 14ms |
| total: | 139ms |

| 0 / 0 |
