cdoyle Posted April 4, 2008 Share Posted April 4, 2008 Hi, I'm trying to modify a ezRPG page, to include a field from an additional table I created. In the 'players' table I added a field named 'City_ID' and I've added a new table called Cities, that holds all the Cities. It's fields are City_ID, City_Name. In the code below, it outputs from $result the info about the player. I want the City Name to appear in this part of the code echo "<td width=\"20%\">" . $result['City_Name'] ."</td>\n"; I'm thinking I need to do a Left Join? But I'm not sure where, I need to do it. I thought maybe here $query = "select * from `players` where `id`!= ? and "; but I'm not sure.. Here is the part of the code I think it needs to go, I wanted to attach the page, but I get an error when I try. case "search": //Check in case somebody entered 0 $_GET['fromlevel'] = ($_GET['fromlevel'] == 0)?"":$_GET['fromlevel']; $_GET['tolevel'] = ($_GET['tolevel'] == 0)?"":$_GET['tolevel']; //Construct query $query = "select * from `players` where `id`!= ? and "; $query .= ($_GET['username'] != "")?"`username` LIKE ? and ":""; $query .= ($_GET['fromlevel'] != "")?"`level` >= ? and ":""; $query .= ($_GET['tolevel'] != "")?"`level` <= ? and ":""; $query .= ($_GET['alive'] == "1")?"`hp` > 20 ":"`hp` < 20 "; $query .= "limit 20"; //Construct values array for adoDB $values = array(); array_push($values, $player->id); //Make sure battle search doesn't show self if ($_GET['username'] != "") { array_push($values, "%".trim($_GET['username'])."%"); //Add username value for search } //Add level range for search if ($_GET['fromlevel']) { array_push($values, intval($_GET['fromlevel'])); } if ($_GET['tolevel']) { array_push($values, intval($_GET['tolevel'])); } include("templates/private_header.php"); //Display search form again echo "<legend><b>Search for a player</b></legend>\n"; echo "<form method=\"get\" action=\"battle2.php\">\n<input type=\"hidden\" name=\"act\" value=\"search\" />\n"; echo "<table width=\"100%\">\n"; echo "<tr>\n<td width=\"40%\">Username:</td>\n<td width=\"60%\"><input type=\"text\" name=\"username\" value=\"" . stripslashes($_GET['username']) . "\" /></td>\n</tr>\n"; echo "<tr>\n<td width=\"40%\">Level</td>\n<td width=\"60%\"><input type=\"text\" name=\"fromlevel\" size=\"4\" value=\"" . stripslashes($_GET['fromlevel']) . "\" /> to <input type=\"text\" name=\"tolevel\" size=\"4\" value=\"" . stripslashes($_GET['tolevel']) . "\" /></td>\n</tr>\n"; echo "<tr>\n<td width=\"40%\">Status:</td>\n<td width=\"60%\"><select name=\"alive\" size=\"2\">\n<option value=\"1\""; echo ($_GET['alive'] == 1)?" selected=\"selected\"":""; echo ">Alive</option>\n<option value=\"0\""; echo ($_GET['alive'] == 0)?" selected=\"selected\"":""; echo ">Dead</option>\n</select></td>\n</tr>\n"; echo "<tr><td></td><td><br /><input type=\"submit\" value=\"Search!\" /></td></tr>\n"; echo "</table>\n"; echo "</form>\n"; echo "<br /><br />"; echo "<table width=\"100%\">\n"; echo "<tr><th width=\"30%\">Username</th><th width=\"20%\">Level</th><th width=\"20%\">Location</th><th width=\"30%\">Battle</a></th></tr>\n"; $query = $db->execute($query, $values); //Search! if ($query->recordcount() > 0) //Check if any players were found { $bool = 1; while ($result = $query->fetchrow()) { echo "<tr class=\"row" . $bool . "\">\n"; echo "<td width=\"30%\"><a href=\"profile.php?username=" . $result['username'] . "\">" . $result['username'] . "</a></td>\n"; echo "<td width=\"20%\">" . $result['level'] . "</td>\n"; [b]echo "<td width=\"20%\">" . $result['City_Name'] ."</td>\n";[/b] echo "<td width=\"30%\"><a href=\"battle2.php?act=attack&username=" . $result['username'] . "\">Attack</a></td>\n"; echo "</tr>\n"; $bool = ($bool==1)?2:1; } } else //Display error message { echo "<tr>\n"; echo "<td colspan=\"3\">No players found. Try changing your search criteria.</td>\n"; echo "</tr>\n"; } echo "</table>\n"; include("templates/private_footer.php"); break; default: include("templates/private_header.php"); //The default battle page, giving choice of whether to search for players or to target one echo "<legend><b>Search for a player</b></legend>\n"; echo "<form method=\"get\" action=\"battle2.php\">\n<input type=\"hidden\" name=\"act\" value=\"search\" />\n"; echo "<table width=\"100%\">\n"; echo "<tr>\n<td width=\"40%\">Username:</td>\n<td width=\"60%\"><input type=\"text\" name=\"username\" /></td>\n</tr>\n"; echo "<tr>\n<td width=\"40%\">Level</td>\n<td width=\"60%\"><input type=\"text\" name=\"fromlevel\" size=\"4\" /> to <input type=\"text\" name=\"tolevel\" size=\"4\" /></td>\n</tr>\n"; echo "<tr>\n<td width=\"40%\">Status:</td>\n<td width=\"60%\"><select name=\"alive\" size=\"2\">\n<option value=\"1\" selected=\"selected\">Alive</option>\n<option value=\"0\">Dead</option>\n</select></td>\n</tr>\n"; echo "<tr><td></td><td><br /><input type=\"submit\" value=\"Search!\" /></td></tr>\n"; echo "</table>\n"; echo "</form>\n"; echo "<br /><br />\n"; echo "<legend><b>Attack a player</b></legend>\n"; echo "<form method=\"get\" action=\"battle2.php?act=attack\">\n<input type=\"hidden\" name=\"act\" value=\"attack\" />\n"; echo "Username: <input type=\"text\" name=\"username\" /><br />\n"; echo "<input type=\"submit\" value=\"Battle!\" />\n"; echo "</form>\n"; include("templates/private_footer.php"); break; } ?> Quote Link to comment https://forums.phpfreaks.com/topic/99474-solved-need-help-with-query-left-join/ Share on other sites More sharing options...
fenway Posted April 4, 2008 Share Posted April 4, 2008 Echo $query. Quote Link to comment https://forums.phpfreaks.com/topic/99474-solved-need-help-with-query-left-join/#findComment-509257 Share on other sites More sharing options...
cdoyle Posted April 5, 2008 Author Share Posted April 5, 2008 I'm not sure what you mean? I tried echo "$query"; and it just displayed 'object' the code has while ($result = $query->fetchrow()) If I used $result['city_id'] I get the ID number from the players table from field City_ID. I'm just not sure how to get the city name from the City table and display it. Quote Link to comment https://forums.phpfreaks.com/topic/99474-solved-need-help-with-query-left-join/#findComment-509720 Share on other sites More sharing options...
cdoyle Posted April 5, 2008 Author Share Posted April 5, 2008 anyone else? Quote Link to comment https://forums.phpfreaks.com/topic/99474-solved-need-help-with-query-left-join/#findComment-509963 Share on other sites More sharing options...
fenway Posted April 5, 2008 Share Posted April 5, 2008 I'm not sure what you mean? I tried echo "$query"; and it just displayed 'object' Echo it _before_ you run db_execute(). Quote Link to comment https://forums.phpfreaks.com/topic/99474-solved-need-help-with-query-left-join/#findComment-510019 Share on other sites More sharing options...
cdoyle Posted April 5, 2008 Author Share Posted April 5, 2008 OK, I moved the echo to before that, and it now displays this on the page select * from `players` where `id`!= ? and `hp` > 20 limit 20 Quote Link to comment https://forums.phpfreaks.com/topic/99474-solved-need-help-with-query-left-join/#findComment-510022 Share on other sites More sharing options...
fenway Posted April 6, 2008 Share Posted April 6, 2008 And $values is? Quote Link to comment https://forums.phpfreaks.com/topic/99474-solved-need-help-with-query-left-join/#findComment-510274 Share on other sites More sharing options...
cdoyle Posted April 6, 2008 Author Share Posted April 6, 2008 I searched the page and found this //Construct values array for adoDB $values = array(); array_push($values, $player->id); //Make sure battle search doesn't show self if ($_GET['username'] != "") { array_push($values, "%".trim($_GET['username'])."%"); //Add username value for search } //Add level range for search if ($_GET['fromlevel']) { array_push($values, intval($_GET['fromlevel'])); } if ($_GET['tolevel']) { array_push($values, intval($_GET['tolevel'])); } Quote Link to comment https://forums.phpfreaks.com/topic/99474-solved-need-help-with-query-left-join/#findComment-510355 Share on other sites More sharing options...
cdoyle Posted April 6, 2008 Author Share Posted April 6, 2008 does this help at all? Quote Link to comment https://forums.phpfreaks.com/topic/99474-solved-need-help-with-query-left-join/#findComment-510542 Share on other sites More sharing options...
fenway Posted April 6, 2008 Share Posted April 6, 2008 does this help at all? Nope... I want to know what's in $values when you execute the query. Quote Link to comment https://forums.phpfreaks.com/topic/99474-solved-need-help-with-query-left-join/#findComment-510558 Share on other sites More sharing options...
cdoyle Posted April 6, 2008 Author Share Posted April 6, 2008 Where should I echo $value I've tried both before the query, and after and each time nothing displays on the page. Would it help to post the code to the whole page? I've tried to attach it, but the forum says the directory is not writable when I try to post. Quote Link to comment https://forums.phpfreaks.com/topic/99474-solved-need-help-with-query-left-join/#findComment-510571 Share on other sites More sharing options...
cdoyle Posted April 7, 2008 Author Share Posted April 7, 2008 Is there anything else I can provide that will help? Quote Link to comment https://forums.phpfreaks.com/topic/99474-solved-need-help-with-query-left-join/#findComment-511099 Share on other sites More sharing options...
fenway Posted April 7, 2008 Share Posted April 7, 2008 Well, you're using a prepared statement, and I'm trying to figure out what ends up in the "?"... and it's $values, the array. Quote Link to comment https://forums.phpfreaks.com/topic/99474-solved-need-help-with-query-left-join/#findComment-511215 Share on other sites More sharing options...
cdoyle Posted April 7, 2008 Author Share Posted April 7, 2008 Not sure if this will help, but here is the code to the entire page. <?php /*************************************/ /* ezRPG script */ /* Written by Zeggy */ /* http://code.google.com/p/ezrpg */ /* http://www.bbgamezone.com/ */ /*************************************/ include("lib.php"); define("PAGENAME", "Battle"); $player = check_user($secret_key, $db); switch($_GET['act']) { case "attack": if (!$_GET['username']) //No username entered { header("Location: battle2.php"); break; } //Otherwise, get player data: $query = $db->execute("select * from `players` where `username`=?", array($_GET['username'])); if ($query->recordcount() == 0) //Player doesn't exist { include("templates/private_header.php"); echo "This player doesn't exist!"; include("templates/private_footer.php"); break; } $enemy1 = $query->fetchrow(); //Get player info foreach($enemy1 as $key=>$value) { $enemy->$key = $value; } //Otherwise, check if player has any health if ($enemy->hp < 20) { include("templates/private_header.php"); echo "This player is in the hospital!"; include("templates/private_footer.php"); break; } //Player cannot attack anymore if ($player->energy == 0) { include("templates/private_header.php"); echo "You have no energy left! You must rest a while."; include("templates/private_footer.php"); break; } //Player is dead if ($player->hp == 0) { include("templates/private_header.php"); echo "You already got the crap beat out of you and in the hospital dummy"; include("templates/private_footer.php"); break; } if ($enemy->username == $player->username) { include("templates/private_header.php"); echo "You cannot attack yourself..."; include("templates/private_footer.php"); break; } //Check Player Location if ($player->City_ID <> $enemy->City_ID) { include("templates/private_header.php"); echo "You can't attack someone in a different city.. Geeze just how dumb are you anyways?"; include("templates/private_footer.php"); break; } //Get enemy's bonuses from equipment $query = $db->query("select blueprint_items.effectiveness, blueprint_items.name from `items`, `blueprint_items` where blueprint_items.id=items.item_id and items.player_id=? and blueprint_items.type='weapon' and items.status='equipped'", array($enemy->id)); $enemy->atkbonus = ($query->recordcount() == 1)?$query->fetchrow():0; $query = $db->query("select blueprint_items.effectiveness, blueprint_items.name from `items`, `blueprint_items` where blueprint_items.id=items.item_id and items.player_id=? and blueprint_items.type='armour' and items.status='equipped'", array($enemy->id)); $enemy->defbonus = ($query->recordcount() == 1)?$query->fetchrow():0; //Get player's bonuses from equipment $query = $db->query("select blueprint_items.effectiveness, blueprint_items.name from `items`, `blueprint_items` where blueprint_items.id=items.item_id and items.player_id=? and blueprint_items.type='weapon' and items.status='equipped'", array($player->id)); $player->atkbonus = ($query->recordcount() == 1)?$query->fetchrow():0; $query = $db->query("select blueprint_items.effectiveness, blueprint_items.name from `items`, `blueprint_items` where blueprint_items.id=items.item_id and items.player_id=? and blueprint_items.type='armour' and items.status='equipped'", array($player->id)); $player->defbonus = ($query->recordcount() == 1)?$query->fetchrow():0; //Calculate some variables that will be used $enemy->strdiff = (($enemy->strength - $player->strength) > 0)?($enemy->strength - $player->strength):0; $enemy->vitdiff = (($enemy->vitality - $player->vitality) > 0)?($enemy->vitality - $player->vitality):0; $enemy->agidiff = (($enemy->agility - $player->agility) > 0)?($enemy->agility - $player->agility):0; $player->strdiff = (($player->strength - $enemy->strength) > 0)?($player->strength - $enemy->strength):0; $player->vitdiff = (($player->vitality - $enemy->vitality) > 0)?($player->vitality - $enemy->vitality):0; $player->agidiff = (($player->agility - $enemy->agility) > 0)?($player->agility - $enemy->agility):0; $totalstr = $enemy->strength + $player->strength; $totalvit = $enemy->vitality + $player->vitality; $totalagi = $enemy->agility + $player->agility; //Calculate the damage to be dealt by each player (dependent on strength and vitality) $enemy->maxdmg = (($enemy->strength * 2) + $enemy->atkbonus['effectiveness']) - ($player->defbonus['effectiveness']); $enemy->maxdmg = $enemy->maxdmg - intval($enemy->maxdmg * ($player->vitdiff / $totalvit)); $enemy->maxdmg = ($enemy->maxdmg <= 2)?2:$enemy->maxdmg; //Set 2 as the minimum damage $enemy->mindmg = (($enemy->maxdmg - 4) < 1)?1:($enemy->maxdmg - 4); //Set a minimum damage range of maxdmg-4 $player->maxdmg = (($player->strength * 2) + $player->atkbonus['effectiveness']) - ($enemy->defbonus['effectiveness']); $player->maxdmg = $player->maxdmg - intval($player->maxdmg * ($enemy->vitdiff / $totalvit)); $player->maxdmg = ($player->maxdmg <= 2)?2:$player->maxdmg; //Set 2 as the minimum damage $player->mindmg = (($player->maxdmg - 4) < 1)?1:($player->maxdmg - 4); //Set a minimum damage range of maxdmg-4 //Calculate battle 'combos' - how many times in a row a player can attack (dependent on agility) $enemy->combo = ceil($enemy->agility / $player->agility); $enemy->combo = ($enemy->combo > 3)?3:$enemy->combo; $player->combo = ceil($player->agility / $enemy->agility); $player->combo = ($player->combo > 3)?3:$player->combo; //Calculate the chance to miss opposing player $enemy->miss = intval(($player->agidiff / $totalagi) * 100); $enemy->miss = ($enemy->miss > 20)?20:$enemy->miss; //Maximum miss chance of 20% (possible to change in admin panel?) $enemy->miss = ($enemy->miss <= 5)?5:$enemy->miss; //Minimum miss chance of 5% $player->miss = intval(($enemy->agidiff / $totalagi) * 100); $player->miss = ($player->miss > 20)?20:$player->miss; //Maximum miss chance of 20% $player->miss = ($player->miss <= 5)?5:$player->miss; //Minimum miss chance of 5% $battlerounds = 50; //Maximum number of rounds/turns in the battle. Changed in admin panel? $output = ""; //Output message //While somebody is still alive, battle! while ($enemy->hp > 0 && $player->hp > 0 && $battlerounds > 0) { $attacking = ($player->agility >= $enemy->agility)?$player:$enemy; $defending = ($player->agility >= $enemy->agility)?$enemy:$player; for($i = 0;$i < $attacking->combo;$i++) { //Chance to miss? $misschance = intval(rand(0, 100)); if ($misschance <= $attacking->miss) { $output .= $attacking->username . " tried to attack " . $defending->username . " but missed!<br />"; } else { $damage = rand($attacking->mindmg, $attacking->maxdmg); //Calculate random damage $defending->hp -= $damage; $output .= ($player->username == $defending->username)?"<font color=\"red\">":"<font color=\"green\">"; $output .= $attacking->username . " attacks " . $defending->username . " for <b>" . $damage . "</b> damage! ("; $output .= ($defending->hp > 0)?$defending->hp . " HP left":"Dead"; $output .= ")<br />"; $output .= "</font>"; //Check if anybody is dead if ($defending->hp <= 0) { $player = ($player->agility >= $enemy->agility)?$attacking:$defending; $enemy = ($player->agility >= $enemy->agility)?$defending:$attacking; break 2; //Break out of the for and while loop, but not the switch structure } } $battlerounds--; if ($battlerounds <= 0) { break 2; //Break out of for and while loop, battle is over! } } for($i = 0;$i < $defending->combo;$i++) { //Chance to miss? $misschance = intval(rand(0, 100)); if ($misschance <= $defending->miss) { $output .= $defending->username . " tried to attack " . $attacking->username . " but missed!<br />"; } else { $damage = rand($defending->mindmg, $defending->maxdmg); //Calculate random damage $attacking->hp -= $damage; $output .= ($player->username == $defending->username)?"<font color=\"green\">":"<font color=\"red\">"; $output .= $defending->username . " attacks " . $attacking->username . " for <b>" . $damage . "</b> damage! ("; $output .= ($attacking->hp > 0)?$attacking->hp . " HP left":"Dead"; $output .= ")<br />"; $output .= "</font>"; //Check if anybody is dead if ($attacking->hp <= 0) { $player = ($player->agility >= $enemy->agility)?$attacking:$defending; $enemy = ($player->agility >= $enemy->agility)?$defending:$attacking; break 2; //Break out of the for and while loop, but not the switch structure } } $battlerounds--; if ($battlerounds <= 0) { break 2; //Break out of for and while loop, battle is over! } } $player = ($player->agility >= $enemy->agility)?$attacking:$defending; $enemy = ($player->agility >= $enemy->agility)?$defending:$attacking; } if ($player->hp <= 0) { //Calculate losses $exploss1 = $player->level * 6; $exploss2 = (($player->level - $enemy->level) > 0)?($enemy->level - $player->level) * 4:0; $exploss = $exploss1 + $exploss2; $goldloss = intval(0.2 * $player->gold); $goldloss = intval(rand(1, $goldloss)); $output .= "<br /><u>You were defeated by " . $enemy->username . "!</u><br />"; $output .= "<br />You lost <b>" . $exploss . "</b> EXP and <b>" . $goldloss . "</b> gold."; $exploss3 = (($player->exp - $exploss) <= 0)?$player->exp:$exploss; $goldloss2 = (($player->gold - $goldloss) <= 0)?$player->gold:$goldloss; //Update player (the loser) $query = $db->execute("update `players` set `energy`=?, `exp`=?, `gold`=?, `deaths`=?, `hp`=0 where `id`=?", array($player->energy - 1, $player->exp - $exploss3, $player->gold - $goldloss2, $player->deaths + 1, $player->id)); //Update enemy (the winner) if ($exploss + $enemy->exp < $enemy->maxexp) { $query = $db->execute("update `players` set `exp`=?, `gold`=?, `kills`=?, `hp`=? where `id`=?", array($enemy->exp + $exploss, $enemy->gold + $goldloss, $enemy->kills + 1, $enemy->hp, $enemy->id)); //Add log message for winner $logmsg = "You were attacked by <a href=\"profile.php?id=" . $player->username . "\">" . $player->username . "</a> but you won!<br />\nYou gained " . $exploss . " EXP and " . $goldloss . " gold."; addlog($enemy->id, $logmsg, $db); } else //Defender has gained a level! =) { $query = $db->execute("update `players` set `stat_points`=?, `level`=?, `maxexp`=?, `exp`=?, `gold`=?, `kills`=?, `hp`=?, `maxhp`=? where `id`=?", array($enemy->stat_points + 3, $enemy->level + 1, ($enemy->level+1) * 70 - 20, ($enemy->exp + $exploss) - $enemy->maxexp, $enemy->gold + $goldloss, $enemy->kills + 1, $enemy->maxhp + 30, $enemy->maxhp + 30, $enemy->id)); //Add log message for winner $logmsg = "You were attacked by <a href=\"profile.php?id=" . $player->username . "\">" . $player->username . "</a> but you won!<br />\nYou gained a level and " . $goldloss . " gold."; addlog($enemy->id, $logmsg, $db); } } else if ($enemy->hp <= 0) { //Calculate losses $expwin1 = $enemy->level * 6; $expwin2 = (($player->level - $enemy->level) > 0)?$expwin1 - (($player->level - $enemy->level) * 3):$expwin1 + (($player->level - $enemy->level) * 3); $expwin2 = ($expwin2 <= 0)?1:$expwin2; $expwin3 = round(0.6 * $expwin2); $expwin = ceil(rand($expwin3, $expwin2)); $goldwin = ceil(0.2 * $enemy->gold); $goldwin = intval(rand(1, $goldwin)); $output .= "<br /><u>You defeated " . $enemy->username . "!</u><br />"; $output .= "<br />You won <b>" . $expwin . "</b> EXP and <b>" . $goldwin . "</b> gold."; if ($expwin + $player->exp >= $player->maxexp) //Player gained a level! { //Update player, gained a level $output .= "<br /><b>You leveled up!</b>"; $newexp = $expwin + $player->exp - $player->maxexp; $query = $db->execute("update `players` set `stat_points`=?, `level`=?, `maxexp`=?, `maxhp`=?, `exp`=?, `gold`=?, `kills`=?, `hp`=?, `energy`=? where `id`=?", array($player->stat_points + 3, $player->level + 1, ($player->level+1) * 70 - 20, $player->maxhp + 30, $newexp, $player->gold + $goldwin, $player->kills + 1, $player->maxhp + 30, $player->energy - 1, $player->id)); } else { //Update player $query = $db->execute("update `players` set `exp`=?, `gold`=?, `kills`=?, `hp`=?, `energy`=? where `id`=?", array($player->exp + $expwin, $player->gold + $goldwin, $player->kills + 1, $player->hp, $player->energy - 1, $player->id)); } //Add log message $logmsg = "You were attacked by <a href=\"profile.php?id=" . $player->username . "\">" . $player->username . "</a> and you were defeated..."; addlog($enemy->id, $logmsg, $db); //Update enemy (who was defeated) $query = $db->execute("update `players` set `hp`=0, `deaths`=? where `id`=?", array($enemy->deaths + 1, $enemy->id)); } else { $output .= "<br /><u>Both of you were too tired to finish the battle! Nobody won...</u>"; $query = $db->execute("update `players` set `hp`=?, `energy`=? where `id`=?", array($player->hp, $player->energy - 1, $player->id)); $query = $db->execute("update `players` set `hp`=? where `id`=?", array($enemy->hp, $enemy->id)); $logmsg = "You were attacked by <a href=\"profile.php?id=" . $player->username . "\">" . $player->username . "</a> but nobody won..."; addlog($enemy->id, $logmsg, $db); } $player = check_user($secret_key, $db); //Get new stats include("templates/private_header.php"); echo $output; include("templates/private_footer.php"); break; case "search": //Check in case somebody entered 0 $_GET['fromlevel'] = ($_GET['fromlevel'] == 0)?"":$_GET['fromlevel']; $_GET['tolevel'] = ($_GET['tolevel'] == 0)?"":$_GET['tolevel']; //Construct query $query = "select * from `players` where `id`!= ? and "; $query .= ($_GET['username'] != "")?"`username` LIKE ? and ":""; $query .= ($_GET['fromlevel'] != "")?"`level` >= ? and ":""; $query .= ($_GET['tolevel'] != "")?"`level` <= ? and ":""; $query .= ($_GET['alive'] == "1")?"`hp` > 20 ":"`hp` < 20 "; $query .= "limit 20"; //Construct values array for adoDB $values = array(); array_push($values, $player->id); //Make sure battle search doesn't show self if ($_GET['username'] != "") { array_push($values, "%".trim($_GET['username'])."%"); //Add username value for search } //Add level range for search if ($_GET['fromlevel']) { array_push($values, intval($_GET['fromlevel'])); } if ($_GET['tolevel']) { array_push($values, intval($_GET['tolevel'])); } include("templates/private_header.php"); //Display search form again echo "<legend><b>Search for a player</b></legend>\n"; echo "<form method=\"get\" action=\"battle2.php\">\n<input type=\"hidden\" name=\"act\" value=\"search\" />\n"; echo "<table width=\"100%\">\n"; echo "<tr>\n<td width=\"40%\">Username:</td>\n<td width=\"60%\"><input type=\"text\" name=\"username\" value=\"" . stripslashes($_GET['username']) . "\" /></td>\n</tr>\n"; echo "<tr>\n<td width=\"40%\">Level</td>\n<td width=\"60%\"><input type=\"text\" name=\"fromlevel\" size=\"4\" value=\"" . stripslashes($_GET['fromlevel']) . "\" /> to <input type=\"text\" name=\"tolevel\" size=\"4\" value=\"" . stripslashes($_GET['tolevel']) . "\" /></td>\n</tr>\n"; echo "<tr>\n<td width=\"40%\">Status:</td>\n<td width=\"60%\"><select name=\"alive\" size=\"2\">\n<option value=\"1\""; echo ($_GET['alive'] == 1)?" selected=\"selected\"":""; echo ">Alive</option>\n<option value=\"0\""; echo ($_GET['alive'] == 0)?" selected=\"selected\"":""; echo ">Dead</option>\n</select></td>\n</tr>\n"; echo "<tr><td></td><td><br /><input type=\"submit\" value=\"Search!\" /></td></tr>\n"; echo "</table>\n"; echo "</form>\n"; echo "<br /><br />"; echo "<table width=\"100%\">\n"; echo "<tr><th width=\"30%\">Username</th><th width=\"20%\">Level</th><th width=\"20%\">Location</th><th width=\"30%\">Battle</a></th></tr>\n"; echo "$query"; $query = $db->execute($query, $values); //Search! echo "$value"; if ($query->recordcount() > 0) //Check if any players were found { $bool = 1; while ($result = $query->fetchrow()) { echo "<tr class=\"row" . $bool . "\">\n"; echo "<td width=\"30%\"><a href=\"profile.php?username=" . $result['username'] . "\">" . $result['username'] . "</a></td>\n"; echo "<td width=\"20%\">" . $result['level'] . "</td>\n"; echo "<td width=\"20%\">" . $result['City_ID'] ."</td>\n"; echo "<td width=\"30%\"><a href=\"battle2.php?act=attack&username=" . $result['username'] . "\">Attack</a></td>\n"; echo "</tr>\n"; $bool = ($bool==1)?2:1; } } else //Display error message { echo "<tr>\n"; echo "<td colspan=\"3\">No players found. Try changing your search criteria.</td>\n"; echo "</tr>\n"; } echo "</table>\n"; include("templates/private_footer.php"); break; default: include("templates/private_header.php"); //The default battle page, giving choice of whether to search for players or to target one echo "<legend><b>Search for a player</b></legend>\n"; echo "<form method=\"get\" action=\"battle2.php\">\n<input type=\"hidden\" name=\"act\" value=\"search\" />\n"; echo "<table width=\"100%\">\n"; echo "<tr>\n<td width=\"40%\">Username:</td>\n<td width=\"60%\"><input type=\"text\" name=\"username\" /></td>\n</tr>\n"; echo "<tr>\n<td width=\"40%\">Level</td>\n<td width=\"60%\"><input type=\"text\" name=\"fromlevel\" size=\"4\" /> to <input type=\"text\" name=\"tolevel\" size=\"4\" /></td>\n</tr>\n"; echo "<tr>\n<td width=\"40%\">Status:</td>\n<td width=\"60%\"><select name=\"alive\" size=\"2\">\n<option value=\"1\" selected=\"selected\">Alive</option>\n<option value=\"0\">Dead</option>\n</select></td>\n</tr>\n"; echo "<tr><td></td><td><br /><input type=\"submit\" value=\"Search!\" /></td></tr>\n"; echo "</table>\n"; echo "</form>\n"; echo "<br /><br />\n"; echo "<legend><b>Attack a player</b></legend>\n"; echo "<form method=\"get\" action=\"battle2.php?act=attack\">\n<input type=\"hidden\" name=\"act\" value=\"attack\" />\n"; echo "Username: <input type=\"text\" name=\"username\" /><br />\n"; echo "<input type=\"submit\" value=\"Battle!\" />\n"; echo "</form>\n"; include("templates/private_footer.php"); break; } ?> Quote Link to comment https://forums.phpfreaks.com/topic/99474-solved-need-help-with-query-left-join/#findComment-511220 Share on other sites More sharing options...
fenway Posted April 7, 2008 Share Posted April 7, 2008 No, it doesn't... forget it. You can add a JOIN on the city table... could you at least post the structure of both tables? Quote Link to comment https://forums.phpfreaks.com/topic/99474-solved-need-help-with-query-left-join/#findComment-511230 Share on other sites More sharing options...
cdoyle Posted April 7, 2008 Author Share Posted April 7, 2008 Yes, Players Table City_ID Cities Table City_ID City_Name City_Description Quote Link to comment https://forums.phpfreaks.com/topic/99474-solved-need-help-with-query-left-join/#findComment-511240 Share on other sites More sharing options...
fenway Posted April 7, 2008 Share Posted April 7, 2008 Then "SELECT p.*, c.city_name FROM players AS p INNER JOIN cities AS c ON ( c.City_ID = p.City_ID ) WHERE.... " will work. Quote Link to comment https://forums.phpfreaks.com/topic/99474-solved-need-help-with-query-left-join/#findComment-511264 Share on other sites More sharing options...
cdoyle Posted April 7, 2008 Author Share Posted April 7, 2008 That worked! Thank You! Quote Link to comment https://forums.phpfreaks.com/topic/99474-solved-need-help-with-query-left-join/#findComment-511596 Share on other sites More sharing options...
Recommended Posts
Join the conversation
You can post now and register later. If you have an account, sign in now to post with your account.