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

Добрый день! подскажите пж как можно узнать кто удалил данные

из таблицы за определнный день?

пробовал такой запрос:

SELECT *
FROM system.query_log
WHERE event_date >= '2023-09-18' and
query LIKE '%target_table%'
AND type = 'QueryFinish' and query LIKE '%DELETE%' OR query LIKE '%TRUNCATE%'

получил данные но в поле user какие то странные значения ::ffff:0.0.0.0.

как написать правильный запрос и как найти чела который удалил данные?

3 ответов

16 просмотров

сделай в селекте select user from .. и у тебя в whee косяк , нужно скобки в месте где (query LIKE '%DELETE%' OR query LIKE '%TRUNCATE%')

1. (самое главное) если у ваших пользователей есть права на truncate, они случайно не под одним логином в базу ходят? 2. как правильно заметили, вы неправильно скомбинировали AND и OR в WHERE, вспоминайте их приоритеты, используйте скобки 3. несколько я понимаю, если у вас кластер, то на каждой ноде свой query_log. если кто-то удалил данные из локальной таблицы на одной ноде, а вы его ловите запросом на другой, то его вы не увидите, пока не будете читать через cluster('', system.query.log) 4. ваш запрос благополучно пропустит запросы "... delete where...", "truncate table...", используйте ILIKE вместо LIKE https://fiddle.clickhouse.com/57689eb0-0590-4c04-880d-80f7c4987c9e

> ::ffff:0.0.0.0. Так мб он подключился через локалхост кликха

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

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

Господа, а что сейчас вообще с рынком труда на делфи происходит? Какова ситуация?
Rꙮman Yankꙮvsky
29
А вообще, что может смущать в самой Julia - бы сказал, что нет единого стандартного подхода по многим моментам, поэтому многое выглядит как "хаки" и произвол. Короче говоря, с...
Viktor G.
2
30500 за редактор? )
Владимир
47
а через ESC-код ?
Alexey Kulakov
29
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
У меня есть функция где происходит это: write_bit(buffer, 1); write_bit(buffer, 0); write_bit(buffer, 1); write_bit(buffer, 1); write_bit(buffer, 1); w...
~
14
Добрый день! Скажите пожалуйста, а какие программы вы бы рекомендовали написать для того, чтобы научиться управлять памятью? Можно написать динамический массив, можно связный ...
Филипп
7
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
Ребят в СИ можно реализовать ООП?
Николай
33
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
Карта сайта