Toon posts:

probleem met SQL in VBA: Select top 1 geeft meerdere waarden

Pagina: 1
Acties:

Acties:
  • 0Henk 'm!

  • 107mb
  • Registratie: Juni 2004
  • Laatst online: 14:56
Ik heb een tabel (werkblad in Excel) met onder andere deze gegevens:
Positie,oppervlak,frequentie,bedrag

Bij de frequenties zijn o.a. de volgende waarden mogelijk:
5w 5 keer per week
3w 3 keer per week
2m 2 keer per maand
8j 8 keer per jaar

Bij een totaaltelling moeten alle oppervlakte’s en bedragen opgeteld worden, en de query moet de hoogste frequentie weergeven.

Vanwege de 8 wordt in dit geval 8 keer per jaar als hoogste frequentie geselecteerd, wat natuurlijk fout is. Daarom heb ik een tweede tabel (tabel FREQ) gemaakt, waarin deze frequenties zijn opgenomen, met een doorberekening naar aantal per jaar (FREQ.brtJr52). 5w is dus 210 keer per jaar. 8j is dus 8 keer per jaar.

Vanwege de complexiteit van de totaaltelling maak ik gebruik van SQL in VBA. De data in het werkblad krijgt een namedRange “DATASET”

Ik heb de volgende (vereenvoudigde) query gemaakt:
Visual Basic:
1
2
3
4
sSelect = "select  a.[pos], space(10) as omschrijving, sum([oppervlak])," & _
"(select top 1 b.[freq1] from DATASET b left join FREQ fr on (fr.[freq]=b.[freq1]) where b.[pos] = a.[pos] order by fr.[brtJr52] desc) as freq," & _
"sum(IIF(isnull(a.[omzetJaar1]),0,a.[omzetJaar1])) " & _
"from DATASET a group by a.[pos]"


De select top 1 zorgt er voor dat de hoogste waarde geretourneerd wordt.

Dan nu het probleem:
Als ik deze query op SQL server database loslaat, dan werkt deze perfect. Bouw ik hem om naar een VBA-SQL query, dan werkt hij ook goed indien de hoogste waarde maar 1 maal voorkomt in de DATASET. Komt bijvoorbeeld 5w meer dan een keer voor dan krijg ik in de debugger de volgende melding:
At most one record can be returned by this subquery.

Ondanks de top 1 krijg ik toch meerdere waarden terug?!?


Tweakers maakt gebruik van cookies

Tweakers plaatst functionele en analytische cookies voor het functioneren van de website en het verbeteren van de website-ervaring. Deze cookies zijn noodzakelijk. Om op Tweakers relevantere advertenties te tonen en om ingesloten content van derden te tonen (bijvoorbeeld video's), vragen we je toestemming. Via ingesloten content kunnen derde partijen diensten leveren en verbeteren, bezoekersstatistieken bijhouden, gepersonaliseerde content tonen, gerichte advertenties tonen en gebruikersprofielen opbouwen. Hiervoor worden apparaatgegevens, IP-adres, geolocatie en surfgedrag vastgelegd.

Meer informatie vind je in ons cookiebeleid.

Sluiten

Toestemming beheren

Hieronder kun je per doeleinde of partij toestemming geven of intrekken. Meer informatie vind je in ons cookiebeleid.

Functioneel en analytisch

Deze cookies zijn noodzakelijk voor het functioneren van de website en het verbeteren van de website-ervaring. Klik op het informatie-icoon voor meer informatie. Meer details

janee

    Relevantere advertenties

    Dit beperkt het aantal keer dat dezelfde advertentie getoond wordt (frequency capping) en maakt het mogelijk om binnen Tweakers contextuele advertenties te tonen op basis van pagina's die je hebt bezocht. Meer details

    Tweakers genereert een willekeurige unieke code als identifier. Deze data wordt niet gedeeld met adverteerders of andere derde partijen en je kunt niet buiten Tweakers gevolgd worden. Indien je bent ingelogd, wordt deze identifier gekoppeld aan je account. Indien je niet bent ingelogd, wordt deze identifier gekoppeld aan je sessie die maximaal 4 maanden actief blijft. Je kunt deze toestemming te allen tijde intrekken.

    Ingesloten content van derden

    Deze cookies kunnen door derde partijen geplaatst worden via ingesloten content. Klik op het informatie-icoon voor meer informatie over de verwerkingsdoeleinden. Meer details

    janee