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


Räkna med värden som inte finns

Postades av 2006-10-19 00:51:50 - Anders Ringman, i forum mysq, Tråden har 12 Kommentarer och lästs av 971 personer

Kryptisk rubrik eller hur? Kom inte på någon bättre.

I alla fall, jag trodde att jag behärskade SQL hyfsat bra men har kört fast på en sak.

Jag har två tabeller och jag vill göra en beräkning på det som finns i tabellen. Tabellerna ser ut så här (Obs: I den riktiga databasen så finns det fler tabeller och tabellerna är större än så här, jag bara förenklar det hela nu när jag ställer frågan):

ANSTALLDA
AnstNr
Namn

SALJ
SaljNr
AnstNr
Belopp

Säg nu, väldigt förenklat, att tabellerna innehåller följande data:

ANSTÄLLDA
1 Arne
2 Bertil

SALJ
1 1 100
2 1 200

Nu skulle jag med en SQL-sats vilja summera alla anställdas försäljning och det i sig är ju inte så svårt. Men i och med att anställd nummer 2 inte har någon försäljning så visas inte denna person när jag kör min SQL-sats.

SQL-satsen ser ut så här:

SELECT
ANSTALLD.ANSTNAMN,
SUM(SALJ.SALJ) AS SUMMA
FROM
SALJ
INNER JOIN ANSTALLD ON (SALJ.ANSTNR = ANSTALLD.ANSTNR)
GROUP BY
ANSTALLD.ANSTNAMN

Det jag får fram när jag kör den är

Arne 300

Vad jag nu vill, och som jag inte får till, är att jag även vill ha med Bertil, även om han inte har någon försäljning. Jag vill att det skall se ut så här efter att jag har kört SQL-satsen.

Arne 300
Bertil

Hur gör man detta? Med en sub-fråga eller vad? Har försökt att få till det men inget fungerar.

Tacksam för tips och hjälp.




Svara

Sv: Räkna med värden som inte finns

Postades av 2006-10-19 07:56:57 - Per Persson

Byt ut INNER JOIN mot RIGHT JOIN. Då får du med alla från högra tabellen även om det inte finns någon matchande rad i den vänstra tabellen.


Svara

Sv:Räkna med värden som inte finns

Postades av 2006-10-19 08:41:53 - Anders Ringman

Det fungerade. Tack!

Fast jag inser nu att jag missade en sak i min fråga (beklagar det). Det skall ske en beräkning i SELECT satsen också. Exempelvis: 1000 - SUM(SALJ.SALJ) AS SUMMA

Då fungerade inte din lösning tyvärr, även om den gav svar på den felaktiga fråga jag ställde.

Sorry om jag krånglar till det.


Svara

Sv: Räkna med värden som inte finns

Postades av 2006-10-19 09:51:31 - Jan Bulér

Jag vet inte om om det funkar i myssql men i SQL-server kan du använda ISNULL-funktionen.

Detta funkar i SQL-server

SELECT ANSTALLDA.Namn, ISNULL(SUM(SALJ.Belopp), 0) AS Summa
FROM SALJ RIGHT OUTER JOIN
ANSTALLDA ON SALJ.AnstNr = ANSTALLDA.AnstNr
GROUP BY ANSTALLDA.Namn


Svara

Sv:Räkna med värden som inte finns

Postades av 2006-10-19 18:07:31 - Per Persson

I MySQL heter funktionen IFNULL och används på samma sätt. Men frågan är om det inte vore bättre med
SUM(IFNULL(Salj.Belopp, 0)) AS Summa
i stället för det Jan Bulér föreslog. Det skulle kunna bli skillnad i vissa fall.


Svara

Sv: Räkna med värden som inte finns

Postades av 2006-10-19 19:35:55 - Andreas Hillqvist

Alternativ lösning:

SELECT ANSTALLDA.AnstNr, ANSTALLDA.Namn, Försäljning.TotaltBelopp
FROM ANSTALLDA LEFT OUTER JOIN
    (SELECT SALJ.AnstNr, SUM(SALJ.Belopp) AS TotaltBelopp
     FROM SALJ
     GROUP BY SALJ.AnstNr) AS Försäljning


Svara

Sv: Räkna med värden som inte finns

Postades av 2006-10-19 19:38:21 - Andreas Hillqvist

KAn du tala om vad det är för beräkning du vill utföra?
Är det att försäljningssiffrorna är Null det som strular?

Aretmetiska operatorer på Null resulterar i null:
1000 - Null = Null


Svara

Sv:Räkna med värden som inte finns

Postades av 2006-10-20 08:09:06 - Per Persson

Den alternativa lösningen fungerar (med små modifieringar) i MySQL 4.1 och senare.


Svara

Sv: Räkna med värden som inte finns

Postades av 2006-10-20 08:36:39 - Jan Bulér

@Per,

Jag har jag provat med både din och min variant i SQL-Server med samma resultat det vore intressant att få veta vad det kan bli för skillnad i vissa fall.


Svara

Sv: Räkna med värden som inte finns

Postades av 2006-10-22 20:37:35 - Anders Ringman

Jag tackar för alla svar...

Fick inget att fungera dock så jag har börjat skissa om hela databasen för att få en bättre struktur och förhoppningsvis lite lättare SQL-satser så småningom.

Tack igen.


Svara

Sv:Räkna med värden som inte finns

Postades av 2006-10-23 00:19:24 - Jan Bulér

Detta funkar i mysql.

(Bytt Right Join mot Left Join, mysql stödjer tydligen inte right join)


Har testat i mysql och både

SELECT ANSTALLDA . Namn , IFNULL ( SUM ( SALJ . Belopp ) , 0 ) AS Summa
FROM ANSTALLDA
LEFT JOIN SALJ ON ANSTALLDA . AnstNr = SALJ . AnstNr
GROUP BY ANSTALLDA . Namn

och

SELECT ANSTALLDA . Namn , SUM ( IFNULL ( SALJ . Belopp , 0 ) ) AS Summa
FROM ANSTALLDA
LEFT JOIN SALJ ON ANSTALLDA . AnstNr = SALJ . AnstNr
GROUP BY ANSTALLDA . Namn

fungerar








Svara

Sv:Räkna med värden som inte finns

Postades av 2006-10-23 00:19:39 - Jan Bulér

Detta funkar i mysql.

(Bytt Right Join mot Left Join, mysql stödjer tydligen inte right join)


Har testat i mysql och både

SELECT ANSTALLDA . Namn , IFNULL ( SUM ( SALJ . Belopp ) , 0 ) AS Summa
FROM ANSTALLDA
LEFT JOIN SALJ ON ANSTALLDA . AnstNr = SALJ . AnstNr
GROUP BY ANSTALLDA . Namn

och

SELECT ANSTALLDA . Namn , SUM ( IFNULL ( SALJ . Belopp , 0 ) ) AS Summa
FROM ANSTALLDA
LEFT JOIN SALJ ON ANSTALLDA . AnstNr = SALJ . AnstNr
GROUP BY ANSTALLDA . Namn

fungerar








Svara

Nyligen

  • 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
  • 14:25 Tips på verktyg för att skapa QR-k
  • 14:23 Tips på verktyg för att skapa QR-k
  • 20:52 Fungerer innskuddsbonuser egentlig

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 154
27 952
271 704
843
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