PDA

View Full Version : Counting Bans Problem - Won't Show


ZomgStuff
05-24-2007, 02:11 AM
Well I created my own page, /ban.php and I created a template for it.

The problem is, in the php file I have this
// Count the total bans
$totalbans = $db->query_first_slave("
SELECT COUNT(userid)
FROM userban

");


That counts how many bans there have been in the past, not active, but total.

I've run the query in phpmyadmin and it works fine and returns 45.
The problem comes when I'm using my template, I use this
Total Bans: $totalbans
and it doesn't display a number. What am I doing wrong?

Thanks in advance.

Michael Morris
05-24-2007, 04:46 AM
Well I created my own page, /ban.php and I created a template for it.

The problem is, in the php file I have this
// Count the total bans
$totalbans = $db->query_first_slave("
SELECT COUNT(userid)
FROM userban

");


That counts how many bans there have been in the past, not active, but total.

I've run the query in phpmyadmin and it works fine and returns 45.
The problem comes when I'm using my template, I use this
Total Bans: $totalbans
and it doesn't display a number. What am I doing wrong?

Thanks in advance.

The code should be
// Count the total bans
$totalbans = $db->query_first_slave("
SELECT COUNT(userid) AS bans
FROM userban

");


The template should reference $totalbans[bans]

The method query_first_slave returns the first row as an array - even if there is only one element.

ZomgStuff
05-24-2007, 11:04 AM
Ah, didn't work ;-( I tried like 50 different codes last night. Well now I'm glad the code is right but tere is something wrong. It doesn't display the number.

My msn is twolvesfan624@msn.com and aim is twolvesfan369, I think my problem lies with something else. Treat be as a noob to this. I think I'm forgetting a vital step.

By the way I used this tutorial to create a new page.
https://vborg.vbsupport.ru/showthread.php?t=62164&highlight=create+your+own+page


Edit, so here is my php code
<?php

// ####################### SET PHP ENVIRONMENT ###########################
error_reporting(E_ALL & ~E_NOTICE);

// #################### DEFINE IMPORTANT CONSTANTS #######################
define('NO_REGISTER_GLOBALS', 1);
define('THIS_SCRIPT', 'ban'); // change this depending on your filename

// ################### PRE-CACHE TEMPLATES AND DATA ######################
// get special phrase groups
$phrasegroups = array(

);

// get special data templates from the datastore
$specialtemplates = array(

);

// pre-cache templates used by all actions
$globaltemplates = array(
'BAN',
);

// pre-cache templates used by specific actions
$actiontemplates = array(

);





// ######################### REQUIRE BACK-END ############################
require_once('./global.php');


// ################################################## #####################
// ######################## START MAIN SCRIPT ############################
// ################################################## #####################

$navbits = array();
$navbits[$parent] = 'Ban Page';

$navbits = construct_navbits($navbits);
eval('$navbar = "' . fetch_template('navbar') . '";');
eval('print_output("' . fetch_template('BAN') . '");');

// Count the total bans
$totalbans = $db->query_first_slave("
SELECT COUNT(userid) AS bans
FROM userban

");



?>

and here is my template

$stylevar[htmldoctype]
<html dir="$stylevar[textdirection]" lang="$stylevar[languagecode]">
<head>
<title>$vboptions[bbtitle]</title>
$headinclude
</head>
<body>
$header

$navbar

<table class="tborder" cellpadding="$stylevar[cellpadding]" cellspacing="$stylevar[cellspacing]" border="0" width="100%" align="center">
<tr>
<td class="tcat"><center><h1>BAN LIST</h1></center></td>
</tr>
<tr>
<td class="alt1">
<center>$vboptions[bbtitle] Ban Statistics</center>
Total Bans: $totalbans[bans]
</td>
</tr>
</table>

$footer
</body>

</html>

Michael Morris
05-24-2007, 12:02 PM
Ah, didn't work ;-( I tried like 50 different codes last night. Well now I'm glad the code is right but tere is something wrong. It doesn't display the number.

My msn is twolvesfan624@msn.com and aim is twolvesfan369, I think my problem lies with something else. Treat be as a noob to this. I think I'm forgetting a vital step.

By the way I used this tutorial to create a new page.
https://vborg.vbsupport.ru/showthread.php?t=62164&highlight=create+your+own+page


Edit, so here is my php code
<?php

// ####################### SET PHP ENVIRONMENT ###########################
error_reporting(E_ALL & ~E_NOTICE);

// #################### DEFINE IMPORTANT CONSTANTS #######################
define('NO_REGISTER_GLOBALS', 1);
define('THIS_SCRIPT', 'ban'); // change this depending on your filename

// ################### PRE-CACHE TEMPLATES AND DATA ######################
// get special phrase groups
$phrasegroups = array(

);

// get special data templates from the datastore
$specialtemplates = array(

);

// pre-cache templates used by all actions
$globaltemplates = array(
'BAN',
);

// pre-cache templates used by specific actions
$actiontemplates = array(

);





// ######################### REQUIRE BACK-END ############################
require_once('./global.php');


// ################################################## #####################
// ######################## START MAIN SCRIPT ############################
// ################################################## #####################

$navbits = array();
$navbits[$parent] = 'Ban Page';

$navbits = construct_navbits($navbits);
eval('$navbar = "' . fetch_template('navbar') . '";');
eval('print_output("' . fetch_template('BAN') . '");');

// Count the total bans
$totalbans = $db->query_first_slave("
SELECT COUNT(userid) AS bans
FROM userban

");



?>

and here is my template

$stylevar[htmldoctype]
<html dir="$stylevar[textdirection]" lang="$stylevar[languagecode]">
<head>
<title>$vboptions[bbtitle]</title>
$headinclude
</head>
<body>
$header

$navbar

<table class="tborder" cellpadding="$stylevar[cellpadding]" cellspacing="$stylevar[cellspacing]" border="0" width="100%" align="center">
<tr>
<td class="tcat"><center><h1>BAN LIST</h1></center></td>
</tr>
<tr>
<td class="alt1">
<center>$vboptions[bbtitle] Ban Statistics</center>
Total Bans: $totalbans[bans]
</td>
</tr>
</table>

$footer
</body>

</html>

You must run the query BEFORE you eval the template. These statements:

eval('$navbar = "' . fetch_template('navbar') . '";');
eval('print_output("' . fetch_template('BAN') . '");');

Should be the last two in your code. Whenever print_output is called it issues an exit - you never come out of that eval statement and never reach the query.

ZomgStuff
05-24-2007, 07:16 PM
You must run the query BEFORE you eval the template. These statements:

eval('$navbar = "' . fetch_template('navbar') . '";');
eval('print_output("' . fetch_template('BAN') . '");');

Should be the last two in your code. Whenever print_output is called it issues an exit - you never come out of that eval statement and never reach the query.

I love you.

Edit:
How can I display an array? IE: Display all the ban id's and say the reason.

sonichero
05-25-2007, 05:56 AM
for anyone who doesnt know, this is what he wants to do

http://forums.facepunchstudios.com/showbans.php?