|  | Posted by Justin Koivisto on 05/18/06 17:34 
Justin Koivisto wrote:> Bob Sanderson wrote:
 >> I am trying to create a form for a MySQL database similar to a
 >> spreadsheet. The idea is to display a list of records, with the last
 >> line of the list being an input form. When the user enters data in the
 >> form and hits the submit button, the data is entered and the form is
 >> reloaded with the new data displayed and another input form becomes
 >> the last line.
 >>
 >> It seems is what I think the approach should be:
 >>
 >> 1. Display all current records - the last line is an input form
 >> 2. User adds data to the form and hits the Submit button
 >> 3. The form action calls the same script 4. The new data is entered
 >> into the database
 >> 5. Back to step one
 >>
 >> Does this make sense or is there a better way? How do I structure the
 >> queries to accomplish this?
 >
 > That would work fine:
 >
 > <?php
 >     if(isset($_POST['add_record'])){
 >         // verify POST fields for type, etc.
 >        $q='INSERT INTO table1 (field2, field3, field4) VALUES ('.
 >            '\''.mysql_real_escape_string($_POST['field2']).'\''.
 >            '\''.mysql_real_escape_string($_POST['field3']).'\''.
 >            '\''.mysql_real_escape_string($_POST['field4']).'\''.
 >            ')';
 >        // where there is an auto_increment field for PK (field1)
 >        // fields 2-4 are text or varchar in example
 >
 >        // execute query, send message, etc.
 >     }
 >
 >     $q='SELECT field1, field2, field3 field4 FROM table1';
 >
 >     // execute query, loop, display list
 >
 >     // add form to end of list with a submit button at end like
 >     // <input type="submit" name="add_record" value="Add Record' />
 > ?>
 >
 > If you want to be able to edit each record, make them all form fields
 > with the values filled in. Use fields like:
 > <?php
 >     echo "<input type='text' name='field1[$recID]' value='$value' />";
 > ?>
 >
 > For the last row, have it be the same format, just use 0 as the id
 > value. That way, when you post, you'll have something like the following
 > as your POST array structure:
 >
 > $_POST = array (
 >   [field1] = array (
 >     [0] = New Rec value
 >     [1] = value1
 >     [2] = value2
 >     [24] = value24
 >   )
 >   [field2] = array (
 >     [0] = New Rec value2
 >     [1] = value1-2
 >     [2] = value2-2
 >     [24] = value24-2
 >   )
 > )
 >
 >
 > If there wasn't anything new added to the form, the structure would be
 > the same, but the new values would be empty.
 
 BTW - if you will have a lot of records, instead of having a huge form
 like this, you will be better off having separate forms for editing via
 a link in the row of the list. (I like using Edit and Delete links.)
 Then in the code you'd have something more like:
 
 <?php
 if(isset($_POST['add_record'])){
 // insert stuff
 }else if(isset($_POST['edit_record'])){
 // update stuff
 }else if(isset($_POST['delete_record'])){
 // delete stuff
 }
 
 if(isset($errors)){
 // I store error messages in an array so I can output them all at once
 // for the user to review. You may want to do other things here as well
 }else{
 
 if(isset($_GET['edit'])){
 // show edit form. I like to use URIs like:
 // page.php?edit=24
 // when I want to edit record 24
 }else if(isset($_GET['delete'])){
 // show delete confirm form
 // I use the same type of URI as the edit for this as well
 }else{
 // no action request, show list with links
 }
 }
 ?>
 [Back to original message] |