PHWinfo banniere

Titres
PORTAIL ANNUAIRE ARTICLES COMPARATEUR HÉBERGEURS DEVIS FORUMS RÉDUCTEUR D'URL
Précédent   PHWinfo > Autres forums > Forum Programmation & Conception > mysql.general > Need with a sql query
S'inscrire FAQ Membres Recherche Messages du jour Marquer les forums comme lus
Need with a sql query

Réponse
 
LinkBack Outils de la discussion
Vieux 22/10/2007, 01h22   #1
Imran
Aucun Avatar
 
Messages: n/a
Hébergeur:
Par défaut Need with a sql query

Hello all:



I have two tables:



1. MenuAccess:



accessId

fkMenuId

fkGroupid

View

Execute



2. MenuOptions



MenuId

MenuName



I would like to get all of the records in MenuOptions and any record in
MenuAccess with a specific fkGroupid. For example:



A. MenuAccess



AccessId fkMenuID fkgroupid view execute

1 1 2 1
1

2 2 2 1
0

3 3 2 0
1

4 1 1 1
1



B. MenuOptions



Menuid MenuName

1 Order Maintenance

2 Customer Maintenance

3 Reports







IIf I run a query for fkgroupid = 1 I should get



AccessId fkMenuID fkgroupid view execute
MenuId MenuName

1 1 2 1
1 1 Order Maintenence

Null Null Null Null
Null 2 Customer Maintenence

Null Null Null Null
Null 3 Reports





Any will be appreciated.



Thanks




  Réponse avec citation
Vieux 22/10/2007, 03h31   #2
mysql@subtropolix.org
Aucun Avatar
 
Messages: n/a
Hébergeur:
Par défaut Re: Need with a sql query

Imran wrote:
> Hello all:
>
> ...
> I would like to get all of the records in MenuOptions and any record in
> MenuAccess with a specific fkGroupid. For example:
>
> ...
>
> IIf I run a query for fkgroupid = 1 I should get
>
>
>
> AccessId fkMenuID fkgroupid view execute
> MenuId MenuName
>
> 1 1 2 1
> 1 1 Order Maintenence
>
> Null Null Null Null
> Null 2 Customer Maintenence
>
> Null Null Null Null
> Null 3 Reports
>


You'll need a UNION for:

SELECT ma.AccessId, ma.fkMenuID, ma.fkgroupid, ma.view, ma.execute,
mo.MenuId, mo.MenuName
FROM MenuAccess AS ma
LEFT JOIN MenuOptions AS mo ON mo.Menuid = ma.fkMenuID
WHERE ma.fkgroupid = 1
UNION
SELECT NULL, NULL, NULL, NULL, NULL, MenuID, MenuName
FROM MenuOptions
WHERE MenuID NOT IN
(SELECT fkMenuID FROM MenuAccess WHERE fkgroupid = 1);

(untested but it looks about right)

Note that the second WHERE clause has a subquery where you have to
repeat the given fkgroupid. Otherwise, you'll get 2 rows for "Order
Maintenence". I'm sure there's a much more elegant way to achieve this.

As an aside, you really should pick one column-naming convention and
stick to it. The case of the column names is all over the place
(fkMenuID, fkgroupid, MenuID). This can only cause you headaches down
the road when you're trying to remember if it was MenuID, menuId,
menuid, or something altogether different.

Personally, I use fk_menu_id.
  Réponse avec citation
Réponse


Outils de la discussion

Règles de messages
Vous ne pouvez pas créer de nouvelles discussions
Vous ne pouvez pas envoyer des réponses
Vous ne pouvez pas envoyer des pièces jointes
Vous ne pouvez pas modifier vos messages

Les balises BB sont activées : oui
Les smileys sont activés : oui
La balise [IMG] est activée : oui
Le code HTML peut être employé : non
Trackbacks are oui
Pingbacks are oui
Refbacks are oui


Fuseau horaire GMT +1. Il est actuellement 23h49.


Édité par : vBulletin® version 3.7.3
Copyright ©2000 - 2008, Jelsoft Enterprises Ltd.
Search Engine Friendly URLs by vBSEO 3.2.0 RC5 Tous droits réservés.
Version française #16 par l'association vBulletin francophone
PHWinfo est un site Éducation Sans Frontières ©2000-2008
Ad Management by RedTyger
©Tous droits réservés par les parties respectives
Page generated in 0,09462 seconds with 10 queries