Fetstil Fetstil Kursiv Understrykning linje färgläggning tabellverk Punktlista Nummerlista Vänster Centrerat högerställt Utfyllt Länk Bild htmlmode
  • Forum & Blog
    • Forum - översikt
      • .Net
        • asp.net generellt
        • c#
        • vb.net
        • f#
        • silverlight
        • microsoft surface
        • visual studio .net
      • databaser
        • sql-server
        • databaser
        • access
        • mysql
      • mjukvara klient
        • datorer och komponenter
        • nätverk, lan/wan
        • operativsystem
        • programvaror
        • säkerhet, inställningar
        • windows server
        • allmänt
        • crystal reports
        • exchange/outlook
        • microsoft office
      • mjukvara server
        • active directory
        • biztalk
        • exchange
        • linux
        • sharepoint
        • webbservers
        • sql server
      • appar (win/mobil)
      • programspråk
        • c++
        • delphi
        • java
        • quick basic
        • visual basic
      • scripting
        • asp 3.0
        • flash actionscript
        • html css
        • javascript
        • php
        • regular expresssion
        • xml
      • spel och grafik
        • DirectX
        • Spel och grafik
      • ledning
        • Arkitektur
        • Systemutveckling
        • krav och test
        • projektledning
        • ledningsfrågor
      • vb-sektioner
        • activeX
        • windows api
        • elektronik
        • internet
        • komponenter
        • nätverk
        • operativsystem
      • övriga forum
        • arbete karriär
        • erbjuda uppdrag och tjänster
        • juridiska frågor
        • köp och sälj
        • matematik och fysik
        • intern information
        • skrivklåda
        • webb-operatörer
    • Posta inlägg i forumet
    • Chatta med andra
  • Konto
    • Medlemssida
    • Byta lösenord
    • Bli bonsumedlem
    • iMail
  • Material
    • Tips & tricks
    • Artiklar
    • Programarkiv
  • JOBB
  • Student
    • Studentlicenser
  • KONTAKT
    • Om pellesoft
    • Grundare
    • Kontakta oss
    • Annonsering
    • Partners
    • Felanmälan
  • Logga in

Hem / Forum översikt / inlägg

Posta nytt inlägg


Joina flera tabeller och få ut flera värden från ett fält?

Postades av 2005-04-13 14:00:38 - Tård Wennerborg, i forum sql-server/msde, Tråden har 4 Kommentarer och lästs av 779 personer

Jag har två tabeller jag behöver plocka data från. Nämligen följande:

[artikeltabell]
artikelid
rubrik

[datatabell]
artikelid (kan finnas fler för detta är en hänvisning till artikel, dock kan det bara finnas en av varje datatyp)
datatyp (bestämmer vilken typ av data fältet "datainnehåll" innehåller, t ex "bild")
datainnehåll (själva datat, t ex "finbild.jpg")

Jag vill i en fråga få ut:
artikelid, rubrik, datainnehåll för datatyp "bild", datainnehåll för datatyp "ljud"

Följande lösning ger ju två poster per artikelid (en där datatypen är bild och en ljud), vilket jag vill undvika. Hur göra?


SELECT artikelid, rubrik, datainnehåll
FROM artikeltabell , datatabell
WHERE artikeltabell.id=datatabell.id AND datatyp='bild' OR datatyp='ljud'


Obs! Ovanstående är bara ett exempel för att verkligheten skulle vara för komplicerad och innehålla för mycket som inte var relevant.


Svara

Sv: Joina flera tabeller och få ut flera värden från ett fält?

Postades av 2005-04-13 17:48:15 - Mikael Sand

Efter lite meckande hittade jag en lösning som funkar eftersom det är SQL server.

<code:sql>
select distinct
artikelId,
Artikeltabell.Rubrik,
( select distinct data from datatabell where datatyp = 1 ) as DataBild,
( select distinct data from datatabell where datatyp = 2 ) as DataLjud
from
datatabell inner join Artikeltabell
on Artikeltabell.ArtId = datatabell.ArtikelId
</code>

Den är inte vacker men det beror lite på att du försöker göra något som din normalisering av databasen inte tagit hänsyn till.

//Mikael Sand


Svara

Sv:Joina flera tabeller och få ut flera värden från ett fält?

Postades av 2005-04-13 21:07:39 - Göran Andersson

> Efter lite meckande hittade jag en lösning som funka

Nej, den fungerar inte. Du kopplar ju inte datatabellen till någon artikel i de nästlade selectsatserna.

Det är enbart om du har en enda bild och ett enda ljud i datatabellen som du kan köra frågan, och då får du ju ut den bilden och det ljudet för alla artiklarna.


Svara

Sv: Joina flera tabeller och få ut flera värden från ett fält?

Postades av 2005-04-13 21:09:42 - Göran Andersson

Du får joina in datatabellen två gånger:

SELECT a.artikelid, a.rubrik, db.datainnehåll as Bild, dl.datainnehåll as Ljud
FROM artikeltabell a
LEFT JOIN datatabell db on db.id = a.id AND db.datatyp='bild'
LEFT JOIN datatabell dl on dl.id = a.id AND dl.datatyp='ljud'


Svara

Sv: Joina flera tabeller och få ut flera värden från ett fält?

Postades av 2005-04-14 09:18:07 - Mikael Sand

Den funkade för mig enligt en uppställning av tabeller med innehåll som du givit.

//Mikael Sand


Svara

Nyligen

  • 14:24 CBD regelbundet?
  • 14:23 CBD regelbundet?
  • 14:22 Har du märkt några verkliga fördel
  • 09:09 Vill du köpa medicinska tester?
  • 12:47 Vem beviljar assistansen – kommune
  • 14:17 Någon med erfarenhet av hemstädnin
  • 14:14 Bör man använda sig av en båtförme
  • 14:12 Finns det någon intressant hundblo

Sidor

  • Hem
  • Bli bonusmedlem
  • Läs artiklar
  • Chatta med andra
  • Sök och erbjud jobb
  • Kontakta oss
  • Studentlicenser
  • Skriv en artikel

Statistik

Antal besökare:
Antal medlemmar:
Antal inlägg:
Online:
På chatten:
4 569 619
27 953
271 709
509
0

Kontakta oss

Frågor runt konsultation, rådgivning, uppdrag, rekrytering, annonsering och övriga ärenden. Ring: 0730-88 22 24 | pelle@pellesoft.se

© 1986-2013 PelleSoft AB. Last Build 4.1.7169.18070 (2019-08-18 10:02:21) 4.0.30319.42000
  • Om
  • Kontakta
  • Regler
  • Cookies