72 похожих чатов

Друзья, поясните, что тут происходит! Дидлок в таблице, один процесс делает

SELECT, второй DELETE. Но почему?

31 ответов

28 просмотров

Можно запросы?

pechezerov- Автор вопроса
Yevhen Nedaskivskyi
Можно запросы?

точные запросы не знаю как откопать, длина в логе ограничена и целиком они там не видны. К тому же они формируются ORM. Но предполагаю что первый должен быть вида SELECT * FROM Events WHERE (StartTime >= A OR EndTime <= B) AND EventType = C , а второй просто DELETE FROM Events WHERE Id = X

pechezerov- Автор вопроса
pechezerov
SQL Server,READ COMMITTED

А какая версия MS SQL Server?

Yevhen Nedaskivskyi
СУБД и тип изоляции?

Хм. Похожэ, ещё одной гадости про MSSQL я не знал. Так и не избавились от наследия блокировочника Sybase? Или там всё-таки, видимо, что-то спецыфичное было в этом SELECT -- ну там, триггер какой неявный?

pechezerov- Автор вопроса
Ilya Anfimov
Хм. Похожэ, ещё одной гадости про MSSQL я не знал....

дидлоки, в которые вовлечён триггер, я вчера тоже разбирал, и вроде бы в таких случаях его видно. А что значит "неявный" ?

pechezerov
дидлоки, в которые вовлечён триггер, я вчера тоже ...

Ну, вообще-то вроде на SELECT триггер просто так не повесишь. Но через всякие view и stored procedure можно добиться.

pechezerov- Автор вопроса

А чего странного то в этом дедлоке ? С одной стороны s блокировка с другой x , они не совместимы. Режим изоляции как я понял дефолтный, например можно включить rcsi на базе чтоб читатели не мешали остальным.

Ilushka
А чего странного то в этом дедлоке ? С одной сторо...

Вообще не знал вот про эту вещь, спасибо!

Ilushka
А чего странного то в этом дедлоке ? С одной сторо...

И это очередная причина, почему СУБД должны в первую очередь выбирать программисты... Какая боль выяснять такие вещи в середине проекта!

pechezerov- Автор вопроса
Ilushka
А чего странного то в этом дедлоке ? С одной сторо...

Я вот тоже не знаю что такое RCSI, это какая-то опция которую принято на хайлоаде включать?

pechezerov
Я вот тоже не знаю что такое RCSI, это какая-то оп...

Read committed snapshot isolation , все чтение будет из version store , которое находится в tempdb базе. Минусы если есть долгие транзакции оно может сильно распухать

Как бы select это shared lock, delete - это update lock, они несовместимы, причем, shared может блокировать того, кто хочет получить update, то есть, select может блокировать delete

Yevhen Nedaskivskyi
Согласен. Но почему deadlock?

Скорее всего там hold lock хинт используется в select

pechezerov
точные запросы не знаю как откопать, длина в логе ...

Есть там в SELECT хинт HOLDLOCK ? Хотя даже если и нет, ничего страшного-то нет. Расскажи, в чём твоя ПРОБЛЕМА заключается, и чего ты хочешь добиться?

Yevhen Nedaskivskyi
СУБД и тип изоляции?

Очевидно, что изоляция стандартная, не MVCC

pechezerov- Автор вопроса
Ilya Zviagin
Есть там в SELECT хинт HOLDLOCK ? Хотя даже если ...

Проблема в том, что я не понимаю, почему единственный DELETE, который представлен на графе, связан с блокировкой сразу нескольких страниц

pechezerov
Проблема в том, что я не понимаю, почему единствен...

Не факт, что ваша строчка на одной странице

pechezerov- Автор вопроса
Yevhen Nedaskivskyi
Не факт, что ваша строчка на одной странице

А, вот эта мысль мне в голову не приходила

pechezerov
Проблема в том, что я не понимаю, почему единствен...

Он ищет записи для того чтобы их удалить на многих страницах

pechezerov
Проблема в том, что я не понимаю, почему единствен...

Так несколько индэксов если -- то ничего удивительного.

pechezerov- Автор вопроса
Ilya Anfimov
Так несколько индэксов если -- то ничего удивитель...

А можно поподробнее? Ссылки на матчасть тоже принимаются.

pechezerov
А можно поподробнее? Ссылки на матчасть тоже прини...

В смысле -- если несколько индэксов -- то разумеется INSERT/UPDATE будет несколько страниц менять. И ничего удивительного, в принцыпе, что SELECT тогда шёл другим путём и ужэ заблокировал страницы в другом порядке.

Ilya Anfimov
В смысле -- если несколько индэксов -- то разумеет...

А вторая страница это как раз страница кластерного индекса... Вполне может быть, кстати

Похожие вопросы

Обсуждают сегодня

Гайс, вопрос для разносторонее развитых: читаю стрим с юарта, нада выделять с него фреймы с определенной структурой, если ли чо готовое, или долбаться с ринг буффером? нада у...
Vitaly
9
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
длина пакета фиксированная, или меняется?
Okhsunrog
7
Вот еще странный косяк, подскажите как бороться. Я git clone сделал себе всего embassy и примеры там запускаю. Всё хорошо. Но вот решил в cargo.toml зависимости не как в приме...
Lukutin R2AJP
5
А в каком формате фреймы? Сам формат сейчас придумываешь, или что-то готовое нужно распарсить?
Okhsunrog
5
https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_h_common.erl#L174 https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_olp.erl#L76 15 лет назад...
Maksim Lapshin
20
Добрый вечер, Пока не совсем понимаю как наладить общение между телеграм ботом и ПО для работы с сим боксом. По самому боту так понял: - Нужен некий баланс, который можно поп...
Magic
6
Всем привет, нужна как никогда, нужна помощь с IO в загрузчике. Пишу в code16 после установки сегментных регистров, пишу вывод символа. Пробовал 2 варианта: # 1 mov $0x0E, %a...
Shadow Akira
14
Раз начали говорить про embassy, то присоединюсь со своими парой вопросов. 1) Есть ли сопоставимые аналоги для асинхронного кода в emdebbed? 2) Можно ли внутри задач embassy ...
NI_isx
6
сделал сайт, прикрутил в боте сайт, и виджет логина. как автоматически логинить пользователя в аккаунт(телеграм), при входе с бота?
Александра Чернивецкая
5
Карта сайта