Jump to content

Recommended Posts

i am working on a relational database of recipes.

 

i have a products table and a recipes table. i also have an ingredients table which is basically a link table between products and recipes so that basically a recipe will have many products through the ingredients table (i hope i am explaining that right).

 

what i am trying to do is select any number of products beforehand, and then write some sort of query that will find the recipe that matches those products exactly.

 

here is a simple schema of what i have now:

 

products:

  id

  name

 

recipes:

  id

  name

 

ingredients:

  id

  product_id

  recipe_id

 

so let's say i have a recipe called peanut butter and jelly. there 3 products in the products table: bread, peanut butter, and jam. so i then have 3 records in the ingredients table linking these 3 items to that recipe.

 

i need it so that if i have fewer ingredients than the recipe calls for, nothing will be returned. or if all of the correct ingredients are used, but also the id of the ketchup product is included, that will return nothing as well.

 

any ideas? thanks

Link to comment
https://forums.phpfreaks.com/topic/97025-mysql-selection-help-needed/
Share on other sites

ok, i don't know if this is a good way of doing it but this sort of works:

 

i find all of the selected product ids and convert it to a comma separated string like "1,2,3"

 

and then run this:

 

SELECT recipe_id, GROUP_CONCAT(product_id) AS product_ids FROM ingredients GROUP BY recipe_id HAVING product_ids = '1,2,3' LIMIT 1

 

a potential problem might be that the order of the comma separated ids might be different but it's closer to what i need at least and maybe it can help give an idea of what i am trying to accomplish.

so this is what i came up with:

 

SELECT recipes.name, COUNT(*) AS ingredients_count
FROM ingredients JOIN recipes ON (ingredients.recipe_id = recipes.id)
WHERE ingredients.product_id IN (1,2,3)
GROUP BY recipe_id HAVING ingredients_count = 3 LIMIT 1

 

is that what you meant? it appears to work, but i'm still playing with it some more.

after doing some testing, that didn't really work.

 

the recipes will not always have 3 ingredients so i would need a dynamic way of selecting the number of ingredients that each recipe has.

 

i changed it a little to this:

 

SELECT recipes.*, (SELECT COUNT(*) FROM ingredients WHERE ingredients.recipe_id = recipes.id) AS ingredients_count
FROM `recipes` JOIN ingredients ON (ingredients.recipe_id = recipes.id)
WHERE (ingredients.product_id IN (1,2,3))
GROUP BY recipe_id HAVING ingredients_count = 3 LIMIT 1

 

for the most part i am still pretty new to some of the more advanced features of mysql besides your standard select statements. my question is how would a query like this effect performance? is it ok to have a select within another select or should i try to avoid something like that?

This thread is more than a year old. Please don't revive it unless you have something important to add.

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.

Guest
Reply to this topic...

×   Pasted as rich text.   Restore formatting

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.

×
×
  • Create New...

Important Information

We have placed cookies on your device to help make this website better. You can adjust your cookie settings, otherwise we'll assume you're okay to continue.