Solved

Building a new iterated loop...recommendations?

Posted on 2011-09-18
6
171 Views
Last Modified: 2012-06-27
I have an order line INSERT that I want to iterate through as many as 15 separate "order line items", but I'm not sure how to build my code to iterate cleanly through all the possible lines. The requirements:
1) I will check for at least one order line (from any camper) in the validation of the previous page's form. Don't need to worry about that here.
2) Every camper need not to have an order line. In the page's initial $_POST array below, camper[1] does not have any order lines.
3) I check for an isset() before processing an order line.
4) I have to assign two variables from the session ID because I use two instances in the processing loop.

Now, my code manages 6 loops. Not enough. And very clumsy. I can't do this 15 times! Please help,

Karl
$_POST Array
(
    [Camper_0_PK] => 490
    [Camper_0_Session_1_List] => 3
    [Camper_0_Session_2_List] => 3
    [Camper_0_Session_3_List] => 
    [Camper_1_PK] => 491
    [Camper_1_Session_1_List] => 
    [Camper_1_Session_2_List] => 
    [Camper_1_Session_3_List] => 
    [Marketing_FreeText] => 
    [Marketing_CouponCode] => 
    [SessionRegSubmit] => Submit
)


Current order line processing code:

// process order line items insert
			// TODO: figure out how to make this into an iterating loop
			if (isset($_POST['Camper_0_Session_1_List'])){
				
				// must retrieve the program FK for the selected session
				$SessionPK = $_POST['Camper_0_Session_1_List'];
				$OrderLISessionFK = $_POST['Camper_0_Session_1_List'];
				$OrderLICamperFK = $_POST['Camper_0_PK'];
				
				// run through line item insert
				require ('panels/panel.order_line_item_insert.php');
			}
			if (isset($_POST['Camper_0_Session_2_List'])){
				
				// must retrieve the program FK for the selected session
				$SessionPK = $_POST['Camper_0_Session_2_List'];
				$OrderLISessionFK = $_POST['Camper_0_Session_2_List'];
				$OrderLICamperFK = $_POST['Camper_0_PK'];
				
				// run through line item insert
				require ('panels/panel.order_line_item_insert.php');
			}
			if (isset($_POST['Camper_0_Session_3_List'])){
				
				// must retrieve the program FK for the selected session
				$SessionPK = $_POST['Camper_0_Session_3_List'];
				$OrderLISessionFK = $_POST['Camper_0_Session_3_List'];
				$OrderLICamperFK = $_POST['Camper_0_PK'];
				
				// run through line item insert
				require ('panels/panel.order_line_item_insert.php');
			}
			// process order line items insert
			if (isset($_POST['Camper_1_Session_1_List'])){
				
				// must retrieve the program FK for the selected session
				$SessionPK = $_POST['Camper_1_Session_1_List'];
				$OrderLISessionFK = $_POST['Camper_1_Session_1_List'];
				$OrderLICamperFK = $_POST['Camper_1_PK'];
				
				// run through line item insert
				require ('panels/panel.order_line_item_insert.php');
			}

...and so on...

Open in new window

0
Comment
Question by:kpisor
[X]
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
  • 3
  • 3
6 Comments
 
LVL 13

Expert Comment

by:Hugh McCurdy
ID: 36557929
Just because the index is typically a constant string, that's not required.  You can build it.  Coming from C, I tend to use common functions to both, such as sprintf().  

We can have variables for the camper # and the session # which can be controlled by while loops or other means.  

$index = sprintf ( "Camper_%s_Session_%s", $camperNbr, $sessionNbr );
if (isset($_POST[$index]))
{
    ....
}

Open in new window


Does that make sense to you?
0
 
LVL 13

Accepted Solution

by:
Hugh McCurdy earned 500 total points
ID: 36557941
I forgot to mention you could also build the string using . as well.

$index = "Camper_" . $camperNbr . "_Session_" . $sessionNbr;

Open in new window


This is most likely a better practice than my sprintf() approach.  Old habits are hard to break.
0
 

Author Comment

by:kpisor
ID: 36558023
hmccurdy:

Yes, quite simple. Just make the index as a string, then process against it. I'll give it a try. Anyone else with suggestions for processing this?
0
Increase Agility with Enabled Toolchains

Connect your existing build, deployment, management, monitoring, and collaboration platforms. From Puppet to Chef, HipChat to Slack, ServiceNow to JIRA, Splunk to New Relic and beyond, hand off data between systems to engage the right people.

Connect with xMatters.

 

Author Comment

by:kpisor
ID: 36585332
Okay, I've rewritten the code and it works clean with two FOR loops:

// process order line items insert; up to 5 campers and 3 line items per order
			for ($i = 0; $i < 4; $i++) {
				$camperIndex = "Camper_" .$i ."_PK";
				
				for ($j = 1; $j < 4; $j++) {
					$sessionIndex = "Camper_" .$i ."_Session_" .$j ."_List";
					
					// test if session is selected
					if (!empty($_POST[$sessionIndex])){
						
						// retrieve the program FK for the selected session
						// two separate sessionIndex variables will be used in the insert loop
						$SessionPK = $_POST[$sessionIndex];
						$OrderLISessionFK = $_POST[$sessionIndex];
						$OrderLICamperFK = $_POST[$camperIndex];
						
						// run through order line item insert
						require ('panels/panel.order_line_item_insert.php');
					}
					
				} // end session list iteration
					
			} // end camper iteration

Open in new window

0
 

Author Closing Comment

by:kpisor
ID: 36585336
I asked the question as I am new to FOR loops...so it might have helped to be more explicit in managing the FOR setups. Otherwise, thanks!
0
 
LVL 13

Expert Comment

by:Hugh McCurdy
ID: 36587117
Thanks for the points.  We can certainly help you with how to use any of the keyword operations if you help.  Loops, if/then, etc., are "bread and butter" to a lot of programmers and I expect hundreds if not thousands of experts on EE can help you with those concepts.

If you still need help with for loops, just ask.  If you need help with any other keyword concepts, just ask.
0

Featured Post

Webinar: MongoDB® Index Types

Join Percona’s Senior Technical Services Engineer, Adamo Tonete as he presents “MongoDB Index Types, How, When and Where Should They be Used?” on Wednesday, July 12, 2017 at 11:00 am PDT / 2:00 pm EDT (UTC-7).

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

This article was originally published on Monitis Blog, you can check it here . Today it’s fairly well known that high-performing websites and applications bring in more visitors, higher SEO, and ultimately more sales. By the same token, downtime…
When the s#!t hits the fan, you don’t have time to look up who’s on call, draft emails, call collaborators, or send text messages. An instant chat window is definitely the way to go, especially one like HipChat. HipChat is a true business app. An…
Viewers will get an overview of the benefits and risks of using Bitcoin to accept payments. What Bitcoin is: Legality: Risks: Benefits: Which businesses are best suited?: Other things you should know: How to get started:
The is a quite short video tutorial. In this video, I'm going to show you how to create self-host WordPress blog with free hosting service.

691 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question