Przykład zapytania SQL w narzędziu klsql2

W tej sekcji przedstawiono przykład zapytania SQL tworzonego przy użyciu narzędzia klsql2.

Poniższe przykłady ilustrują otrzymanie zdarzeń, które wystąpiły na urządzeniach w ciągu ostatnich siedmiu dni, oraz wyświetlenie zdarzeń według czasu ich wystąpienia. Najnowsze zdarzenia są wyświetlane jako pierwsze.

Przykład dla Microsoft SQL Server:

SELECT

/* identyfikator zdarzenia */

e.nId,

 

/* godzina wystąpienia zdarzenia */

e.tmRiseTime,

 

/* wewnętrzna nazwa typu zdarzenia */

e.strEventType,

 

/* wyświetlona nazwa zdarzenia */

e.wstrEventTypeDisplayName,

 

/* wyświetlony opis zdarzenia */

e.wstrDescription,

 

/* nazwa grupy, w której znajduje się zdarzenie */

e.wstrGroupName,

 

/* wyświetlona nazwa urządzenia, na którym wystąpiło zdarzenie */

h.wstrDisplayName,

CAST(((h.nIp / 16777216) & 255) AS varchar(4)) + '.' +

CAST(((h.nIp / 65536) & 255) AS varchar(4)) + '.' +

CAST(((h.nIp / 256) & 255) AS varchar(4)) + '.' +

 

/* adres IP urządzenia, na którym wystąpiło zdarzenie */

CAST(((h.nIp) & 255) AS varchar(4)) as strIp

FROM v_akpub_ev_event e

INNER JOIN v_akpub_host h ON h.nId=e.nHostId

WHERE e.tmRiseTime>=DATEADD(Day, -7, GETUTCDATE())

ORDER BY e.tmRiseTime DESC

Przykład dla PostgreSQL:

SELECT

/* identyfikator zdarzenia */

"e"."nId",

 

/* godzina wystąpienia zdarzenia */

"e"."tmRiseTime",

 

/* wewnętrzna nazwa typu zdarzenia */

"e"."strEventType",

 

/* wyświetlona nazwa zdarzenia */

"e"."wstrEventTypeDisplayName",

 

/* wyświetlony opis zdarzenia */

"e"."wstrDescription",

 

/* wyświetlony opis zdarzenia */

"e"."wstrGroupName",

 

/* wyświetlona nazwa urządzenia, na którym wystąpiło zdarzenie */

"h"."wstrDisplayName",

(

CAST((("h"."nIp" / 16777216 )& 255 ) AS VARCHAR(4)) || '.' ||

CAST((("h"."nIp" / 65536 )& 255 ) AS VARCHAR(4)) || '.' ||

CAST((("h"."nIp" / 256 )& 255 ) AS VARCHAR(4)) || '.' ||

/* adres IP urządzenia, na którym wystąpiło zdarzenie */

CAST((("h"."nIp" )& 255 ) AS VARCHAR(4))

) AS "strIp"

FROM "v_akpub_ev_event" AS "e"

INNER JOIN "v_akpub_host" AS "h" ON "h"."nId" = "e"."nHostId"

WHERE "e"."tmRiseTime" >= NOW() AT TIME ZONE 'utc' + make_interval(days => CAST(-7 AS INT))

ORDER BY "e"."tmRiseTime" DESC ;

Przykład dla MySQL lub MariaDB:

SELECT

/* identyfikator zdarzenia */

`e`.`nId`,

 

/* godzina wystąpienia zdarzenia */

`e`.`tmRiseTime`,

 

/* wewnętrzna nazwa typu zdarzenia */

`e`.`strEventType`,

 

/* wyświetlona nazwa zdarzenia */

`e`.`wstrEventTypeDisplayName`,

 

/* wyświetlony opis zdarzenia */

`e`.`wstrDescription`,

 

/* nazwa grupy urządzeń */

`e`.`wstrGroupName`,

 

/* wyświetlona nazwa urządzenia, na którym wystąpiło zdarzenie */

`h`.`wstrDisplayName`,

CONCAT(

LEFT(CAST(((`h`.`nIp` DIV 1677721) & 255) AS CHAR), 4), '.',

LEFT(CAST(((`h`.`nIp` DIV 65536) & 255) AS CHAR), 4), '.',

LEFT(CAST(((`h`.`nIp` DIV 256) & 255) AS CHAR), 4), '.',

/* adres IP urządzenia, na którym wystąpiło zdarzenie */

LEFT(CAST(((`h`.`nIp`) & 255) AS CHAR), 4)

) AS `strIp`

FROM `v_akpub_ev_event` AS `e`

INNER JOIN `v_akpub_host` AS `h` ON `h`.`nId` = `e`.`nHostId`

WHERE `e`.`tmRiseTime` >= ADDDATE( UTC_TIMESTAMP( ) , INTERVAL -7 DAY)

ORDER BY `e`.`tmRiseTime` DESC ;

Zobacz również:

Konfigurowanie eksportowania zdarzeń do systemów SIEM

Przejdź do góry