Stasy11
@Stasy11
The best epta

Как подсчитать количество записей в таблице с помощью php и внести правки в файл?

Есть такой вот скрипт, который выводит таблицу истории транзакций.
<?php	
if( ! defined( 'DATALIFEENGINE' ) ) die( "Hacking attempt!" );
define( 'MODULE_DATA', ENGINE_DIR . "/data/billing" );
$widjet = '';
$cache = preg_replace("/[^a-zA-Z0-9\s]/", "", $cache );
$theme = preg_replace("/[^a-zA-Z0-9\s]/", "", $theme );
if( $cache )
{
    $widjet = dle_cache( 'billing_' . $cache );
}
if( ! $widjet )
{
    $params = array();
    if( $plugin )
    {
        $params[] = 'history_plugin = \'' . $db->safesql( $plugin ) . '\'';
    }
    if( $plugin_id )
    {
        $params[] = 'history_plugin_id = \'' . intval( $plugin_id ) . '\'';
    }
    if( $login )
    {
        $params[] = 'history_user_name = \'' . $db->safesql( $login ) . '\'';
    }
    if( isset( $plus_min ) )
    {
        $params[] = 'history_plus >= \'' . $db->safesql( $plus_min ) . '\'';
    }
    if( isset( $plus_max ) )
    {
        $params[] = 'history_plus <= \'' . $db->safesql( $plus_max ) . '\'';
    }
    if( isset( $minus_min ) )
    {
        $params[] = 'history_minus >= \'' . $db->safesql( $minus_min ) . '\'';
    }
    if( isset( $minus_max ) )
    {
        $params[] = 'history_minus <= \'' . $db->safesql( $minus_max ) . '\'';
    }
    if( $time_start )
    {
        $params[] = 'history_date >= \'' . strtotime( $time_start ) . '\'';
    }
    if( $time_end )
    {
        $params[] = 'history_date <= \'' . strtotime( $time_end ) . '\'';
    }
    if( ! in_array( $sort, array('history_plus', 'history_minus', 'history_balance', 'history_date') ) )
    {
        $sort = 'history_id';
    }
    if( $sort_by != 'desc' )
    {
        $sort_by = 'asc';
    }
    if( ! intval( $limit ) )
    {
        $limit = 10;
    }
    if( ! $theme )
    {
        $theme = 'history';
    }
    if( ! $tpl = @file_get_contents( ROOT_DIR . '/templates/' . $config['skin'] . '/billing/widgets/' . $theme . '.tpl' ) )
    {
        echo 'Error file load: ' . $theme . '.tpl';
    }
    else
    {
        $buff = '';
        $db->query( "SELECT * FROM " . USERPREFIX . "_billing_history
                        " . ( count($params) ? 'WHERE ' . implode(' and ', $params) : '') . "
                        ORDER BY {$sort} {$sort_by} LIMIT {$limit}" );
        while ( $row = $db->get_row() )
        {
            $buff = $tpl;
            $buff = str_replace("{date}", langdate('d.m.Y', $row['history_date']), $buff);
            $buff = str_replace("{time}", langdate('H:i', $row['history_date']), $buff);
			$buff = str_replace("{comment}", $row['history_text'], $buff);
            $buff = str_replace("{comment_shot}", strip_tags($row['history_text']), $buff);
			$buff = str_replace("{plugin}", $row['history_plugin'], $buff);
			$buff = str_replace("{plugin.id}", $row['history_plugin_id'], $buff);
            $buff = str_replace("{user}", $row['history_user_name'], $buff);
			$buff = str_replace("{user_urlencode}", urlencode($row['history_user_name']), $buff);
			$buff = str_replace("{sum}", $row['history_plus']	? "<font color=\"green\">+{$row['history_plus']} {$row['history_currency']}</font>"
																		: "<font color=\"red\" id=\"net1\">-{$row['history_minus']} {$row['history_currency']}</font>", $buff);
            $widjet .= $buff;
        }
        if( $cache )
        {
            create_cache( 'billing_' . $cache, $widjet);
        }
    }
}
echo $widjet;
?>


Но в нем нет возможности тегом типа {tag} выводить общее количество записей и выводить записи с плюсом и с минусом. В php совсем слаб, как бы такое реализовать? и вообще возможно ли такое?
  • Вопрос задан
  • 49 просмотров
Пригласить эксперта
Ответы на вопрос 1
KodyWiremane
@KodyWiremane
Пони, Debian, LEMP, LAN, любитель
Это Wordpress?

$db какой тип имеет?

Если wpdb (WordPress Database Access Abstraction Object), то $db->num_rows должно содержать число строк в ответе на последний запрос, далее аналогично с остальными заменами … = str_replace("{tag}", $db->num_rows, …).

А что с плюсами и минусами не так, в коде вроде бы присутствует соответствующий фрагмент?

upd: … = str_replace("{tag}", $db->num_rows(), …)
Ответ написан
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Войти через центр авторизации
Похожие вопросы
YCLIENTS Москва
от 200 000 до 350 000 ₽
Ведисофт Екатеринбург
от 25 000 ₽
ИТЦ Аусферр Магнитогорск
от 100 000 до 160 000 ₽