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


SQL sträng - 3 tabeller

Postades av 2006-11-02 18:05:02 - Uffe Bengtsson, i forum asp - allmänt, Tråden har 3 Kommentarer och lästs av 825 personer

Hej igen!

Har suttit o klurat "lite":) på en SQL-sträng som ska hämta information från tre tabeller. I dagsläget ser SQL:en ut så här men nu ska jag bland in ytterliggare 2 stycken tabeller med samma WHERE krav. Någon som har en idé om hur det kan se ut?
<code>
strSQL = "SELECT * FROM tblResultat WHERE YEAR(datum) = " & Ar & " AND MONTH(datum) = " & Manad & " and PersonalID=" & PersonalID & " Order by Datum Desc"
</code>

Så här ser databasstrukturen ut:
http://www.webbuffe.biz/dbResultat.gif

Tackar på förhand än en gång


Svara

Sv: SQL sträng - 3 tabeller

Postades av 2006-11-02 18:54:24 - Jonas Boman

Vilken information vill du ha ut ur de andra tabellerna?
Om du kunde utveckla lite ytterligare är det lättare att hjälpa dig.

/jonas


Svara

Sv:SQL sträng - 3 tabeller

Postades av 2006-11-02 21:20:02 - Uffe Bengtsson

OK, missade lite där. Ur tblButik behöver jag hämta ButikNamn, ur tblResultat skall allt hämtas och ur tblPersonal behöver jag PersonalNamn.

MVH Uffe


Svara

Sv: SQL sträng - 3 tabeller

Postades av 2006-11-02 21:43:52 - Andreas Hillqvist

Om det är Access måste du använda paranteser:

FROM (tblResultat INNER JOIN 
    tblButik ON tblResultat.ButikID = tblButik.ButikID) INNER JOIN 
    tblPersonal ON tblResultat.PersonalID = tblPersonal.PersonalID

Eller:
FROM (tblResultat INNER JOIN 
    tblPersonal ON tblResultat.PersonalID = tblPersonal.PersonalID) INNER JOIN 
    tblButik ON tblResultat.ButikID = tblButik.ButikID

Spelar ingen större roll i vilken ordning du placerar dem i detta fallet.


Frågan är om du behöver alla tre tabellerna eftersom du bara hämtar filtrerat till en anställd?
Då gör du bara resultatet onödigt stort att hämta från servern, då personalinformationen dupliceras för varje rad.

Hämta personalinformationen först.
Sedan resultatet.
Jag tycker dessutom du bör använda parameter fråger. Dessa främjar säkerhet och kvalitet.

SQL för en parameterfråga kan se ut så här:
    strSQL = "SELECT tblButik.ButikNamn, tblResultat.*" + vbCrLf + _
             "FROM tblResultat INNER JOIN tblButik ON tblResultat.ButikID = tblButik.ButikID" + vbCrLf + _
             "WHERE PersonalID= ? AND datum >= ? AND datum < ?" + vbCrLf + _
             "ORDER BY Datum Desc"

Begränsningen av en perioden till en månad bör inte göras Med Year och Month funktionen då inte Index kan användas.

Beräkna istället datum för första dagen i månad och första dagen i följande månad:
StartDate = DateSerial(Ar, Manad, 1)
EndDate = DateSerial(Ar, Manad+1, 1)

Det finns exempel i forumet hur du skickar parametrar till frågan. PArametrarna ersätter sedan fråge tecknen.


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 169
27 953
271 705
472
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