lorixillo
22-09-2010, 12:43
come prima cosa salve a tutti!
ho un problema di inserimento di record in un database access mediante l'utilizzo di driver jdbc.
sto realizzando il trasferimento di vecchie tabelle btrieve di un programma di gestione delle donazioni di sangue per l'AVIS in tabelle access mediante java.
per prima cosa ho trasformato le tabelle btrieve .btr in file di testo .txt mediante un apposito tool.
poi ho creato un programma java che estrapola le informazioni di ogni riga del txt, crea una query di tipo INSERT INTO e inserisce la riga nel DB tramite il sistema
ps = con.prepareStatement(creaQuery(dati));
ps.executeUpdate();
fin qui tutto bene, ma poi accade una cosa alquanto strana!
ebbene, mentre una tabella è inserita correttamente e velocemente (stampando a video ogni query di insert ne compaiono a video circa 200 al secondo), l'altra viene inserita altrettanto velocemente per i primi 196-197 records, mentre i rimanenti vengono inseriti con una frequenza di circa 1 al secondo °_°!
ebbene, i record sono tipo 73000, non ho tutto questo tempo da perdere xD
ho controllato il controllabile :muro: , in particolare:
- non è colpa dell'istruzione executeQuery() dato che, commentandola, il risultato non cambia;
- non è colpa della simultanea lettura da file, dato che l'altra tabella è inserita correttamente (ed è una tabella con una 15ina di campi!!!);
- non è colpa della tabella access dove vado a inserire i record, dato che è simile in tutto per tutto all'altra! inoltre la rigenero spesso senza ottenere alcun risultato;
- isolando l'istruzione prepareStatement() ho scoperto che è proprio lei (e nessun altro) il problema (ho provato pure con un inserimento fuffa del tipo "INSERT INTO TABELLAFUFFA (A,B) VALUES ('a','b')" e si blocca dopo le solite prime 197 righe...).
ecco ulteriori dettagli sparsi che possono esservi utili nell'aiutarmi:
modello query funzionante:
INSERT INTO DONATORE (IdDonatore, CognomeNome, IdSesso, Indirizzo, CAP, Comune, Provincia, DataNascita, ComuneNascita, TelefonoPrincipale, TelefonoSecondario, CodiceProfessione, Frequenza, IdGruppoSanguigno, IdFattoreRH, Fenotipi, DataRilascio, DataCessazione, IdTipoTessera, IdTipoDonazione, IdTitoloStudio, IdStatoDonatore, IdAvvisoChiamata, IdGiornale) VALUES (0000, 'cogn nom', 0, 'Via Fuffa 1', '12121', 'casa sua', 'CS', '01/01/1753', 'comune', '01010104345', '0349343434', 0, 2, 0, 1, 'ccDeekk', '09/04/1294', null, 1, 0, 3, 0, 1, 1)
modello query capricciosa:
INSERT INTO DONAZIONE (IdDonatore, Numero, Data, IdTipoDonazione, Luogo) VALUES (15, 2, '22/01/1984', 1, 'ospedale')
grazie a coloro che proveranno ad aiutarmi!
Loris
ho un problema di inserimento di record in un database access mediante l'utilizzo di driver jdbc.
sto realizzando il trasferimento di vecchie tabelle btrieve di un programma di gestione delle donazioni di sangue per l'AVIS in tabelle access mediante java.
per prima cosa ho trasformato le tabelle btrieve .btr in file di testo .txt mediante un apposito tool.
poi ho creato un programma java che estrapola le informazioni di ogni riga del txt, crea una query di tipo INSERT INTO e inserisce la riga nel DB tramite il sistema
ps = con.prepareStatement(creaQuery(dati));
ps.executeUpdate();
fin qui tutto bene, ma poi accade una cosa alquanto strana!
ebbene, mentre una tabella è inserita correttamente e velocemente (stampando a video ogni query di insert ne compaiono a video circa 200 al secondo), l'altra viene inserita altrettanto velocemente per i primi 196-197 records, mentre i rimanenti vengono inseriti con una frequenza di circa 1 al secondo °_°!
ebbene, i record sono tipo 73000, non ho tutto questo tempo da perdere xD
ho controllato il controllabile :muro: , in particolare:
- non è colpa dell'istruzione executeQuery() dato che, commentandola, il risultato non cambia;
- non è colpa della simultanea lettura da file, dato che l'altra tabella è inserita correttamente (ed è una tabella con una 15ina di campi!!!);
- non è colpa della tabella access dove vado a inserire i record, dato che è simile in tutto per tutto all'altra! inoltre la rigenero spesso senza ottenere alcun risultato;
- isolando l'istruzione prepareStatement() ho scoperto che è proprio lei (e nessun altro) il problema (ho provato pure con un inserimento fuffa del tipo "INSERT INTO TABELLAFUFFA (A,B) VALUES ('a','b')" e si blocca dopo le solite prime 197 righe...).
ecco ulteriori dettagli sparsi che possono esservi utili nell'aiutarmi:
modello query funzionante:
INSERT INTO DONATORE (IdDonatore, CognomeNome, IdSesso, Indirizzo, CAP, Comune, Provincia, DataNascita, ComuneNascita, TelefonoPrincipale, TelefonoSecondario, CodiceProfessione, Frequenza, IdGruppoSanguigno, IdFattoreRH, Fenotipi, DataRilascio, DataCessazione, IdTipoTessera, IdTipoDonazione, IdTitoloStudio, IdStatoDonatore, IdAvvisoChiamata, IdGiornale) VALUES (0000, 'cogn nom', 0, 'Via Fuffa 1', '12121', 'casa sua', 'CS', '01/01/1753', 'comune', '01010104345', '0349343434', 0, 2, 0, 1, 'ccDeekk', '09/04/1294', null, 1, 0, 3, 0, 1, 1)
modello query capricciosa:
INSERT INTO DONAZIONE (IdDonatore, Numero, Data, IdTipoDonazione, Luogo) VALUES (15, 2, '22/01/1984', 1, 'ospedale')
grazie a coloro che proveranno ad aiutarmi!
Loris