Jump to content

Recommended Posts

I am definitely a rookie with php and hope I am asking this right!  What I am trying to do is send the id of the product to the next page and in that page load the product description (desc).  What I have so far is:

 

    <?php
         $cat = $_GET['cat'];
         $get_items = "SELECT * FROM poj_products WHERE cat='$cat'";
         $get_items = mysql_query($get_items);      

echo '<a href="'.$sitelocation.$item_row['url'].'?item_desc='.$item_row['id'].'>view details/order</a>';

?>

 

but url link is not echoed.  Any ideas on this?

 

Thank you!

  • Replies 92
  • Created
  • Last Reply

Top Posters In This Topic

Top Posters In This Topic

You're executing the query, but not assigning its results;

 

<?php
$cat = $_GET['cat'];
$get_items = "SELECT * FROM poj_products WHERE cat='$cat'";
$get_items = mysql_query($get_items);  


$results = mysql_fetch_assoc($get_items);


echo '<a href="'.$sitelocation.$results['url'].'?item_desc='.$iresults['id'].'>view details/order</a>';

$cat = mysql_real_escape_string($_GET['cat']);
$r = "SELECT * FROM poj_products WHERE cat='$cat'";
$get_items = mysql_query($r);  
$results = mysql_fetch_assoc($get_items);
mysql_free_result($r);  // please be tidy

echo '<a href="'.$sitelocation.$results['url'].'?item_desc='.$iresults['id'].'>view details/order</a>';

I wouldn't say using mysql_free_result() was being tidy

 

mysql_free_result() only needs to be called if you are concerned about how much memory is being used for queries that return large result sets. All associated result memory is automatically freed at the end of the script's execution.

 

Really not necessary in this instance, and the result memory is free'd up when the script finish.

You're executing the query, but not assigning its results;

 

<?php
$cat = $_GET['cat'];
$get_items = "SELECT * FROM poj_products WHERE cat='$cat'";
$get_items = mysql_query($get_items);  


$results = mysql_fetch_assoc($get_items);


echo '<a href="'.$sitelocation.$results['url'].'?item_desc='.$iresults['id'].'>view details/order</a>';

 

After modifying the code above to suite my situation to:

 

<?php
$cat = $_GET['cat'];
$get_items = "SELECT * FROM poj_products WHERE cat='$cat'";
$get_items = mysql_query($get_items);


$item_row = mysql_fetch_assoc($get_items);


echo '<a href="'.$sitelocation.$item_row['url'].'?item_desc='.$item_row['id'].'>view details/order</a>';

?>

 

It is still not working?  Still not echoing??

Try the following, it'll display mysql errors and php errors.

 

<?php

/* Enable displaying of errors */
error_reporting(E_ALL);
ini_set('display_errors', 'On');

$cat = (int) $_GET['cat'];
$get_items = "SELECT * FROM poj_products WHERE cat='$cat'";
$get_items = mysql_query($get_items);
if($get_items){
$item_row = mysql_fetch_assoc($get_items);
echo '<a href="'.$sitelocation.$item_row['url'].'?item_desc='.$item_row['id'].'>view details/order</a>';
}else{
die("Unable to connect to database.".mysql_error());
}

?>

You need to check that $_GET['cat'] exists first before using it

 

if(isset($_GET['cat']) && is_numeric($_GET['cat']))
{
    $cat = (int) $_GET['cat'];
    $get_items = "SELECT * FROM poj_products WHERE cat='$cat'";
    $get_items = mysql_query($get_items);
    if($get_items){
       $item_row = mysql_fetch_assoc($get_items);
       echo '<a href="'.$sitelocation.$item_row['url'].'?item_desc='.$item_row['id'].'>view details/order</a>';
    }else{
       die("Unable to connect to database.".mysql_error());
    }
}

No.

 

I now have:

 

<?php

/* Enable displaying of errors */
error_reporting(E_ALL);
ini_set('display_errors', 'On');

$cat = $_GET['cat'];
$get_items = "SELECT * FROM poj_products WHERE cat='$cat'";
$get_items = mysql_query($get_items);
if($get_items){
   $item_row = mysql_fetch_assoc($get_items);
   echo '<a href="'.$sitelocation.$item_row['url'].'?item_desc='.$item_row['id'].'>view details/order</a>';
   echo $_GET['cat'];
}else{
   die("Unable to connect to database.".mysql_error());
}

?>

 

Does everything look right?

If echoing the $_GET['cat'] isn't displaying anything, then the variable?cat=child isn't accessible via the url.  Could you paste the actual url (the actual results of your previous post) so I can confirm that the variable is present and rule that out as an issue.

Sorry!  I had things set up a bit wrong.  Things are set up properly now, BUT I am getting the error:

 

Notice: Undefined index: cat in /homepages/27/d120150310/htdocs/poj/test1.php on line 64

 

Line 64 is:

 

$cat = (int) $_GET['cat'];

 

But it is defined, right?

It means that there is no "?cat=child" in the url.  So the script attempts to pull the $_GET['cat'] but can't because the variable doesn't exist in the url.

 

You need to make sure the variable exists in the url before the script can pull the category and execute the query.

 

Make sense?

This thread is more than a year old. Please don't revive it unless you have something important to add.

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.

Guest
Reply to this topic...

×   Pasted as rich text.   Restore formatting

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.


×
×
  • Create New...

Important Information

We have placed cookies on your device to help make this website better. You can adjust your cookie settings, otherwise we'll assume you're okay to continue.