Psycho
Moderators-
Posts
12,159 -
Joined
-
Last visited
-
Days Won
130
Everything posted by Psycho
-
Is it possible to achieve what I am attempting?
Psycho replied to Bl4ckMaj1k's topic in PHP Coding Help
Rather than respond to all of your comments I will provide my own explanation of the code. But, first let me answer your two specific questions. 1. Yes. But, if you are properly constructing your database, the tools should be in a separate table with a unique ID for each record. Then that ID would be used as a foreign key to reference the tools from other tables. 2. See explanation below. OK, I don't think you even need the checkboxes (as I explained earlier), but it sounds as if that is what you want to do. So, I will explain that code. The form (modified to not use an ID value for the tools): <input name="tools[]" type="radio" value="Hammer" /> Hammer <input name="quantity[Hammer]" type="text" /> <input name="tools[]" type="radio" value="Wrench" /> Wrench <input name="quantity[Wrench]" type="text" /> In the form you have separate checkboxes to select each tool and a corresponding text field to record the quantity for each tool. The name of each checkbox is "tools[]" with the value being the name of each tool. By naming the fields in this manner, the PHP code in the receiving page can reference the selected tools using $_POST['tools']. Note; only the values of the CHECKED checkboxes are passed in the POST data. So, on the receiving page, the variable $_POST['tools'] will be an array of all the checked tool inputs. The quantity fields are named in the manner "quantity[TOOL_NAME]" where TOOL_NAME is the name of the tool. So, in the receiving PHP page you can reference the quantities in the format $_POST['quantity']['TOOL_NAME']. Now, since you have a list of all the selected tools in the $_POST['tools'] array, you just iterate through that array to find the associated quantity values. PHP Processing page (minor modification to use the tool name instead of ID) $queryValues = array(); foreach($_POST['tools'] as $tool) { $quantity = (int) $_POST['quantity'][$tool]; if($quantity > 0) { $queryValues[] = "($tool, $quantity)"; } } $query = "INSERT INTO [table_name] (`toolname`, `toolvalue`) VALUES " . implode(", ", $queryValues); The first thing we do is create an array ($queryValues) to hold the values to be inserted into the database. The reason for this is that you should NEVER run queries in loops. Instead gather all the data in the loop and run one query. So, I will store a separate piece of text in this array for each record to be inserted in the DB. Next, we will loop through each of the selected tools from the POST data and process that tool and it's associated quantity to create the values for the insert query. Within the loop $tool will be set as each selected tool name during each iteration. Within the loop, we will first get the associated quantity for the selected tool. The (int) will ensure the value is converted into an integer. This serves two purposes 1) It ensure the value is a number and 2) it ensures the value will be safe for a DB query. Then there is an if statement to ensure the value is greater than 0. If 0 is an allowed value for your purposes, you can remove the IF statement. If the quantity is valid we then add a new piece of text to the $queryValues array that will be used to insert a record in the DB. I assumed that the records being inserted will have (at a minimum) values for two columns: the tool name and the tool quantity. lastly, after the foreach() loop completes, we have an array containing multiple records to be inserted into a table. So, we create a single INSERT query that will insert ALL the record in ONE query. This is done by imploding the records. -
EDIT: btherl beat me to it, but I will post this anyway since my solution is much more efficient (no offense btherl) Um, yeah. If you notice the code you put in the post title is NOT the same as the code you posted in the description. There is a huge difference - mainly that $data2 is an array! $data2[] = $data2 + $data; How can you create a new value by adding an array to a numeric value? You need to think about what you are really trying to accomplish in simple terms and then translate it into code. Here is how I would state the problem: "I want to generate a value on each iteration which is the sum of the current iteration value and all previous iteration values". There is a very easy solution to your problem. Since $data contains the current iteration value and all previous iteration values, you just need the sum of all the values in that array!: while ($row = mysql_fetch_array($result)) { $data[] = $row['EF0000000DBBDD1D']*6/1000; $data1[] = strtotime($row['DATETIME']); $data2[] = array_sum($data); }
-
Is it possible to achieve what I am attempting?
Psycho replied to Bl4ckMaj1k's topic in PHP Coding Help
Not really. At first I was going to suggest checkboxes, but when I though about it further I realized the checkboxes were not needed either. You could just process the text fields for the quantity inputs - just show a label next to each one. If you really want to use checkboxes, you can. Sample form <input name="tools[]" type="radio" value="hammerID" /> Hammer <input name="quantity[hammerID]" type="text" /> <input name="tools[]" type="radio" value="wrenchID" /> Wrench <input name="quantity[wrenchID]" type="text" /> Sample processing code $queryValues = array(); foreach($_POST['tools'] as $itemID) { $quantity = (int) $_POST['quantity'][$itemID]; if($quantity > 0) { $queryValues[] = "($itemID, $quantity)"; } } $query = "INSERT INTO [table_name] VALUES " . implode(", ", $queryValues); -
Is it possible to achieve what I am attempting?
Psycho replied to Bl4ckMaj1k's topic in PHP Coding Help
You have some contradictory information in your post. If you have a radio button group to select the item then you only need one quantity field since you could only select one item. But, you don't need a separate selection for the item vs. the quantity input at all. Just create quantity text inputs for each item. Then on the processing page, only process the text fields that have values. Example form: <input name="quantity[hammerID]" type="text" /> Hammer <input name="quantity[wrenchID]" type="text" /> Wrench Then on the processing page, do something like this: $queryValues = array(); foreach($_POST['quantity'] as $itemID => $quantity) { $quantity = (int) $quantity; if($quantity > 0) { $queryValues[] = "($itemID, $quantity)"; } } $query = "INSERT INTO [table_name] (itemID, itemQty) VALUES " . implode(", ", $queryValues); -
Can you elaborate on your statement? I'm not sure what you are proposing? I stated in my first post that there were several methods to persist the value and that session values were my preference (with passing on URL or in cookie as two alternatives). If you have a alternative solution, please share it and the reasons you would use it. Well, the error condition would only occur id the POST value is not set AND the session value is not set. If the page can be run without a "model" value to filter on - which is a perfectly acceptable requirement - then you just need to not include the error condition. However, if it is expected - and it is not happening - then you need to determine why the error condition is occurring. Either the POST value is not getting sent/received (could be a typo between the field name and the POST index value) or the session value is not set (again, could be a typo or you are not using session_start()).
-
There is no such thing as perfect code. I take time out of my day to help people for free who simply copy/paste the code without even trying to understand it and then have the audacity to say it doesn't work because of a simple syntax error which they should be perfectly capable of recognizing and fixing. "they" should be more appreciative of the help that is provided to them, IMHO.
-
How do you know it is putting one record before another? The only way to "see" the records in a database (that I know of) is to run a query and then display the results. The query will determine the sort order. If you don't provide one then I believe the implied sort order is the order in which the records are created. But, I would NEVER rely upon that. If you want your records in a particular order then order them using the query.
-
So fix it. I plainly state in my signature that I may not test the code. It would require much more time to rebuild databases and other requirements to test some code. You should be able to find and fix the simple syntax error in the code I provided.
-
You are missing the whole point. You are still trying to create separate IDs for each record to use for showing/hiding the data. You are making it more difficult than it needs to be. All you need is a single table that holds all the records and use the ID of that table to show/hide all the records at once. You already have the table, just add an ID to it and create a trigger to call the function. Change this $category_id = ''; echo '<table align="center" width="40%" border="3" cellpadding="0" cellspacing="0">'; while($row = mysql_fetch_array($statusUpdate)) { To this: $category_id = ''; echo "<a href=\"#\" onclick=\"toggle_visibility('THE_TABLE');\";return false\">Show/Hide the table</a>"; echo '<table id="THE_TABLE" align="center" width="40%" border="3" cellpadding="0" cellspacing="0">'; while($row = mysql_fetch_array($statusUpdate)) {
-
Why would you give the table an ID that has anything to do with the record IDs? You don't need to give the DIVs IDs since you aren't going to hide/sho those individually. You ONLY need an ID on the table and a single link to initiate the JS function. I'm giving you enough information to solve this yourself without writing the code for you.
-
Sorry, I thought the string was defined with double quotes (so the variales would be interpreted). Try this: $outputArray[] ="<a href='/titlehistory/{$row['shortName']}'>{$row['titleName']}</a>";
-
Where are you defining the $model variable? You could do something like this: if(isset($_POST['model'])) { $model = mysql_real_escape_string(trim($_POST['model'])); $_SESSION['model'] = $model; } elseif(isset($_SESSION['model']) { $model = $_SESSION['model']; } else { //model not set - perform error handling } Don't forget to use session_start() at the top of the page.
-
$outputArray = array(); while ( $row = mysqli_fetch_array ( $titlesResult, MYSQLI_ASSOC ) ) { $outputArray[] ='<a href="/titlehistory/{$row['shortName']}">{$row['titleName']}</a>'; } echo implode(' |', $outputArray);
-
You need to crawl before you walk and walk before you run. I suggest you look at some tutorials regarding MySQL queries. The problem is you are trying to filter the records based upon the ID using a WHERE clause, but you forgot the "WHERE" part of the WHERE clause. $querytext = "SELECT text FROM quiz WHERE id = '$prob'";
-
As I said, you need to implement the onclick event to show/hide the table - not the individual records. Give the table an id (let's say "mytable"). Then implement an onclick trigger passing the table's ID as the parameter in that function call.
-
Use an onclick event to change the visibility of the table instead of the TDs. Just give the table an ID and create an object to invoke the toggle_visibility() function passing the table id.
-
Because it is the field directly before the password field. The browser doesn't "comprehend" the text on the page it only makes a logical determination on what the username/password fields are. The "username" field could just as likely be named "login" or just about anything else based upon the language of the person who developed the page. So, the browser is likely detecting the "password" TYPE field and selecting the immediately preceeding field as the username. If you had simply stated the fields were pre-populated with values when the page loads - THAT would have described the problem. Instead, your original post could have meant just about anything. Especially when the code posted is pulling values from the database (could have been pulling wrong values) and is saving data to the database (could be saving the wrong values).
-
I don't need to even read through your code to know what the problem is. You apparently have a page where a user can do a search. When the user submits that page you pass the value for the results to be filtered on. In this case it is the value of $model - although you didn't show how that value is defined! But, I suspect it is via a POST value. Anyway, once the user selects another page you are reloading the current page passing a page variable - but you are not passing the $model value. Therefore the subsequent page load is trying to run a query to find record where the model value is an empty string - thus the empty results. You need to pass the model value on to each and every page load if you want the records to be continued to be filtered by that result. One way you can do that by appending the model value onto the query string (along with the page value). But, that can get ugly and requires more work to ensure the value doesn't get corrupted in the query string. Two other alternatives would be to store the model value as a cookie or a session value. I would use a session value.
-
What do you mean "this code is making my username.......searls03 and password as default value"? I have no clue where in that long set of code where you are stating that is happening. Are one of the messages in the code stating something in particular? Can you point out the line in question where you are getting the unexpected results? That would help to trace back at where the error could be occuring?
-
The problem is that you are running two distinct queries, one of which is a loop on the results of the first query. You apparently have multiple results from $tbl_name2 that are associated with the same record in $tbl_name. You should NEVER run queries in loops. In this case you should be doing a JOIN between the two tables along with a GROUP BY to only get the unique values. EDIT: This should get you started $likeValues = "$tbl_name2.keyword LIKE '%" . implode("%' OR $tbl_name2.keyword LIKE '%", $keywords) . "%'" $query = "SELECT * FROM $tbl_name JOIN $tbl_name2 USING(product_id) WHERE $likeValues GROUP BY product_id";
-
OK, if I understand you correctly, the option to select parents is not an option associated with the records in the `medlemmer` table. instead it is an option when submitting the form to send the emails. So, the logic is still the same, just check the POST value in the logic I provided instead of the database value. Although I don't understand your checkbox array. If you are using the checkboxes to select the recipients, then what is the purpose of the query to get recipients? Oh well. if(in_array('Foraldre', $_POST['mailtarget'])) { //Parents checkbox NOT selected $ToEmail = $row->email; } else { //Parents checkbox selected $ToEmail = "{$row->email}; {$row->mor_email}; {$row->far_email}"; }
-
Of course it doesn't you aren't "returning" the value, you are echoing the value into an XML file. So, if the value is >5, then redefine the value as five. Then the 5 will get written to the file. Put this right before the echo statement: if ($row['quantity'] >= 5) { $row['quantity'] = "5"; }
-
Below is a working solution - albeit a rough one. You just need to provide the appropriate information in the five variables at the top of the script. I was going to extend the functionality to first let the user select any table, but I'll let you do that if you so choose. Here are some notes about the script: 1. I use the query "DESCRIBE [TABLE_NAME]" to get the field information for the table. Currently, the script is only using the field names, but the results contain much more information such as the field type (i.e. int, varchar, etc.). This script can be further expanded to provide only the appropriate comparison operators for each field. For example, it doesn't make sense to have a "greater than" operator for a text field, but it would be handy to have a "starts with". 2. I like phpJoeMo's suggestion above about having a select box to determine the fields to be used in the comparisons. That allows you to have the same field used twice in the WHERE clause (but that would necessitate the ability to use OR's - see #4 below) 3. After running the script, I think it would make sense to have the input fields repopulated with the submitted values when the results are displayed. That way the user can easily make minor modifications to get the results they are looking for. 4. Lastly, all of the comparisons in the WHERE clause are considered as AND comparisons. It would be beneficial to allow for OR'd conditions as well. But, then you would also need to add the ability to have parenthesized comparisons. EDIT #5: Very important! I didn't take the time to escape the user input. You will want to do that to prevent errors and possible database corruption. I'll let you read through the code to see what I did and where. <?php $__DB_SERVER__ = "localhost"; $__DB_USER__ = "XXXXX"; $__DB_PASS__ = "XXXXX"; $__DB_NAME__ = "test"; $__DB_TABLE__ = "lu_products"; mysql_connect($__DB_SERVER__, $__DB_USER__, $__DB_PASS__) or die(mysql_error()); mysql_select_db($__DB_NAME__) or die(mysql_error()); if(isset($_POST['select'])) { $selectClause = '`' . implode('`, `', $_POST['select']) . '`'; $whereParts = array(); foreach($_POST['where'] as $field) { $whereParts[] = "`{$field}` {$_POST['compare'][$field]} '{$_POST['value'][$field]}'"; } $whereClause = implode("\n AND ", $whereParts); $query = "SELECT $selectClause FROM $__DB_TABLE__ WHERE $whereClause"; echo $query; $result = mysql_query($query) or die(mysql_error()); if(mysql_num_rows($result)==0) { $output = "There were no matching records."; } else { $header = true; $output = "<table border='1'>\n"; while($row = mysql_fetch_assoc($result)) { if($header) { $output .= " <tr>\n"; foreach($row as $label => $value) { $output .= " <th>$label</th>\n"; } $output .= " </tr>\n"; $header = false; } $output .= " <tr>\n"; foreach($row as $value) { $output .= " <td>$value</td>\n"; } $output .= " </tr>\n"; } $output .= "</table>\n"; } } //Get fields for table $query = "DESCRIBE {$__DB_TABLE__}"; $result = mysql_query($query) or die(mysql_error()); if($result) { while($row = mysql_fetch_assoc($result)) { $fieldNames[] = $row['Field']; } } $selectFields = ''; $whereFields = ''; $compareOptions = "<option value='='>equals</option>\n"; $compareOptions .= "<option value='<>'>does not equal</option>\n"; $compareOptions .= "<option value='>'>greater than</option>\n"; $compareOptions .= "<option value='<'>less than</option>\n"; $compareOptions .= "<option value='>='>greater than or equal to</option>\n"; $compareOptions .= "<option value='<='>less than or equal to</option>\n"; $compareOptions .= "<option value='LIKE'>is like</option>"; foreach($fieldNames as $field) { $selectFields .= "<tr>\n"; $selectFields .= " <td colspan=\"4\" style=\"padding-left:25px;\">\n"; $selectFields .= " <input type=\"checkbox\" name=\"select[]\" value=\"{$field}\" /> {$field}\n"; $selectFields .= " </td>\n"; $selectFields .= "</tr>\n"; $whereFields .= "<tr>\n"; $whereFields .= " <td style=\"padding-left:25px;\"><input type=\"checkbox\" name=\"where[]\" value=\"{$field}\" /></td>\n"; $whereFields .= " <td>{$field}</td>\n"; $whereFields .= " <td><select name=\"compare[$field]\">\n"; $whereFields .= $compareOptions; $whereFields .= " </select></td>\n"; $whereFields .= " <td><input type=\"text\" name=\"value[$field]\"></td>\n"; $whereFields .= "</tr>\n"; } ?> <html> <head> <style> th { text-align: left; padding-top:10px;} </style> </head> <body> <form action="" method="post"> <table border=0> <tr> <th colspan="4">SELECT</th> </tr> <?php echo $selectFields; ?> <tr> <th colspan="4">FROM <?php echo $__DB_TABLE__; ?></th> </tr> <tr> <th colspan="4">WHERE</th> </tr> <?php echo $whereFields; ?> </table> <button type="submit">SUBMIT</button> <br><br> <?php echo $output; ?> </form> </body> </html>
-
Only if you want to use that data - so the answer is yes. But, just adding additional fields to a query isn't going to do anything with that data unless you code for it. You will also need to pull the value for the "parents" checkbox. You don't say what that field is called. So, your query would look something like this: $query = "SELECT email, tilknytning, nyhedsbrev, mom_email, dad_email, parentsCheckbox FROM medlemmer WHERE tilknytning IN ($gruppeList) && nyhedsbrev = 'Ja'"; Next, modify your code for defining the recipients for each email. I will assume that if the email is going to the parents that it is OK to send one email to the three recipients if($row->parentsCheckbox!=1) { //Parents checkbox NOT selected $ToEmail = $row->email; } else { //Parents checkbox selected $ToEmail = "{$row->email}; {$row->mom_email}; {$row->dad_email}"; }
-
The problem you have is that checkboxes are only passed in the POST data if they are checked. So, if user checks boxes 0 and 5, the post data has checkbox fields with ids of 0 and 1. The solution is very easy though. I assume you have a loop that created all the form inputs. In that loop, I also assume you have a variable to keep track of the loops (i.e. $x). In the loop that creates the fields, set the value of the checkboxes using the $x value (i.e. 0 through 9). Also, for the field names of the fields that correspond to those checkboxes, set the index in the field name using the $x. Now, when you receive the form post, you check the values passed for the "field" checkboxes and use those values to reference the fields associated with them.