Skip to main content

MySQL query to list Items and its categories.There are tables for Items, Categories and Item_category relation. One item may fall in different categories. In the result there should be no repeation of records and Categories should be comma separated.


There is an ITEM table , CATEGORY table and an ITEM_CATEGORY relation table. Items may fall in multiple categories "Item" table has item id and item name.  "cat" table has Category Id and Category Name. There is a third table  to store the item category relation. "Item_cat" table  contains Itm_Id (item id) and cat_Id (category id).


Here the question is how to generate a result like this

ItmName  ##    Category
Item1 ##    Cat1,Cat3
Item2 ##    Cat2
Item3 ##    Cat1,Cat4
Item3 ##    Cat1

Sample MySQL query to list Items and its categories. In this example there are tables for Items, Categories and Item_category relation. One item may fall in different categories. In the result there should be no repeat of records and the categories should be comma separated.


The result should contain Item name and comma seperated category name to which the item belongs to.

Come on let's do it :)




Step1: Create Category table


CREATE TABLE `cat` (  `CId` int(11) NOT NULL AUTO_INCREMENT,  `CName` varchar(10) NOT NULL,  PRIMARY KEY (`CId`))

Structure of category table:
 "cat" table
 1     CId     int(11)    
 2     CName     varchar(20)



data in  "cat" table  ( Item category )
CId     CName
1     SUV
2     Sedan
3     F1 Race
4     MultiAxl



 Step2:Create Item table

CREATE TABLE `item` (  `Id` int(11) NOT NULL AUTO_INCREMENT,  `ItmName` varchar(10) NOT NULL,  PRIMARY KEY (`Id`))

Structure of item table:

 "item" table
 1     Id     int(11)    
 2     ItmName varchar(15)



 data in  "item" table
Id     ItmName
1     Maruthi 800
2     Punto
3   XLT Terran
4     Sienna




 Step3:   Create Item category relation table

 CREATE TABLE `Item_cat` (  `Itm_Id` int(11) NOT NULL,  `cat_Id` int(11) NOT NULL)

  "Item_cat" table    ( Item category relation)
 1     Itm_Id     int(11)        
 2     cat_Id     int(11)



data in Item category relation  ( "Item_cat" ) table

Itm_Id     cat_Id
1     1
1     2
2     1
3     1
3     4
2     3



Step 4 : Execute query

 SELECT ItmName, GROUP_CONCAT(CName SEPARATOR ',') as Category FROM (select I.ItmName,C.CName
  from item I
    left join Item_cat CI on (CI.itm_id = I.ID)
    left join cat C on( C.CId = CI.cat_id )) T GROUP BY ItmName






Final Result 
ItmName  ##    Category
Maruthi 800 ##    SUV,Sedan
Punto ##    SUV,F1 Race
Sienna ##    NULL
XLT Terran ##    SUV,MultiAxl   


Ex: here Maruti 80 comes under 2 categores SUV and sedan

Popular posts from this blog

How to delete videos from your Youtube Watch History list?

How to Delete Individual or all videos from your Youtube Watch History list? Youtube keeps a fine record of the videos that you had watched earlier. You can view this by visiting the History section. If you want to remove the video's from the list do the following: Logon to Youtube and click on the "History" tab on the left menu to view Watch History ( Read more ) There will be check boxes corresponding to each video in the list Tick the check boxes of the videos which you want to remove Click on " Remove " button to delete the videos.

How to add "Link to this page" option under blogger posts?

Steps in adding Link to this page to your blogger posts Links to your page can improve your page rank. So it is a good option to add HTML code for linking to your web page. So that reader can copy and paste it on their web page. if another website links to your web page, this is considered an external link to your website. External links to your website are the most important source of ranking power and in SEO terminology it is considered as third party ranking vote for your page.

Intex Aqua 5.5 VR Plus genuine Review - Dont Buy Intex Aqua 5.5 VR Plus - Board complaint and low battery backup issues

Intex Aqua 5.5 VR Plus  Review - Dont Buy Intex Aqua 5.5 VR + - Board complaint and low battery backup issues I bought an Intex Aqua 5.5 VR Plus on April 23, 2018, With in a week it started to show Battery backup issues. Even if it is charged full, it will completely drain out with in 12 or 13 hours. During this time No internet was used, only 2 or 3 calls were done. Some times there was issues with net connection also.


Urgent Openings for PHP trainees, Andriod / IOS developers and PHP developers in Kochi Trivandrum Calicut and Bangalore. Please Send Your updated resumes to recruit.vo@gmail.com   Read more »
Member
Search This Blog