Jump to content

One Item in multiple categories ? MySQL ...


Recommended Posts

categories table:              items_table                     items_categories

----------------           ------------------             -----------------

id                               id                                     category_id

parent                         category_id                        item_id

category_name             item_name

 

I have a problem , I need the above structure work as:

When selected main category show all items in subcategories also have one item in more than one category ...

there is single table for main and sub-sub-sub ... (tree-like) categories ...

 

hope some one can put me in right direction ...

thank you

 

Link to comment
https://forums.phpfreaks.com/topic/112685-one-item-in-multiple-categories-mysql/
Share on other sites

Hi brOken

Sorry if could not explain better, i will try now :-)

 

When selected main category , i would like to show-list all items in main category but also in subcategories of selected main category ...

When selected sub category i want to show all items in that sub category but also items of sub-sub category  to particular sub category etc ...

 

 

i do have a ready a categories tree script with recursive function php ...

 

I need a SQL statement that would select items with just one get parameter (category_id)

 

categories table:

------------------------

"category_id" int(11) NOT NULL auto_increment COMMENT 'Main ID',

  "category_parent_id" int(11) default '0' COMMENT 'Parent ID',

  "name" varchar(250) NOT NULL ,

 

Items table:

-------------------------

"item_id" bigint(20) NOT NULL auto_increment,

  "category_id" int(11) default '1' COMMENT 'Category Main ID',

  "name" varchar(250) NOT NULL,

  "image" varchar(250) default NULL,

  "description" text,

 

As you see i use single category id ... in items ...

 

So the problem is to show items that belong to sub-categories when a parent (or main) category is selected ...

 

 

 

 

I think I have found answer else:

What you are describing is a classic Many-To-Many relationship. Many sites, attached to Many categories. The correct way to do this is to use 3 tables. A sites table, a categories table, and an "assignments" table which assigns sites to categories.

 

SITES

    siteid                     <-- primary key

    url                         <-- other fields related to your site

    description

    rating

 

CATEGORIES

    categoryid             <-- primary key

    name

    description

    keywords

   

ASSIGNMENTS

    siteid                  <-- foreign key to site

    categoryid           <-- foreign key to category

 

 

I like to make my primary and foreign keys of type MEDIUM INT, because you can make these autoincrement so you don't need to worry about them, but the format of your primary key is up to you, just keep it consistent.

 

You would use embedded select statements to get your data.

 

SELECT * FROM SITES s WHERE '15' IN (SELECT categoryid FROM ASSIGNMENTS a WHERE a.siteid = s.siteid)

 

would get all the sites that are in the category with categoryid = '15'"

 

So it will be suitable ...

but i can't use categories directly to items ... but will try as relationship ...

 

thank you

 

And this will not help me display items of subcategory when selected main (parent) category

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.