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 ответов

13 просмотров

сделай в селекте 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. Так мб он подключился через локалхост кликха

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

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

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...
~
13
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
Ребят в СИ можно реализовать ООП?
Николай
33
Как передать управляющий символ в открытую через CreateProcess консоль? Собсна, есть процедура: procedure TRedirectThread.WriteData(Data: OEMString); var Written: Cardinal;...
Serjone
6
в JclConsole объявлено так: function CtrlHandler(CtrlType: DWORD): BOOL; stdcall; - где ваше объявление с stdcall? у вас на картинке нет stdcall
Karagy
8
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
program test; {$mode delphi} procedure proc(v: int32); overload; begin end; procedure proc(v: int64); overload; begin end; var x: uint64; begin proc(x); end. Уж не знаю...
notme
6
Карта сайта