|  | Posted by Giannis Vrentzos on 08/03/06 13:12 
mpar612@gmail.com wrote:> Hi everyone,
 >
 > I'm not sure if this is asking too much or not.  I am trying to get the
 > following PHP code to work on my website.  It utilizes PHP 5, MySQL 4.1
 > and the PEAR DB module.
 >
 > I am having issues retrieving data from the form.  It won't retrieve
 > all of the data only a part of it.  All of the code is below and I also
 > attached the code for the main file.  I seem to understand everything
 > except for the last 40 or so lines of code, which is where the SQL
 > statements come into play.
 >
 > If anyone has any helpful hints or tips, I would really appreciate it.
 > Or if anyone can make a recommendation for a book or website that might
 > help me figure this out, that would be great too.  Thanks!
 >
 > Here is the code for the database:
 > CREATE TABLE lounge (
 > isbn INT NOT NULL,
 > artist_name VARCHAR(255),
 > album_title VARCHAR(255),
 > release_date VARCHAR(30),
 > description VARCHAR(255),
 > price VARCHAR(255)
 > )
 >
 > Here is the code for formhelpers.php (this is required for the section
 > of code):
 > <?php
 > //print a text box
 > function input_text($element_name, $values, $size, $max_length) {
 > print '<input type="text" name="' . $element_name .'" value="';
 > print htmlentities($values[$element_name]) . '" size="' . $size . '"
 > maxlength="' . $max_length . '">';
 > }
 >
 > //print a submit button
 > function input_submit($element_name, $label) {
 > print '<input type="submit" name="' . $element_name .'" value="';
 > print htmlentities($label) .'"/>';
 > }
 >
 > //print a textarea
 > function input_textarea($element_name, $values) {
 > print '<textarea name="' . $element_name .'">';
 > print htmlentities($values[$element_name]) . '</textarea>';
 > }
 >
 > //print a radio button or checkbox
 > function input_radiocheck($type, $element_name, $values,
 > $element_value) {
 > print '<input type="' . $type . '" name="' . $element_name .'" value="'
 > . $element_value . '" ';
 > if ($element_value == $values[$element_name]) {
 >         print ' checked="checked"';
 > }
 > print '/>';
 > }
 >
 > //print a <select> menu
 > function input_select($element_name, $selected, $options, $multiple =
 > false) {
 >
 > // print out the <select> tag
 > print '<select name="' . $element_name;
 >
 > // if multiple choices are permitted, add the multiple attribute
 > // and add a [] to the end of the tag name
 > if ($multiple) { print '[]" multiple="multiple'; }
 > print '">';
 >
 > // set up the list of things to be selected
 > $selected_options = array();
 > if ($multiple) {
 > foreach ($selected[$element_name] as $val) {
 > $selected_options[$val] = true;
 > }
 > } else {
 > $selected_options[ $selected[$element_name] ] = true;
 > }
 >
 > // print out the <option> tags
 > foreach ($options as $option => $label) {
 > print '<option value="' . htmlentities($option) . '"';
 > if ($selected_options[$option]) {
 > print ' selected="selected"';
 > }
 >
 > print '>' . htmlentities($label) . '</option>';
 >
 > }
 >
 > print '</select>';
 >
 > }
 > ?>
 >
 > Here is the code for the main page:
 > <?php
 >
 > // Load PEAR DB
 > require 'DB.php';
 > // Load the form helper functions.
 > require 'formhelpers.php';
 >
 > // Connect to the database
 > $db = DB::connect('mysql://');
 > if (DB::isError($db)) { die ("Can't connect: " . $db->getMessage()); }
 >
 > // Set up automatic error handling
 > $db->setErrorHandling(PEAR_ERROR_DIE);
 >
 > // Set up fetch mode: rows as objects
 > $db->setFetchMode(DB_FETCHMODE_OBJECT);
 >
 > // The main page logic:
 > // - If the form is submitted, validate and then process or redisplay
 > // - If it's not submitted, display
 > if ($_POST['_submit_check']) {
 >     // If validate_form() returns errors, pass them to show_form()
 >     if ($form_errors = validate_form()) {
 >         show_form($form_errors);
 >     } else {
 >         // The submitted data is valid, so process it
 >         process_form();
 >     }
 > } else {
 >     // The form wasn't submitted, so display
 >     show_form();
 > }
 >
 > function show_form($errors = '') {
 >     // If the form is submitted, get defaults from submitted parameters
 >     if ($_POST['_submit_check']) {
 >
 >     // If errors were passed in, put them in $error_text (with HTML
 > markup)
 >     if (is_array($errors)) {
 >         $error_text = '<tr><td>You need to correct the following
 > errors:';
 >         $error_text .= '</td><td><ul><li>';
 >         $error_text .= implode('</li><li>',$errors);
 >         $error_text .= '</li></ul></td></tr>';
 >     } else {
 >         // No errors? Then $error_text is blank
 >         $error_text = '';
 >     }
 > 	}
 >
 >     // Jump out of PHP mode to make displaying all the HTML tags easier
 > ?>
 > <form method="POST" action="<?php print $_SERVER['PHP_SELF']; ?>">
 > <table>
 > <?php print $error_text ?>
 >
 > <tr><td>ISBN:</td>
 > <td><?php input_text('isbn', $defaults, '', '') ?></td></tr>
 >
 > <tr><td>Artist Name:</td>
 > <td><?php input_text('artist_name', $defaults, '', '') ?></td></tr>
 >
 > <tr><td>Album Title:</td>
 > <td><?php input_text('album_title', $defaults, '', '') ?></td></tr>
 >
 > <tr><td>Release Date:</td>
 > <td><?php input_text('release_date', $defaults, '', ''); ?>
 > </td></tr>
 >
 > <tr><td>Description:</td>
 > <td><?php input_text('description', $defaults, '', ''); ?>
 > </td></tr>
 >
 > <tr><td>Price:</td>
 > <td><?php input_text('price', $defaults, '', ''); ?>
 > </td></tr>
 >
 > <tr><td colspan="2" align="center"><?php
 > input_submit('search','Search'); ?>
 > </td></tr>
 >
 > </table>
 > <input type="hidden" name="_submit_check" value="1"/>
 > </form>
 > <?php
 >       } // The end of show_form()
 >
 > function validate_form() {
 >     $errors = array();
 >
 >     // isbn is required
 >     if (! strlen(trim($_POST['isbn']))) {
 >         $errors[] = 'Please enter an isbn number';
 >     }
 >     return $errors;
 > }
 >
 > function process_form() {
 >     // Access the global variable $db inside this function
 >     global $db;
 >
 >     // build up the query
 >     $sql = 'SELECT isbn, artist_name, album_title, release_date,
 > description, price FROM lounge WHERE
 > 	isbn = ?';
 >
 >     // if a dish name was submitted, add to the WHERE clause
 >     // we use quoteSmart() and strtr() to prevent user-enter wildcards
 > from working
 >
 > 	 if (strlen(trim($_POST['artist_name']))) {
 >         $artist_name = $db->quoteSmart($_POST['artist_name']);
 >         $artist_name = strtr($artist_name, array('_' => '\_', '%' =>
 > '\%'));
 >         $sql .= " AND artist_name LIKE $artist_name";
 > 	}
 >
 > 	if (strlen(trim($_POST['album_title']))) {
 >         $album_title = $db->quoteSmart($_POST['album_title']);
 >         $album_title = strtr($artist_name, array('_' => '\_', '%' =>
 > '\%'));
 >         $sql .= " AND album_title LIKE $album_title";
 > 	}
 >
 > 	if (strlen(trim($_POST['release_date']))) {
 >         $release_date = $db->quoteSmart($_POST['release_date']);
 >         $release_date = strtr($release_date, array('_' => '\_', '%' =>
 > '\%'));
 >         $sql .= " AND release_date LIKE $release_date";
 > 	}
 >
 > 	if (strlen(trim($_POST['description']))) {
 >         $description = $db->quoteSmart($_POST['description']);
 >         $description = strtr($description, array('_' => '\_', '%' =>
 > '\%'));
 >         $sql .= " AND description LIKE $description";
 > 	}
 >
 > 	if (strlen(trim($_POST['price']))) {
 >         $price = $db->quoteSmart($_POST['price']);
 >         $price = strtr($price, array('_' => '\_', '%' => '\%'));
 >         $sql .= " AND price LIKE $price";
 > 	}
 >
 >     // Send the query to the database program and get all the rows back
 >     $results = $db->getAll($sql, array($_POST['isbn']));
 >
 >     if (count($results) == 0) {
 >         print 'No results were found.';
 >     } else {
 >         print '<table>';
 >         print '<tr><th>ISBN</th><th>Artist Name</th><th>Album
 > Title</th><th>Release
 > Date</th><th>Description</th><th>Price</th></tr>';
 >         foreach ($results as $artist_name) {
 >
 > printf('<tr><td>%s</td><td>%s</td><td>%s</td><td>%s</td><td>%s</td><td>%s</td></tr>',
 >                    htmlentities($results->isbn),
 > $artist_name->artist_name, $album_title->album_title,
 > $release_date->release_date, $results->description, $results->price);
 >         }
 >     }
 > }
 > ?>
 >
 
 
 Try to change the last foreach loop with the following. If this won't
 work, try print_r($results) to see array's values.
 
 foreach ($results as $res) {
 printf('<tr><td>%s</td><td>%s</td><td>%s</td><td>%s</td><td>%s</td><td>%s</td></tr>',
 htmlentities($res->isbn),
 $res->artist_name,
 $res->album_title,
 $res->release_date,
 $res->description,
 $res->price
 );
 }
 
 Gvre
 [Back to original message] |