%PDF- %PDF-
Mini Shell

Mini Shell

Direktori : /home/bitrix/www/bitrix/modules/perfmon/classes/general/
Upload File :
Create Path :
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");
	}
}

Zerion Mini Shell 1.0