Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Recensione Samsung Galaxy S26 Ultra: finalmente qualcosa di nuovo
Recensione Samsung Galaxy S26 Ultra: finalmente qualcosa di nuovo
Per diversi giorni il Galaxy S26 Ultra di Samsung è stato il nostro compagno di vita. Oltre alle conferme del colosso coreano come la qualità del display e una suite AI senza rivali, arriva il Privacy Display, un unicum nel mondo smartphone. Ci sono ancora alcuni gap che non sono riusciti a colmare lato batteria e fotocamera, seppur con alcuni miglioramenti.
Diablo II Resurrected: il nuovo DLC Reign of the Warlock
Diablo II Resurrected: il nuovo DLC Reign of the Warlock
Abbiamo provato per voi il nuovo DLC lanciato a sorpresa da Blizzard per Diablo II: Resurrected e quella che segue è una disamina dei nuovi contenuti che abbiamo avuto modo di sperimentare nel corso delle nostre sessioni di gioco, con particolare riguardo per la nuova classe dello Stregone
Deep Tech Revolution: così Area Science Park apre i laboratori alle startup
Deep Tech Revolution: così Area Science Park apre i laboratori alle startup
Siamo tornati nel parco tecnologico di Trieste per il kick-off del programma che mette a disposizione di cinque startup le infrastrutture di ricerca, dal sincrotrone Elettra ai laboratori di genomica e HPC. Roberto Pillon racconta il modello e la visione
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 20-10-2009, 12:20   #1
serpico84
Senior Member
 
L'Avatar di serpico84
 
Iscritto dal: Sep 2005
Messaggi: 342
[JAVA E DB ACCESS] Accedere a DB Access

Devo creare una procedura che in ingresso prende il path che contiene la destinazione del file .mdb Access (facciamo finta che già si conosca questo path) e che, se il path è esatto, accede al database (quindi penso mi servano i driver per caricare il db access)...qualcuno può darmi una mano??
serpico84 è offline   Rispondi citando il messaggio o parte di esso
Old 20-10-2009, 14:18   #2
SodoMyzer
Bannato
 
Iscritto dal: Mar 2004
Messaggi: 76
Lo feci un pò di tempo fa...e nn ricordo bene il tutto ...comunque...
Dal basso della mia scarsa esperienza:
potresti creare una variabile di sistema in Pannello di controllo-Sistema-(Scheda AVANZATE),in basso a sx c'è il bottone "Variabili d'ambiente",
oppure
da Pannello di Controllo-strumenti di amministrazione-Origine dati (ODBC)
e in DSN utente o di sistema nemmeno ricordo, fare AGGIUNGI-Microsoft Access Driver
nella finestra che ti esce metti il nome da richiamare (nel mio caso DbLibri) e settare il percorso lì.
(mi sembra più la seconda)

non ricordo bene come feci...per ora ti posto una vecchia classe che scrissi per il file DbLibri.mdb che usava il DSN
(non il path intero come serve a te...).

Codice:
public class DBTest
{
public static void main(String[] args) 
{
	{
		try 
		{ 
		Class.forName("sun.jdbc.odbc.JdbcOdbcDriver"); 
		System.err.println("Driver trovato");
		} 
		catch(ClassNotFoundException e) 
		{ 
		System.out.println(e.toString());
		System.out.println("Il driver non può essere caricato");
		System.exit(1);
		} 
	}

		try 
		{
		Connection conn = DriverManager.getConnection("jdbc:odbc:DbLibri.mdb","",""); 
	     	System.err.println("Connessione OK!");
	        Statement stmt = conn.createStatement(); 
	     	System.err.println("Statement creato");
		ResultSet rs = stmt.executeQuery("SELECT TITOLO FROM LIBRO"); 
		System.err.println("Query eseguita");
		while(rs.next()) 
			{System.out.println(rs.getString("titolo"));}
//"titolo" è il nome della colonna, volendo possiamo mettere (1) ad esempio
//se vogliamo il valore del primo campo
//Usare gli opportuni "get" (getInt,getDate ecc ecc) a seconda del tipo
		rs.close(); 
		stmt.close(); 
		conn.close();	
		}	
		catch(SQLException _sql)
		{
		System.out.println(_sql.getMessage()); 
		_sql.printStackTrace(System.out); 
		System.exit(1); 
		}
}
Il fatto di poter scrivere senza percorso completo
DriverManager.getConnection("jdbc:odbcbLibri.mdb","","");
si può fare proprio perchè settando una variabile d'ambiente, quando la si richiama è il sistema a indirizzarti nella cartella e al file.
Nel tuo caso, nel creare un metodo che prende in input una stringa del path, al posto di "DbLibri" mi pare che debba andarci tutto il path...prova un pò!
I due campi vuoti alla fine della stringa di connessione dovrebbero essere user e password, che, se ricordo bene, in access non esistono.

Ultima modifica di SodoMyzer : 20-10-2009 alle 14:37.
SodoMyzer è offline   Rispondi citando il messaggio o parte di esso
Old 20-10-2009, 14:45   #3
serpico84
Senior Member
 
L'Avatar di serpico84
 
Iscritto dal: Sep 2005
Messaggi: 342
grazie dell'aiuto fra un po proverò il tuo esempio...ma per caso devo importare qualche libreria al progetto?? Per il momento per come lo sto facendo io mi da questo errore:

java.sql.SQLException: [Microsoft][Driver Manager ODBC] Nome origine dati non trovato e driver predefinito non specificato.

Sono molto niubbo nel settore....
serpico84 è offline   Rispondi citando il messaggio o parte di esso
Old 20-10-2009, 16:24   #4
serpico84
Senior Member
 
L'Avatar di serpico84
 
Iscritto dal: Sep 2005
Messaggi: 342
Ecco la funzione che lancio per il momento

Codice:
public String avvia() {
        recuperoDati();//lancia il recupero dati da file
        String risposta = "";
        System.out.println("Avvio connessione");
        try {
            //Carico il Driver
            Class.forName("sun.jdbc.odbc.JdbcOdbcDriver").newInstance();
            //Indico il database al quale devo connettermi
            conn = (Connection) DriverManager.getConnection("jdbc:odbc:DRIVER=Microsoft Access Driver(*.mdb);DBQ=backup19_10_2009.mdb");
            System.out.println("Connessione stabilita con il Database");
        } catch (InstantiationException ex) {
            risposta = "Problema di connessione" + ex.getMessage();
        } catch (IllegalAccessException ex) {
            risposta = "Problema si connessione" + ex.getMessage();
        } catch (ClassNotFoundException e) {
            risposta = "Driver non trovato" + e.getMessage();
        } catch (SQLException e) {
            risposta = "E' stata rilevata SQLException: " + e.getMessage();
        }
        System.out.println(risposta);
        return risposta;
    }
per adesso ci metto l'esatta posizione del database su DBQ=backup19_10_2009.mdb (il database è all'interno del progetto altimenti metto c:\\.....)

Ultima modifica di serpico84 : 20-10-2009 alle 19:39.
serpico84 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Recensione Samsung Galaxy S26 Ultra: finalmente qualcosa di nuovo Recensione Samsung Galaxy S26 Ultra: finalmente ...
Diablo II Resurrected: il nuovo DLC Reign of the Warlock Diablo II Resurrected: il nuovo DLC Reign of the...
Deep Tech Revolution: così Area Science Park apre i laboratori alle startup Deep Tech Revolution: così Area Science P...
HP OMEN MAX 16 con RTX 5080: potenza da desktop replacement a prezzo competitivo HP OMEN MAX 16 con RTX 5080: potenza da desktop ...
Recensione Google Pixel 10a, si migliora poco ma è sempre un'ottima scelta Recensione Google Pixel 10a, si migliora poco ma...
Le analisi di ALMA sulla cometa interste...
La missione cinese Tianwen-3 per portare...
Un satellite di HEO Space ha catturato u...
Mini LED 144Hz a prezzo folle: questo Hi...
Novità per Fortinet: arrivano For...
Volkswagen e Xpeng, il SUV è real...
Volkswagen ribattezza ID.3 e le dà un mo...
Aruba rende disponibile VMware Hosted Pr...
Questa Olympus da 20 MP con stabilizzazi...
Il nuovo dispositivo di Rabbit si chiama...
'Se avete RAM, siamo pronti ad acquistar...
Veeam corregge diverse vulnerabilit&agra...
MacBook Neo segna una svolta per Apple: ...
Polestar pubblica il report LCA di Poles...
Il rame non basta più: NVIDIA, AM...
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: 03:22.


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