Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Redmi Note 15 Pro+ 5G: autonomia monstre e display luminoso, ma il prezzo è alto
Redmi Note 15 Pro+ 5G: autonomia monstre e display luminoso, ma il prezzo è alto
Xiaomi ha portato sul mercato internazionale la nuova serie Redmi Note, che rappresenta spesso una delle migliori scelte per chi non vuole spendere molto. Il modello 15 Pro+ punta tutto su una batteria capiente e su un ampio display luminoso, sacrificando qualcosa in termini di potenza bruta e velocità di ricarica
HONOR Magic 8 Pro: ecco il primo TOP del 2026! La recensione
HONOR Magic 8 Pro: ecco il primo TOP del 2026! La recensione
HONOR ha finalmente lanciato il suo nuovo flagship: Magic 8 Pro. Lo abbiamo provato a fondo in queste settimane e ve lo raccontiamo nella nostra recensione completa. HONOR rimane fedele alle linee della versione precedente, aggiungendo però un nuovo tasto dedicato all'AI. Ma è al suo interno che c'è la vera rivoluzione grazie al nuovo Snapdragon 8 Elite Gen 5 e alla nuova MagicOS 10
Insta360 Link 2 Pro e 2C Pro: le webcam 4K che ti seguono, anche con gimbal integrata
Insta360 Link 2 Pro e 2C Pro: le webcam 4K che ti seguono, anche con gimbal integrata
Le webcam Insta360 Link 2 Pro e Link 2C Pro sono una proposta di fascia alta per chi cerca qualità 4K e tracciamento automatico del soggetto senza ricorrere a configurazioni complesse. Entrambi i modelli condividono sensore, ottiche e funzionalità audio avanzate, differenziandosi per il sistema di tracciamento: gimbal a due assi sul modello Link 2 Pro, soluzione digitale sul 2C Pro
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 09-01-2009, 20:35   #1
CIUFFO
Member
 
L'Avatar di CIUFFO
 
Iscritto dal: Feb 2001
Città: Reggio Emilia
Messaggi: 230
[VBA] Query con parametri

Codice:
Set dbs = CurrentDb
Set FidoResiduo = dbs.OpenRecordset("SELECT  DISTINCTROW Sum(TabellaOperazioni.[TOTALE SEND]) AS [TOTALE SEND]," _
& "Sum(TabellaOperazioni.[IMPORTO RECEIVE]) AS [IMPORTO RECEIVE]," _
& "Sum(TabellaOperazioni.[TOTALE QUICK]) AS [TOTALE QUICK], Sum(TabellaOperazioni.BONIFICO) AS BONIFICO," _
& "Sum([TabellaOperazioni].[TOTALE SEND])-NZ(Sum([TabellaOperazioni].[IMPORTO RECEIVE]))-NZ(Sum([TabellaOperazioni].[BONIFICO]))+NZ(Sum([TabellaOperazioni].[TOTALE QUICK])) AS [DA PAGARE]," _
& "Round(DLookUp('[fido settimanale]','[tblFido]')+nz(Sum([TabellaOperazioni].[BONIFICO]))-nz(Sum([TabellaOperazioni].[TOTALE SEND]))+nz(Sum([TabellaOperazioni].[IMPORTO RECEIVE]))-nz(Sum([TabellaOperazioni].[TOTALE QUICK])),2) AS [FIDO RESIDUO]" _
& "FROM TabellaOperazioni WHERE(((TabellaOperazioni.DATA) Between Date() And Date()-5))")
Con questo codice eseguo una query su una tabella filtrando i dati in base alla data che deve essere compresa (between) tra oggi e oggi-5.
Io vorrei sostituire date()-5 con una variabile ma non sò come si fa.
CIUFFO è offline   Rispondi citando il messaggio o parte di esso
Old 10-01-2009, 01:05   #2
guldo76
Senior Member
 
L'Avatar di guldo76
 
Iscritto dal: Nov 2002
Città: Morio Cho
Messaggi: 2596
È access, sì?
Bé, non lo conosco bene, ma da quello che vedo il metodo OpenRecordset prende come argomento una stringa che contiene un'istruzione SQL, giusto?
Puoi comporre l'istruzione come vuoi. Ad esempio:
Codice:
stringaSQL = "select " & nomeCampo & " from tabella"
Set FidoResiduo = dbs.OpenRecordset(stringaSQL)
dove nomeCampo è una variabile di tipo String.

Analogamente per la data.
Però devi fare attenzione al formato della data. Access se non sbaglio accetta le date nel formato seguente:
Codice:
#5/15/2008#
compresi i segni "#", che quindi dovrai mettere tu, eventualmente. Nota che qui la data è nel formato #g/m/aaaa# per cui quello è il 15 maggio.
Fa' qualche tentativo per essere sicuro che la data venga passata correttamente.

Oppure, per non porti neanche il problema, rendi dinamico solo lo scarto (cioè "5" nell'espressione "Date() - 5"), così non devi preoccuparti del formato della data.
guldo76 è offline   Rispondi citando il messaggio o parte di esso
Old 10-01-2009, 09:43   #3
CIUFFO
Member
 
L'Avatar di CIUFFO
 
Iscritto dal: Feb 2001
Città: Reggio Emilia
Messaggi: 230
Codice:
Private Sub Comando517_Click()
Dim inizio, fine
Dim Criteri As String

If Weekday(Date) = 1 Then 'Domenica
inizio = Date - 6
End If
If Weekday(Date) = 2 Then 'Lunedi
inizio = Date
End If
If Weekday(Date) = 3 Then 'Martedi
inizio = Date - 1
End If
If Weekday(Date) = 4 Then 'Mercoledi
inizio = Date - 2
End If
If Weekday(Date) = 5 Then 'Giovedi
inizio = Date - 3
End If
If Weekday(Date) = 6 Then 'Venerdi
inizio = Date - 4
End If
If Weekday(Date) = 7 Then 'Sabato
inizio = Date - 5
End If

Criteri = "'(TabellaOperazioni.DATA) between " & Date & " And " & inizio & "'"

Set dbs = CurrentDb
Set FidoResiduo = dbs.OpenRecordset("SELECT  DISTINCTROW Sum(TabellaOperazioni.[TOTALE SEND]) AS [TOTALE SEND]," _
& "Sum(TabellaOperazioni.[IMPORTO RECEIVE]) AS [IMPORTO RECEIVE]," _
& "Sum(TabellaOperazioni.[TOTALE QUICK]) AS [TOTALE QUICK], Sum(TabellaOperazioni.BONIFICO) AS BONIFICO," _
& "Sum([TabellaOperazioni].[TOTALE SEND])-NZ(Sum([TabellaOperazioni].[IMPORTO RECEIVE]))-NZ(Sum([TabellaOperazioni].[BONIFICO]))+NZ(Sum([TabellaOperazioni].[TOTALE QUICK])) AS [DA PAGARE]," _
& "Round(DLookUp('[fido settimanale]','[tblFido]')+nz(Sum([TabellaOperazioni].[BONIFICO]))-nz(Sum([TabellaOperazioni].[TOTALE SEND]))+nz(Sum([TabellaOperazioni].[IMPORTO RECEIVE]))-nz(Sum([TabellaOperazioni].[TOTALE QUICK])),2) AS [FIDO RESIDUO]" _
& "FROM TabellaOperazioni WHERE(((TabellaOperazioni.DATA) Between Date() And Date()-5))")

MsgBox FidoResiduo("FIDO RESIDUO")

End Sub
Sì parliamo di Access, questa routine mi serve per visualizzare il fido residuo della settimana in corso, dal lunedì ad oggi, infatti la prima parte della routine assegna alla variabile "inizio" il valore calcolato togliendo a "date" tanti giorni quanti sono quelli da lunedì ad oggi, perciò io vorrei passare alla SQL la mia variabile.
CIUFFO è offline   Rispondi citando il messaggio o parte di esso
Old 10-01-2009, 09:53   #4
MarcoGG
Senior Member
 
L'Avatar di MarcoGG
 
Iscritto dal: Dec 2004
Messaggi: 3210
Quote:
Originariamente inviato da CIUFFO Guarda i messaggi

& "FROM TabellaOperazioni WHERE(((TabellaOperazioni.DATA) Between Date() And Date()-5))")
Riporto solo l'ultima linea del tuo codice.
Così, al volo :

Codice:
& "FROM TabellaOperazioni WHERE(((TabellaOperazioni.DATA) Between Date() And " & CDate(inizio) & "))" )
Se non ho fatto casino con le tonde dovrebbe andare...
MarcoGG è offline   Rispondi citando il messaggio o parte di esso
Old 10-01-2009, 13:49   #5
CIUFFO
Member
 
L'Avatar di CIUFFO
 
Iscritto dal: Feb 2001
Città: Reggio Emilia
Messaggi: 230
Codice:
Function CalcolaFidoResiduo()
Dim Differenza

If Weekday(Date) = 1 Then 'Domenica
Differenza = -6
End If
If Weekday(Date) = 2 Then 'Lunedi
Differenza = -0
End If
If Weekday(Date) = 3 Then 'Martedi
Differenza = -1
End If
If Weekday(Date) = 4 Then 'Mercoledi
Differenza = -2
End If
If Weekday(Date) = 5 Then 'Giovedi
Differenza = -3
End If
If Weekday(Date) = 6 Then 'Venerdi
Differenza = -4
End If
If Weekday(Date) = 7 Then 'Sabato
Differenza = -5
End If

Set dbs = CurrentDb
Set FidoResiduo = dbs.OpenRecordset("SELECT  DISTINCTROW Sum(TabellaOperazioni.[TOTALE SEND]) AS [TOTALE SEND]," _
& "Sum(TabellaOperazioni.[IMPORTO RECEIVE]) AS [IMPORTO RECEIVE]," _
& "Sum(TabellaOperazioni.[TOTALE QUICK]) AS [TOTALE QUICK], Sum(TabellaOperazioni.BONIFICO) AS BONIFICO," _
& "Sum([TabellaOperazioni].[TOTALE SEND])-NZ(Sum([TabellaOperazioni].[IMPORTO RECEIVE]))-NZ(Sum([TabellaOperazioni].[BONIFICO]))+NZ(Sum([TabellaOperazioni].[TOTALE QUICK])) AS [DA PAGARE]," _
& "Round(DLookUp('[fido settimanale]','[tblFido]')+nz(Sum([TabellaOperazioni].[BONIFICO]))-nz(Sum([TabellaOperazioni].[TOTALE SEND]))+nz(Sum([TabellaOperazioni].[IMPORTO RECEIVE]))-nz(Sum([TabellaOperazioni].[TOTALE QUICK])),2) AS [FIDO RESIDUO]" _
& "FROM TabellaOperazioni WHERE (TabellaOperazioni.DATA) between Date() And " & "Date()" & Differenza)

End Function
Ho risolto in questo modo
Grazie mille
CIUFFO è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Redmi Note 15 Pro+ 5G: autonomia monstre e display luminoso, ma il prezzo è alto Redmi Note 15 Pro+ 5G: autonomia monstre e displ...
HONOR Magic 8 Pro: ecco il primo TOP del 2026! La recensione HONOR Magic 8 Pro: ecco il primo TOP del 2026! L...
Insta360 Link 2 Pro e 2C Pro: le webcam 4K che ti seguono, anche con gimbal integrata Insta360 Link 2 Pro e 2C Pro: le webcam 4K che t...
Motorola edge 70: lo smartphone ultrasottile che non rinuncia a batteria e concretezza Motorola edge 70: lo smartphone ultrasottile che...
Display, mini PC, periferiche e networking: le novità ASUS al CES 2026 Display, mini PC, periferiche e networking: le n...
Samsung TV in offerta su Amazon: Neo QLE...
Sì, c'è un display è...
Fast restart di Windows spiegato 30 anni...
Il mondo piange Gladys West, la matemati...
Tomb Raider: Catalyst, il cast si allarg...
Renault Group chiude un ottimo 2025: Dac...
A questo prezzo la Blink Mini è difficil...
DJI Mini 4 Pro Fly More a 859€ su Amazon...
realme P4 Power avrà una batteria...
Marathon: data di uscita, edizioni e tut...
Dojo 3 riparte: Tesla affida a Intel il ...
Smartphone e attenzione in frantumi: Mat...
Aerei costruiti da robot umanoidi? L'eur...
Chery prende tutti in contropiede: batte...
Il colpo silenzioso di Intel: arriva l'u...
Chromium
GPU-Z
OCCT
LibreOffice Portable
Opera One Portable
Opera One 106
CCleaner Portable
CCleaner Standard
Cpu-Z
Driver NVIDIA GeForce 546.65 WHQL
SmartFTP
Trillian
Google Chrome Portable
Google Chrome 120
VirtualBox
Tutti gli articoli Tutte le news Tutti i download

Strumenti

Regole
Non Puoi aprire nuove discussioni
Non Puoi rispondere ai messaggi
Non Puoi allegare file
Non Puoi modificare i tuoi messaggi

Il codice vB è On
Le Faccine sono On
Il codice [IMG] è On
Il codice HTML è Off
Vai al Forum


Tutti gli orari sono GMT +1. Ora sono le: 10:49.


Powered by vBulletin® Version 3.6.4
Copyright ©2000 - 2026, Jelsoft Enterprises Ltd.
Served by www3v