Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Plaud Note Pro convince per qualità e integrazione, ma l’abbonamento resta un ostacolo
Plaud Note Pro convince per qualità e integrazione, ma l’abbonamento resta un ostacolo
Plaud Note Pro è un registratore digitale elegante e tascabile con app integrata che semplifica trascrizioni e riepiloghi, offre funzioni avanzate come template e note intelligenti, ma resta vincolato a un piano a pagamento per chi ne fa un uso intensivo
Google Pixel 10 è compatto e ha uno zoom 5x a 899€: basta per essere un best-buy?
Google Pixel 10 è compatto e ha uno zoom 5x a 899€: basta per essere un best-buy?
Google Pixel 10 è uno smartphone che unisce una fotocamera molto più versatile rispetto al passato grazie allo zoom ottico 5x, il supporto magnetico Pixelsnap e il nuovo chip Tensor G5. Il dispositivo porta Android 16 e funzionalità AI avanzate come Camera Coach, mantenendo il design caratteristico della serie Pixel con miglioramenti nelle prestazioni e nell'autonomia. In Italia, però, mancano diverse feature peculiari basate sull'AI.
Prova GeForce NOW upgrade Blackwell: il cloud gaming cambia per sempre
Prova GeForce NOW upgrade Blackwell: il cloud gaming cambia per sempre
L'abbonamento Ultimate di GeForce NOW ora comprende la nuova architettura Blackwell RTX con GPU RTX 5080 che garantisce prestazioni tre volte superiori alla precedente generazione. Non si tratta solo di velocità, ma di un'esperienza di gioco migliorata con nuove tecnologie di streaming e un catalogo giochi raddoppiato grazie alla funzione Install-to-Play
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 19-11-2002, 14:47   #1
Carmen
Senior Member
 
Iscritto dal: Jul 2001
Messaggi: 367
Sql per la somma dei dati

Ciao.


in un modulo *.BAS irserisco il questo codice

Private DB As Database
Private rsVari As Recordset


quando mi serve nei vari form del progetto utilizzo questo codice per fare delle determinate somme filtrando i dati dal DB:

Set DB = OpenDatabase(App.Path & "\NomeDB.mdb")
Set rsVari = DB.OpenRecordset("SELECT Sum(Importo) as Totale, Sum(Importo*aliquotaIVA/100) as Iva FROM TabellaDB WHERE ID=" & Parametro)

If IsNull(rsVari("Totale")) = False And IsNull(rsVari("Iva")) = False Then
MsgBox rsVari("Totale")
MsgBox rsVari("Iva")
else
'nessun record che rispecchi i parametri di ricerca
end if


La cosa funziona tranquillamente, il problema che non riesco ad capire dove possa risiedere e che di tanto in tanto, capita che non mi fà più le somme. In pratica e come se L'SQL non filtri più i nessun dato. Se chiudo il programma ed rietro rifunziona.

Sinceramente non capisco cosa possa essere. Per questo chiedo un vostro parere, e se magari se si possa fare la stessa cosa utilizzando invece di un SQL un tipo di ricerca indicizzata. con il SEEK, sempre chè sia migliore rispetto all'SQL sopra citata.

spero in un vostro AIUTO!!!!!!!!

Carmen
Carmen è offline   Rispondi citando il messaggio o parte di esso
Old 19-11-2002, 18:05   #2
tas
Senior Member
 
L'Avatar di tas
 
Iscritto dal: Feb 2001
Città: Nordest
Messaggi: 217
Che strano... forse è un problema di memoria. Ti sei ricordata di rilasciare la memoria degli oggetti non più utilizzati? Esempio:
Codice:
Dim db As Database
Dim rs As Recordset
Dim sql As String

'creo oggetti...
Set db = OpenDatabase(App.Path & "\NomeDB.mdb")
sql = "SELECT Sum(Importo) as Totale, ..."
Set rs = db.OpenRecordset(sql)

'utilizzo gli oggetti

...

'in chiusura rilascio la memoria
rs.Close
db.Close
Set rs = Nothing
Set db = Nothing
tas è offline   Rispondi citando il messaggio o parte di esso
Old 20-11-2002, 00:03   #3
Carmen
Senior Member
 
Iscritto dal: Jul 2001
Messaggi: 367
Ciao. Si alla fine chiudevo sia DB.close che rs.Close.
Non avevo messo però:
Set rs = Nothing
Set db = Nothing

Due domande da farti:

1) Ai impostato L'SQL un pò diversa, la cosa può essere rilevante o meno rispetto alla mia versione?

2) Siccome eseguo in diversi punti più o meno queste operazioni penzavo di dichiarare una volta sola in un modulo *.BAS queste variabili:

Dim db As Database
Dim rs As Recordset
Dim sql As String


Come:
public db As Database
public rs As Recordset
public sql As String


ovviamente subito dopo ogni esecuzione della routine rilascio subito la memoria:

rs.Close
db.Close
Set rs = Nothing
Set db = Nothing

Cosa ne penzi???. Ciao
Carmen è offline   Rispondi citando il messaggio o parte di esso
Old 20-11-2002, 00:45   #4
tas
Senior Member
 
L'Avatar di tas
 
Iscritto dal: Feb 2001
Città: Nordest
Messaggi: 217
Risposta 1: nessuna differenza, ho usato la variabile sql solo per migliorare la leggibilità del codice

Risposta 2: nel modo come l'hai descritto non serve a nulla, piuttosto farei così:
Codice:
'in un modulo .bas :
Public db As Database

'nell'evento Load del form principale:
Set db = OpenDatabase(App.Path & "\NomeDB.mdb")

'nell'evento Unload del form principale:
db.Close
Set db = Nothing

'dentro ad una qualsiasi procedura:
Dim rs As Recordset
Dim sql As String

sql = "SELECT ... "
Set rs = db.OpenRecordset(sql, dbOpenDynaset)
...
rs.Close
Set rs = Nothing
In sostanza tengo aperto il database per tutto il tempo nel quale l'applicazione rimane aperta, in maniera molto simile a quello che fa Access. Quando ho bisogno di un recordset utilizzo la variabile db già inizializzata.

ciao
tas è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Plaud Note Pro convince per qualità e integrazione, ma l’abbonamento resta un ostacolo Plaud Note Pro convince per qualità e int...
Google Pixel 10 è compatto e ha uno zoom 5x a 899€: basta per essere un best-buy? Google Pixel 10 è compatto e ha uno zoom ...
Prova GeForce NOW upgrade Blackwell: il cloud gaming cambia per sempre Prova GeForce NOW upgrade Blackwell: il cloud ga...
Ecovacs Deebot X11 Omnicyclone: niente più sacchetto per lo sporco Ecovacs Deebot X11 Omnicyclone: niente più...
Narwal Flow: con il mocio orizzontale lava i pavimenti al meglio Narwal Flow: con il mocio orizzontale lava i pav...
Xpeng produrrà in Europa: siglato...
Microsoft 365 Copilot si installer&agrav...
VMware perderà il 35% delle appli...
Arriva Managed Kubernetes Standard, la p...
Dal MIT un nuovo elettrolita solido auto...
Object First annuncia la disponibilit&ag...
Apple lancia Music Transfer Tool: import...
Mario Draghi critica gli obiettivi green...
Dimensity 9500 promette prestazioni da p...
HybridPetya, il ransomware che può...
Apple Mac mini con chip M4 a prezzi mai ...
Alphabet, società madre di Google...
Incidente con Tesla in Svizzera: il prop...
Shein chiude a Stradella e si sposta in ...
Cosa ci ha detto IAA Mobility 2025? Elet...
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: 12:22.


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