Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Sony WF-1000X M6: le cuffie in-ear di riferimento migliorano ancora
Sony WF-1000X M6: le cuffie in-ear di riferimento migliorano ancora
WF-1000X M6 è la sesta generazione di auricolare in-ear sviluppata da Sony, un prodotto che punta a coniugare facilità di utilizzo con una elevata qualità di riproduzione dei contenuti audio e una cura nella riduzione del rumore ambientale che sia da riferimento
Snowflake porta l'IA dove sono i dati, anche grazie a un accordo con OpenAI
Snowflake porta l'IA dove sono i dati, anche grazie a un accordo con OpenAI
Snowflake ha presentato diverse novità per la sua piattaforma legate all'intelligenza artificiale. Quella forse più eclatante è una collaborazione con OpenAI, ma non mancano diverse nuove funzionalità che rendono la piattaforma più flessibile e in grado di rispondere meglio alle esigenze in continuo cambiamento delle aziende
Sistema Mesh Roamii BE Pro: il Wi-Fi 7 secondo MSI
Sistema Mesh Roamii BE Pro: il Wi-Fi 7 secondo MSI
Con velocità teoriche fino a 11 Gbps, gestione tramite app intelligente e protezione avanzata dei dispositivi, Roamii BE Pro porta il Wi‑Fi 7 tri‑band nelle abitazioni più esigenti. Un sistema Wi-Fi Mesh proposto da MSI allo scopo di garantire agli utenti una rete fluida e continua capace di sostenere streaming 8K, gaming competitivo e le applicazioni moderne più esigenti in termini di banda
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 19-11-2002, 15: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, 19: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, 01: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, 01: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


Sony WF-1000X M6: le cuffie in-ear di riferimento migliorano ancora Sony WF-1000X M6: le cuffie in-ear di riferiment...
Snowflake porta l'IA dove sono i dati, anche grazie a un accordo con OpenAI Snowflake porta l'IA dove sono i dati, anche gra...
Sistema Mesh Roamii BE Pro: il Wi-Fi 7 secondo MSI Sistema Mesh Roamii BE Pro: il Wi-Fi 7 secondo M...
Recensione HUAWEI Mate X7: un foldable ottimo, ma restano i soliti problemi Recensione HUAWEI Mate X7: un foldable ottimo, m...
Nioh 3: souls-like punitivo e Action RPG Nioh 3: souls-like punitivo e Action RPG
Zscaler Threat Report 2026: l'adozione d...
Claude AI minaccia omicidi e ricatti qua...
Dentro la gara: a Milano Cortina 2026 i ...
Samsung Display presenta QD-OLED Penta T...
KONAMI torna con "Silent Hill: Town...
Rende il citofono smart a 44,99€: Ring I...
ThunderX3 XTC, la sedia da ufficio che s...
Mercy, Mission Impossible, Aronofsky: il...
Project Windless: il nuovo action in esc...
Saros: mostrato il gameplay del gioco de...
God of War: Sons of Sparta annunciato e ...
John Wick torna in un nuovo videogioco a...
MADE chiude il 2025 con 59 partner e 250...
007 First Light: allo State of Play un n...
Gli iPhone su Amazon costano meno che su...
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: 05:34.


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