%PDF- %PDF-
Direktori : /home/bitrix/www/bitrix/modules/perfmon/classes/general/ |
Current File : /home/bitrix/www/bitrix/modules/perfmon/classes/general/error.php |
<?php class CPerfomanceError { public static function Delete($arFilter) { global $DB; $obQueryWhere = new CSQLWhere; $obQueryWhere->SetFields(array( "HIT_ID" => array( "TABLE_ALIAS" => "e", "FIELD_NAME" => "HIT_ID", "FIELD_TYPE" => "int", "JOIN" => false, ), "ERRNO" => array( "TABLE_ALIAS" => "e", "FIELD_NAME" => "ERRNO", "FIELD_TYPE" => "int", "JOIN" => false, ), "ERRFILE" => array( "TABLE_ALIAS" => "e", "FIELD_NAME" => "ERRFILE", "FIELD_TYPE" => "string", "JOIN" => false, ), "ERRSTR" => array( "TABLE_ALIAS" => "e", "FIELD_NAME" => "ERRSTR", "FIELD_TYPE" => "string", "JOIN" => false, ), "ERRLINE" => array( "TABLE_ALIAS" => "e", "FIELD_NAME" => "ERRLINE", "FIELD_TYPE" => "int", "JOIN" => false, ), )); $strSql = " DELETE FROM b_perf_error "; if (!is_array($arFilter)) $arFilter = array(); if ($strQueryWhere = $obQueryWhere->GetQuery($arFilter)) { $strSql .= " WHERE ".$strQueryWhere." "; } return $DB->Query($strSql, false, "File: ".__FILE__."<br>Line: ".__LINE__); } public static function GetList($arSelect, $arFilter, $arOrder, $bGroup = false) { global $DB; if (!is_array($arSelect)) $arSelect = array(); if (count($arSelect) < 1) $arSelect = array( "ID", "HIT_ID", "ERRNO", "ERRFILE", "ERRLINE", "ERRSTR", ); if (!is_array($arOrder)) $arOrder = array(); if (count($arOrder) < 1) $arOrder = array( "HIT_ID" => "DESC", "ID" => "DESC", ); $arQueryOrder = array(); foreach ($arOrder as $strColumn => $strDirection) { $strColumn = strtoupper($strColumn); $strDirection = strtoupper($strDirection) == "ASC"? "ASC": "DESC"; switch ($strColumn) { case "ID": case "HIT_ID": case "ERRNO": case "ERRFILE": case "ERRLINE": case "ERRSTR": $arSelect[] = $strColumn; $arQueryOrder[$strColumn] = $strColumn." ".$strDirection; break; case "COUNT": if ($bGroup) { $arSelect[] = $strColumn; $arQueryOrder[$strColumn] = $strColumn." ".$strDirection; } break; } } $arQueryGroup = array(); $arQuerySelect = array(); foreach ($arSelect as $strColumn) { $strColumn = strtoupper($strColumn); switch ($strColumn) { case "ID": case "HIT_ID": if (!$bGroup) $arQuerySelect[$strColumn] = "e.".$strColumn; break; case "ERRNO": case "ERRFILE": case "ERRLINE": case "ERRSTR": if ($bGroup) $arQueryGroup[$strColumn] = "e.".$strColumn; $arQuerySelect[$strColumn] = "e.".$strColumn; break; case "COUNT": if ($bGroup) { $arQuerySelect[$strColumn] = "COUNT(e.ID) ".$strColumn; } break; } } $obQueryWhere = new CSQLWhere; $obQueryWhere->SetFields(array( "HIT_ID" => array( "TABLE_ALIAS" => "e", "FIELD_NAME" => "HIT_ID", "FIELD_TYPE" => "int", "JOIN" => false, ), "ERRNO" => array( "TABLE_ALIAS" => "e", "FIELD_NAME" => "ERRNO", "FIELD_TYPE" => "int", "JOIN" => false, ), "ERRFILE" => array( "TABLE_ALIAS" => "e", "FIELD_NAME" => "ERRFILE", "FIELD_TYPE" => "string", "JOIN" => false, ), "ERRSTR" => array( "TABLE_ALIAS" => "e", "FIELD_NAME" => "ERRSTR", "FIELD_TYPE" => "string", "JOIN" => false, ), "ERRLINE" => array( "TABLE_ALIAS" => "e", "FIELD_NAME" => "ERRLINE", "FIELD_TYPE" => "int", "JOIN" => false, ), )); if (count($arQuerySelect) < 1) $arQuerySelect = array("ID" => "e.ID"); $strSql = " SELECT ".implode(", ", $arQuerySelect)." FROM b_perf_error e "; if (!is_array($arFilter)) $arFilter = array(); if ($strQueryWhere = $obQueryWhere->GetQuery($arFilter)) { $strSql .= " WHERE ".$strQueryWhere." "; } if ($bGroup && count($arQueryGroup) > 0) { $strSql .= " GROUP BY ".implode(", ", $arQueryGroup)." "; } if (count($arQueryOrder) > 0) { $strSql .= " ORDER BY ".implode(", ", $arQueryOrder)." "; } return $DB->Query($strSql, false, "File: ".__FILE__."<br>Line: ".__LINE__); } public static function Clear() { global $DB; return $DB->Query("TRUNCATE TABLE b_perf_error"); } }