Avatar billede punnishment Nybegynder
04. juli 2007 - 20:02 Der er 2 kommentarer

SQL på Access DB med både inner og left join

Min SQL streng ser således ud

SELECT
a.navn, a.ss, b.adresse, b.id AS bid, b.postnr, b.by, c.omkreds, c.maal, c.vand, c.omfang
FROM a
  INNER JOIN b
    (LEFT JOIN c ON a.id = b.userid)
  ON a.bid = b.id
WHERE a.ud = '0';

Denne SQL sætning giver følgende fejl medellelse.

Error Type:
Microsoft Office Access Database Engine (0x80040E14)
Syntax error in FROM clause.

Hvordan laves en Inner og en LEft join til Access DB?

Har behov for at sammensmelte 2 tabeller, og hive data ud fra den 3. tabel hvis det eksistere.
Avatar billede punnishment Nybegynder
04. juli 2007 - 20:03 #1
SQL sætningen skulle se således ud:

SELECT
a.navn, a.ss, b.adresse, b.id AS bid, b.postnr, b.by, c.omkreds, c.maal, c.vand, c.omfang
FROM a
  INNER JOIN b
    (LEFT JOIN c ON a.id = c.userid)
  ON a.bid = b.id
WHERE a.ud = '0';
Avatar billede punnishment Nybegynder
04. juli 2007 - 20:27 #2
har løst problemet ved at flytte lidt på SQL strengen

FROM (a INNER JOIN b ON a.bid = b.id) LEFT JOIN c ON a.id = c.userid

men min left-join funktion virker ikke optimalt. Er hensigten med left, ikke at hente info fra den tredje tabel, hvis den er der, ellers behøves oplysningerne ikke?
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
Kurser inden for grundlæggende programmering

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