Avatar billede sylvesternielsen Nybegynder
27. september 2004 - 19:12 Der er 2 kommentarer og
1 løsning

Outer join statement laver duplicates.

Jeg har tabeller.
tabel1 er en liste over moduler
tabel2 er en liste over de moduler hvert portal ejer.

Det jeg gør at hente hele listen over moduler, her laver jeg en outer join som skulle checke om portalen ejer modulet.

Altså ville jeg gerne have en liste over alle moduler og med et felt som hedder Subscribed som har værdien 0 eller 1 afhængigt af om portalen ejer dette.

problemet er så bare at den ikke kun henter portal listen 1 gang.
Hver gang der er et portal som ejer modulet bliver det vist, altså kommer der duplicates af modulet flere gange.

Min SQL streng ser således ud:


select distinct(ModuleDefinitions.ModuleDefID),
      'Subscribed' = case when (PortalId = 8 and PortalModuleDefinitionId is not null) then 1 else 0 end,
      ModuleDefinitions.FriendlyName,
      ModuleDefinitions.Description,
      PortalModuleDefinitions.HostFee
from  ModuleDefinitions
left outer join PortalModuleDefinitions on ModuleDefinitions.ModuleDefID = PortalModuleDefinitions.ModuleDefID
where  ModuleDefinitions.IsPremium = 1
order by ModuleDefinitions.FriendlyName
Avatar billede atke Nybegynder
28. september 2004 - 13:54 #1
Er det mon det her du søger:

SELECT
  distinct(ModuleDefinitions.ModuleDefID),
  'Subscribed' = case
                  when (PortalId = 8 and PortalModuleDefinitionId is not null) then 1
                  else 0
                end,   
  ModuleDefinitions.FriendlyName,
  ModuleDefinitions.Description,
  PortalModuleDefinitions.HostFee
FROM 
  ModuleDefinitions left outer join
  PortalModuleDefinitions on
      ModuleDefinitions.ModuleDefID = PortalModuleDefinitions.ModuleDefID
  AND PortalId = 8                          -- Har kun tilføjet denne linie
WHERE 
  ModuleDefinitions.IsPremium = 1
ORDER BY
  ModuleDefinitions.FriendlyName
Avatar billede sylvesternielsen Nybegynder
06. oktober 2004 - 13:15 #2
Nej, dette fungere ikke da vi så ikke får listet de moduler som brugeren ikke ejer.

Vi skal jo have listet alle modulerne. Og ejer portalen modulet skal vi sætte subscribed til 1 og ellers 0.
Avatar billede sylvesternielsen Nybegynder
05. november 2004 - 12:18 #3
Jeg lukker.
Avatar billede Ny bruger Nybegynder

Din løsning...

Tilladte BB-code-tags: [b]fed[/b] [i]kursiv[/i] [u]understreget[/u] Web- og emailadresser omdannes automatisk til links. Der sættes "nofollow" på alle links.

Loading billede Opret Preview
Kategori
Computerworld tilbyder specialiserede kurser i database-management

Log ind eller opret profil

Hov!

For at kunne deltage på Computerworld Eksperten skal du være logget ind.

Det er heldigvis nemt at oprette en bruger: Det tager to minutter og du kan vælge at bruge enten e-mail, Facebook eller Google som login.

Du kan også logge ind via nedenstående tjenester