I’m trying to figure out how to get a select statement to be populated by an ever-changing number of where’s. This is for an order-status tracking application.
Basically, the idea is a user (customer of our company) logs in, and can see his/her orders, check status, etc. No problem. The problem arises when that user needs to be associated with multiple companies. Say they work or own two different companies, or they work for a company that owns multiple sub-companies, each ordering individually, but the big-shot needs to see everything ordered by all of the companies. This is where I’m running into a problem. I can’t seem to figure out a good way of making this happen. The only thing I have come up with is this:
client='Client Name One' OR client='Client name two' AND hidden='0' OR client='Client name three' AND hidden='0' OR client='Client name four' AND hidden='0'
(note that client in the previous code refers to the user’s company, thus our client)
placed inside of a column called company in my users table of the database. This then gets called like this:
$clientnamequery = "SELECT company FROM mtc_users WHERE username='testing'";
$clientnameresult = mysql_query($clientnamequery); list($clientname)=mysql_fetch_row($clientnameresult);
$query = "SELECT -redacted lots of column names- FROM info WHERE hidden='0' AND $clientname ORDER BY $col $dir";
$result = mysql_query($query);
Thing is, while this works I can’t seem to make PHP add in the client=’ and ‘ AND hidden=’0’ correctly. Plus, it’s kind of kludgy.
Any ideas? Thanks in advance!
Expanding on Tim’s answer, you can use the IN operator and subqueries:
Or you can try a join:
A join is the preferred approach. Among other reasons, it will probably be the most efficient (though you should test this with
EXPLAIN SELECT ...). You probably shouldn’t grab all table columns (theinfo.*) in case you can later change the table definition; I only put that in because I didn’t know which columns you wanted.On an unrelated note, look into using prepared queries with either the mysqli or PDO drivers. Prepared queries are more efficient when you execute a query multiple times and also obviate the need to sanitize user input.
The relational approach involves tables like:
If company names are to be unique, you could use those as a primary key rather than an
idfield. “co_members” is a poor name, but “employees” and “shareholders” didn’t quite seem the correct terms. As you are more familiar with the system, you’ll be able to come up with a more appropriate name.