Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Antigravity A1: drone futuristico per riprese a 360° in 8K con qualche lacuna da colmare
Antigravity A1: drone futuristico per riprese a 360° in 8K con qualche lacuna da colmare
Abbiamo messo alla prova il drone Antigravity A1 capace di riprese in 8K a 360° che permette un reframe in post-produzione ad eliche ferme. Il concetto è molto valido, permette al pilota di concentrarsi sul volo e le manovre in tutta sicurezza e decidere con tutta tranquillità come gestire le riprese. La qualità dei video, tuttavia, ha bisogno di uno step in più per essere competitiva
Sony Alpha 7 V, anteprima e novità della nuova 30fps, che tende la mano anche ai creator
Sony Alpha 7 V, anteprima e novità della nuova 30fps, che tende la mano anche ai creator
Dopo oltre 4 anni si rinnova la serie Sony Alpha 7 con la quinta generazione, che porta in dote veramente tante novità a partire dai 30fps e dal nuovo sensore partially stacked da 33Mpixel. L'abbiamo provata per un breve periodo, ecco come è andata dopo averla messa alle strette.
realme GT 8 Pro Dream Edition: prestazioni da flagship e anima racing da F1
realme GT 8 Pro Dream Edition: prestazioni da flagship e anima racing da F1
realme e Aston Martin Aramco F1 Team si sono (ri)unite dando alla vita un flagship con chip Snapdragon 8 Elite Gen 5 e design esclusivo ispirato alle monoposto di Formula 1. La Dream Edition introduce la nuova colorazione Lime Essence abbinata al tradizionale Aston Martin Racing Green, decorazioni intercambiabili personalizzate e una confezione a tema F1, intorno a uno smartphone dall'ottima dotazione tecnica con batteria da 7000mAh ricaricabile a 120W e isola fotografica intercambiabile
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 24-04-2002, 14:04   #1
Magnum2000
Senior Member
 
L'Avatar di Magnum2000
 
Iscritto dal: Mar 2001
Messaggi: 352
[VB]Compattare un database da programma: si può?

Ciao ragazzi!
Volevo chiedere se è possibile utilizzare un controllo di VB per inserire nel proprio programma una funzione che compatti un database Access.
Questa funzione dovrebbe servire a ripristinare un ordine sequenziale ai campi contatore, quando sono stati eliminati dei record con, appunto, dei campi contatore (scusate il gioco di parole).
Mi sbaglio?
Esiste un controllo del genere?
Grazie 1000!
__________________
"L'uomo che ha Fede è fortunato. Chi non ha Fede è una persona cui manca qualcosa nel profondo della sua esistenza. La Fede è speranza. L'uomo che abbandona questa speranza non è un uomo, è un disperato" [A. Zichichi]
Magnum2000 è offline   Rispondi citando il messaggio o parte di esso
Old 24-04-2002, 17:11   #2
tas
Senior Member
 
L'Avatar di tas
 
Iscritto dal: Feb 2001
Città: Nordest
Messaggi: 217
Non serve un controllo.

Se usi la libreria DAO basta scrivere così:

DAO.CompactDatabase(source, destination)

------

Se usi ADO, invece, devi caricare anche la libreria JRO (Microsoft Jet and Replicator object). Questo è un sample trovato su MSDN, che in più cripta il database:

Function EncryptDb(strSourceDB As String, _
strDestDB As String) As String
Dim jetEngine As JRO.JetEngine
Dim strSourceConnect As String
Dim strDestConnect As String

' Build connection strings for SourceConnection and
' DestConnection arguments.
strSourceConnect = "Data Source=" & strSourceDB
strDestConnect = "Data Source=" & strDestDB & ";" & _
"Jet OLEDB:Encrypt Database=True"

Set jetEngine = New JRO.JetEngine

' Compact and encrypt the database specified by strSourceDB
' to the name and path specified by strDestDB.
jetEngine.CompactDatabase strSourceConnect, strDestConnect

Set jetEngine = Nothing
End Function


Per fare solo la compattazione, basta modificare opportunamente la stringa di connessione.
tas è offline   Rispondi citando il messaggio o parte di esso
Old 25-04-2002, 00:05   #3
Magnum2000
Senior Member
 
L'Avatar di Magnum2000
 
Iscritto dal: Mar 2001
Messaggi: 352
Quote:
Originariamente inviato da tas
[b]Non serve un controllo.

Se usi la libreria DAO basta scrivere così:

DAO.CompactDatabase(source, destination)

------

Se usi ADO, invece, devi caricare anche la libreria JRO (Microsoft Jet and Replicator object). Questo è un sample trovato su MSDN, che in più cripta il database:

Function EncryptDb(strSourceDB As String, _
strDestDB As String) As String
Dim jetEngine As JRO.JetEngine
Dim strSourceConnect As String
Dim strDestConnect As String

' Build connection strings for SourceConnection and
' DestConnection arguments.
strSourceConnect = "Data Source=" & strSourceDB
strDestConnect = "Data Source=" & strDestDB & ";" & _
"Jet OLEDB:Encrypt Database=True"

Set jetEngine = New JRO.JetEngine

' Compact and encrypt the database specified by strSourceDB
' to the name and path specified by strDestDB.
jetEngine.CompactDatabase strSourceConnect, strDestConnect

Set jetEngine = Nothing
End Function


Per fare solo la compattazione, basta modificare opportunamente la stringa di connessione.
Moooolto interessante!
Ma perchè ci sono una stringa di partenza ed una di destinazione?
Se ho un file chiamato "db.mdb" e voglio compattarlo, strSourceDB sarà il path del programma con il file del database e strDestDB cos'è?
__________________
"L'uomo che ha Fede è fortunato. Chi non ha Fede è una persona cui manca qualcosa nel profondo della sua esistenza. La Fede è speranza. L'uomo che abbandona questa speranza non è un uomo, è un disperato" [A. Zichichi]
Magnum2000 è offline   Rispondi citando il messaggio o parte di esso
Old 25-04-2002, 00:07   #4
Magnum2000
Senior Member
 
L'Avatar di Magnum2000
 
Iscritto dal: Mar 2001
Messaggi: 352
Dimenticavo...
l'operazione di criptaggio (si chiama così?) in cosa consiste?
Se cripto un database, poi per leggerlo è diverso dal normale?
__________________
"L'uomo che ha Fede è fortunato. Chi non ha Fede è una persona cui manca qualcosa nel profondo della sua esistenza. La Fede è speranza. L'uomo che abbandona questa speranza non è un uomo, è un disperato" [A. Zichichi]
Magnum2000 è offline   Rispondi citando il messaggio o parte di esso
Old 25-04-2002, 18:04   #5
tas
Senior Member
 
L'Avatar di tas
 
Iscritto dal: Feb 2001
Città: Nordest
Messaggi: 217
L'operazione di compattazione non sovrascrive il database originale, ma lo copia in un nuovo file. Ecco perchè servono due stringhe!

L'operazione di crittografia impedisce la lettura dei dati da un editor di testo (come riporta la guida di Access), mentre risulta sempre leggibile da Access e ADO/DAO.
tas è offline   Rispondi citando il messaggio o parte di esso
Old 26-04-2002, 10:00   #6
Magnum2000
Senior Member
 
L'Avatar di Magnum2000
 
Iscritto dal: Mar 2001
Messaggi: 352
Quote:
Originariamente inviato da tas
[b]L'operazione di compattazione non sovrascrive il database originale, ma lo copia in un nuovo file. Ecco perchè servono due stringhe!

L'operazione di crittografia impedisce la lettura dei dati da un editor di testo (come riporta la guida di Access), mentre risulta sempre leggibile da Access e ADO/DAO.
1) Ma poi come faccio a dire al mio programma di caricare i dati dal nuovo file?
Si può eseguire la procedura, sovrascrivendo il vecchi file?

2)Con un editor di testo??
Che si può fare?
__________________
"L'uomo che ha Fede è fortunato. Chi non ha Fede è una persona cui manca qualcosa nel profondo della sua esistenza. La Fede è speranza. L'uomo che abbandona questa speranza non è un uomo, è un disperato" [A. Zichichi]
Magnum2000 è offline   Rispondi citando il messaggio o parte di esso
Old 26-04-2002, 17:36   #7
tas
Senior Member
 
L'Avatar di tas
 
Iscritto dal: Feb 2001
Città: Nordest
Messaggi: 217
Io di solito faccio così:
[list=1][*]eseguo la compattazione di ARCHIVIO.MDB sul file ARCHIVIO.TMP[*]se tutto è andato bene, rinomino ARCHIVIO.MDB in ARCHIVIO.001[*]rinomino ARCHIVIO.TMP in ARCHIVIO.MDB[/list=1]


Riguardo al discorso dell'editor di testo... diciamo che è un discorso di sicurezza. Se imposti una password per accedere ad un archivio, per un utente sprovvisto di password sarà impossibile aprirlo con Access o con ADO/DAO. Se però uno tenta lo stesso di carpire le informazioni contenute nell'archivio, riuscirà a leggere i testi contenuti con un editor di testo o meglio con visualizzatore binario... a meno che l'archivio non sia stato criptato!
tas è offline   Rispondi citando il messaggio o parte di esso
Old 26-04-2002, 19:26   #8
Magnum2000
Senior Member
 
L'Avatar di Magnum2000
 
Iscritto dal: Mar 2001
Messaggi: 352
Quote:
Originariamente inviato da tas
[b]Io di solito faccio così:
[list=1][*]eseguo la compattazione di ARCHIVIO.MDB sul file ARCHIVIO.TMP[*]se tutto è andato bene, rinomino ARCHIVIO.MDB in ARCHIVIO.001[*]rinomino ARCHIVIO.TMP in ARCHIVIO.MDB[/list=1]
Senti, so che la domanda che ti farò è un pò invasiva...
...però, se non ci si aiuta tra di noi..
Mi piacerebbe capire il meccanismo di compattazione; mi puoi aiutare? (non è da molto che utilizzo VB)
__________________
"L'uomo che ha Fede è fortunato. Chi non ha Fede è una persona cui manca qualcosa nel profondo della sua esistenza. La Fede è speranza. L'uomo che abbandona questa speranza non è un uomo, è un disperato" [A. Zichichi]
Magnum2000 è offline   Rispondi citando il messaggio o parte di esso
Old 27-04-2002, 12:15   #9
tas
Senior Member
 
L'Avatar di tas
 
Iscritto dal: Feb 2001
Città: Nordest
Messaggi: 217
Quote:
Originariamente inviato da Magnum2000
[b]

Senti, so che la domanda che ti farò è un pò invasiva...
...però, se non ci si aiuta tra di noi..
Mi piacerebbe capire il meccanismo di compattazione; mi puoi aiutare? (non è da molto che utilizzo VB)

La compattazione serve per recuperare lo spazio perso quando per esempio cancelli un record. Per motivi di performances, Jet non recupera quello spazio, in quanto tale operazione richiederebbe uno spostamento a volte ingente di dati.

Sempre per motivi di performances, viene creato in coda ad ogni tabella uno spazio vuoto maggiore di quello necessario per inserire un record. Questo blocco di byte verrà via via riempito di record, poi quando questo sarà pieno verrà creato un nuovo blocco e via dicendo. Anche in questo caso, l'operazione di inserimento di un nuovo blocco comporta rallentamenti generali al database, ma tale operazione viene eseguita una volta "ogni tanto" e quindi generalmente l'archivio continua ad essere veloce.

Compattando l'archivio (in realtà, con le ultime versioni del Jet, le operazioni CompactDatabase e RepairDatabase sono la stessa cosa) si va a recuperare tutto lo spazio inutile nelle varie tabelle.

Naturalmente, appena si andrà ad aggiungere un nuovo record, Jet inserirà di nuovo un blocco in coda alla tabella, vanificando in parte la compattazione appena svolta.
tas è offline   Rispondi citando il messaggio o parte di esso
Old 27-04-2002, 12:25   #10
Magnum2000
Senior Member
 
L'Avatar di Magnum2000
 
Iscritto dal: Mar 2001
Messaggi: 352
Quote:
Originariamente inviato da tas
[b]


La compattazione serve ...

...le operazioni CompactDatabase e RepairDatabase sono la stessa cosa) ...

HMMMM!
Mi potresti scrivere la sintassi completa di questi due comandi? (CompactDatabase e RepairDatabase)

Quale dei due mi consigli di utilizzare?
Che dici, mi conviene inserire nel mio programmino un pulsante che consenta di compattare il database?

Ah, ritornando al discorso del "Criptaggio", come faccio a leggere i dati una volta criptato il database?
La stringa di connessione cambia, vero?
__________________
"L'uomo che ha Fede è fortunato. Chi non ha Fede è una persona cui manca qualcosa nel profondo della sua esistenza. La Fede è speranza. L'uomo che abbandona questa speranza non è un uomo, è un disperato" [A. Zichichi]
Magnum2000 è offline   Rispondi citando il messaggio o parte di esso
Old 27-04-2002, 12:39   #11
Magnum2000
Senior Member
 
L'Avatar di Magnum2000
 
Iscritto dal: Mar 2001
Messaggi: 352
per TAS

All'indirizzo seguente dell'MSDN ho trovato questo codice per riparare un database:
http://msdn.microsoft.com/library/de...rdatabasex.asp

Codice:
Sub RepairDatabaseX()

    Dim errLoop As Error

    If MsgBox("Repair the Northwind database?", _
            vbYesNo) = vbYes Then
        On Error GoTo Err_Repair
        DBEngine.RepairDatabase "Northwind.mdb"
        On Error GoTo 0
        MsgBox "End of repair procedure!"
    End If

    Exit Sub

Err_Repair:

    For Each errLoop In DBEngine.Errors
        MsgBox "Repair unsuccessful!" & vbCr & _
            "Error number: " & errLoop.Number & _
            vbCr & errLoop.Description
    Next errLoop

End Sub
E' questo il metodo che dicevi?
Basta modificare il nome del database?
__________________
"L'uomo che ha Fede è fortunato. Chi non ha Fede è una persona cui manca qualcosa nel profondo della sua esistenza. La Fede è speranza. L'uomo che abbandona questa speranza non è un uomo, è un disperato" [A. Zichichi]
Magnum2000 è offline   Rispondi citando il messaggio o parte di esso
Old 27-04-2002, 17:37   #12
tas
Senior Member
 
L'Avatar di tas
 
Iscritto dal: Feb 2001
Città: Nordest
Messaggi: 217
Re: per TAS

Quote:
Originariamente inviato da Magnum2000
[b]
E' questo il metodo che dicevi?
Basta modificare il nome del database?
Dipende: quel codice è relativo a DAO, se invece usi ADO...

Codice:
jetEngine.CompactDatabase strSourceConnect, strDestConnect
(in ADO non esiste più RepairDatabase)

ciao
tas è offline   Rispondi citando il messaggio o parte di esso
Old 27-04-2002, 20:38   #13
Magnum2000
Senior Member
 
L'Avatar di Magnum2000
 
Iscritto dal: Mar 2001
Messaggi: 352
Re: Re: per TAS

Quote:
Originariamente inviato da tas
[b]

Dipende: quel codice è relativo a DAO, se invece usi ADO...

Codice:
jetEngine.CompactDatabase strSourceConnect, strDestConnect
(in ADO non esiste più RepairDatabase)

ciao
Aaaaa.
Ma, scusame se te lo ripeto, come faccio a fare un backup del database e rinominare quello vecchio?
__________________
"L'uomo che ha Fede è fortunato. Chi non ha Fede è una persona cui manca qualcosa nel profondo della sua esistenza. La Fede è speranza. L'uomo che abbandona questa speranza non è un uomo, è un disperato" [A. Zichichi]
Magnum2000 è offline   Rispondi citando il messaggio o parte di esso
Old 29-04-2002, 10:44   #14
tas
Senior Member
 
L'Avatar di tas
 
Iscritto dal: Feb 2001
Città: Nordest
Messaggi: 217
Ecco i comandi dei quali hai bisogno:
Codice:
FileCopy source, destination
Name oldpathname As newpathname
Kill pathname
  • FileCopy copia un file;
    Name permette di rinominare o spostare un file o una directory;
    Kill elimina un file
tas è offline   Rispondi citando il messaggio o parte di esso
Old 29-04-2002, 13:03   #15
Magnum2000
Senior Member
 
L'Avatar di Magnum2000
 
Iscritto dal: Mar 2001
Messaggi: 352
Quote:
Originariamente inviato da tas
[b]Ecco i comandi dei quali hai bisogno:
Codice:
FileCopy source, destination
Name oldpathname As newpathname
Kill pathname
  • FileCopy copia un file;
    Name permette di rinominare o spostare un file o una directory;
    Kill elimina un file

Vediamo un pò:

1)"source" e "destination" sono percorsi (senza il nome del file)
2)"oldpathname" e "newpathname" sono percorsi (con il nome del file)
3)"pathname" percorso con nome del file

Giusto?
__________________
"L'uomo che ha Fede è fortunato. Chi non ha Fede è una persona cui manca qualcosa nel profondo della sua esistenza. La Fede è speranza. L'uomo che abbandona questa speranza non è un uomo, è un disperato" [A. Zichichi]
Magnum2000 è offline   Rispondi citando il messaggio o parte di esso
Old 29-04-2002, 13:44   #16
tas
Senior Member
 
L'Avatar di tas
 
Iscritto dal: Feb 2001
Città: Nordest
Messaggi: 217
Guardati questi help su MSDN:
ciao
tas è offline   Rispondi citando il messaggio o parte di esso
Old 29-04-2002, 16:20   #17
Magnum2000
Senior Member
 
L'Avatar di Magnum2000
 
Iscritto dal: Mar 2001
Messaggi: 352
Quote:
Originariamente inviato da tas
[b]Guardati questi help su MSDN:
ciao
Grazie tas!
Quanta pazienza che hai.
__________________
"L'uomo che ha Fede è fortunato. Chi non ha Fede è una persona cui manca qualcosa nel profondo della sua esistenza. La Fede è speranza. L'uomo che abbandona questa speranza non è un uomo, è un disperato" [A. Zichichi]
Magnum2000 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Antigravity A1: drone futuristico per riprese a 360° in 8K con qualche lacuna da colmare Antigravity A1: drone futuristico per riprese a ...
Sony Alpha 7 V, anteprima e novità della nuova 30fps, che tende la mano anche ai creator Sony Alpha 7 V, anteprima e novità della ...
realme GT 8 Pro Dream Edition: prestazioni da flagship e anima racing da F1 realme GT 8 Pro Dream Edition: prestazioni da fl...
OVHcloud Summit 2025: le novità del cloud europeo tra sovranità, IA e quantum OVHcloud Summit 2025: le novità del cloud...
Un mostro da MSI: QD-OLED WQHD a 500 Hz con AI Care e DisplayPort 2.1a Un mostro da MSI: QD-OLED WQHD a 500 Hz con AI C...
Axiom Space ha completato un importante ...
Gli aeroplani Airbus utilizzeranno i sat...
Una nuova immagine della cometa interste...
'La soluzione a un problema che non esis...
Radeon RX 9000 sì, Ryzen 9000 no:...
Amazon versa 180 milioni al Fisco e canc...
Meta, il Board di Supervisione guarda o...
DJI rivoluziona le consegne aeree: il nu...
Fibercop e Microsoft Italia uniscono per...
App Store Award 2025: scarica le 17 app ...
NVIDIA fa marcia indietro, il supporto P...
Addio definitivo alla GeForce GTX 1080: ...
Numeri record per gli iPhone 17: Apple s...
L'Italia del 2025 raccontata da Google: ...
Piaggio lancia Porter NPE, il pick-up el...
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:09.


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