I’d like to create a query in MySQL that has an optional value. When the value is specified the query is filtered by that value, when the value is not all rows are returned. Here’s the idea:
public function doQuery($item = 'ANY_VALUE') {
$query = "SELECT * FROM table WHERE item = ?";
db->fetchAll($query,array($item))
...
}
doQuery(); // Returns everything
doQuery($item='item1'); // Returns only rows where item = 'item1'
Is there an easy way to do this without creating two query strings depending on the value of $item?
As far as I know, no such “any” placeholder exists.
If you can use LIKE, you could do
if you can append a condition, you could nullify the
itemclause like this:(won’t work in your example though, because you are passing “item” as a parameter)
That’s all the options I can see – it’s probably easiest to work with two queries, removing the
WHEREclause altogether in the second one.This would probably work, but I*m not sure whether it’s a good idea from a database point of view.