Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Gigabyte MO32U24 OLED: il 4K a 240Hz su un pannello OLED ideale per il gaming
Gigabyte MO32U24 OLED: il 4K a 240Hz su un pannello OLED ideale per il gaming
Pannello QD-OLED da 32 pollici con risoluzione 4K, frequenza di aggiornamento a 240Hz e tempi di risposta rapidissimi: il Gigabyte MO32U24 evolve il progetto del suo predecessore MO32U e alza ulteriormente l'asticella delle prestazioni. È ancora una volta un monitor indirizzato ai giocatori più esigenti
Recensione realme 16 5G: lo smartphone con Selfie Mirror ha una batteria da 6550mAh
Recensione realme 16 5G: lo smartphone con Selfie Mirror ha una batteria da 6550mAh
realme 16 5G è un nuovo smartphone con sensore Sony IMX 852 da 50MP sul retro e uno specchio selfie fisico integrato nella camera bar, una prima nel segmento di mercato. Batteria da 6550mAh in un corpo da 8,1mm e 183g, certificazione IP69K e ricarica da 45W completano un pacchetto aggressivo per la fascia media, per uno dei prodotti più interessanti del produttore sul piano commerciale
Come rispettare tutte le nuove regole per i monopattini elettrici? La guida per non rischiare sanzioni
Come rispettare tutte le nuove regole per i monopattini elettrici? La guida per non rischiare sanzioni
Sono ormai definitive le nuove norme del Codice della Strada per i monopattini elettrici. Non solo targa e assicurazione, le regole sono tante e riguardano diversi aspetti, vi spieghiamo come evitare sanzioni che possono essere salate
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 01-11-2011, 13:12   #1
ZanTeo
Member
 
Iscritto dal: Oct 2011
Messaggi: 45
[Java][db access]problema con INSERT INTO

Salve ragazzi, ho un problema con l'insert into, ho creato un main dove prima inserisco dei valori nel db e poi stamparli. La classe non mi segnala nessun errore ma quando la eseguo la parte di codice relativa all'insert into genera un errore.
Il codice è:
Codice:
import java.util.Vector;
public class TestInserimentoDB {
	/**
	 * @param args
	 */
	public static void main(String[] args) {
		String [][] parametri = {{"DRIVER", "Microsoft Access Driver (*.mdb)"},
				{"DBQ", "EstrattorePDF.mdb"}};
		DatabaseBridge db=new DatabaseBridge("",parametri);
		if ( !db.connetti() ) {
			System.out.println("Errore durante la connessione!");
			System.out.println( db.getErrore() );
			System.exit(0);
		}
		else 
			System.out.println("Connessione ok");
		db.eseguiQuery("INSERT INTO files (ID,NomeFile,protetto,processato,DataUltimoProcesso) " +
				"VALUES (#"
                            + "'1'"
                            + "'prima prova'"
                            + "'0'"
                            + "'1'"
                            + "'31/10/2011'"
                           );
		@SuppressWarnings("rawtypes")
		Vector v = db.eseguiQuery("SELECT * FROM files;");
		int i=0;
		while ( i<v.size() ) {
			System.out.println("Record numero " + (i+1));
			String [] record = (String[]) v.elementAt(i);
			for (int j=0; j<record.length; j++)
				System.out.println( record[j] );
		}
		if ( !db.eseguiAggiornamento("UPDATE files SET campo=valore WHERE campo>1;") ) {
			System.out.println("Errore nell'aggiornamento!");
			System.out.println( db.getErrore() );
		}
		db.disconnetti();
		System.out.println("Disconnessione ok");
	}
}
L'errore stampato è:
Codice:
Connessione ok
java.sql.SQLException: [Microsoft][Driver ODBC Microsoft Access] Errore di sintassi nella data nell'espressione della query '#'1''prima prova''0''1''31/10/2011''.
	at sun.jdbc.odbc.JdbcOdbc.createSQLException(Unknown Source)
	at sun.jdbc.odbc.JdbcOdbc.standardError(Unknown Source)
	at sun.jdbc.odbc.JdbcOdbc.SQLExecDirect(Unknown Source)
	at sun.jdbc.odbc.JdbcOdbcStatement.execute(Unknown Source)
	at sun.jdbc.odbc.JdbcOdbcStatement.executeQuery(Unknown Source)
	at test.DatabaseBridge.eseguiQuery(DatabaseBridge.java:70)
	at test.TestInserimentoDB.main(TestInserimentoDB.java:21)
Disconnessione ok
l'errore è segnalato nel campo data, ma è scritto conforme al db, ho provato anche ad usare solo mese anno ma l'errore è sempre quello, forse devo usare dei tipi diversi di apicetti
__________________
Teo
ZanTeo è offline   Rispondi citando il messaggio o parte di esso
Old 01-11-2011, 17:45   #2
wingman87
Senior Member
 
Iscritto dal: Nov 2005
Messaggi: 2790
I valori devono essere separati da virgola. E il cancelletto a cosa serve?
wingman87 è offline   Rispondi citando il messaggio o parte di esso
Old 01-11-2011, 19:14   #3
ZanTeo
Member
 
Iscritto dal: Oct 2011
Messaggi: 45
Quote:
Originariamente inviato da wingman87 Guarda i messaggi
I valori devono essere separati da virgola. E il cancelletto a cosa serve?
Intendi in questo modo:
Codice:
db.eseguiQuery("INSERT INTO files (ID,NomeFile,protetto,processato,DataUltimoProcesso) VALUES ("'1'","'prima prova'","'0'","'1'","'10/2011'");
così mi da che tutta la linea di codice è un errore.
Per aiutarti a capire meglio la struttura ti dico cosa è ogni singolo componente:
  • ID (chiave della tabella) intero - long
  • NomeFile VarChar - testo
  • protetto bit (booleano)
  • processato bit (booleano)
  • DataUltimoUtilizzo DateTime [data/ora]
__________________
Teo
ZanTeo è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Gigabyte MO32U24 OLED: il 4K a 240Hz su un pannello OLED ideale per il gaming Gigabyte MO32U24 OLED: il 4K a 240Hz su un panne...
Recensione realme 16 5G: lo smartphone con Selfie Mirror ha una batteria da 6550mAh Recensione realme 16 5G: lo smartphone con Selfi...
Come rispettare tutte le nuove regole per i monopattini elettrici? La guida per non rischiare sanzioni Come rispettare tutte le nuove regole per i mono...
DLSS 4.5: con Dynamic Frame Generation e MFG 6X NVIDIA alza la posta DLSS 4.5: con Dynamic Frame Generation e MFG 6X ...
Plaud NotePin S, il registratore IA si fa indossabile (ma è facile da perdere) Plaud NotePin S, il registratore IA si fa indoss...
Infineon apre il 2 luglio lo Smart Power...
Crimson Desert non si ferma: il gioco di...
Con iOS 27 l'iPhone si ripristina da sol...
Visa porta i pagamenti in ChatGPT: gli a...
OpenAI valuta un 'drastico' taglio dei p...
Il MacBook con display touch si far&agra...
Google promette di restituire più...
Quattro monitor 4K, doppia LAN 2.5G e Wi...
ROG Equalizer, il cavo 'salva-GPU': prim...
Falla critica CVSS 9.8 in Oracle PeopleS...
Microsoft accelera su Edge: aggiornament...
AMD ha corretto un bug da 10.000 dollari...
Vertiv: data center, la corsa dell’IA sp...
Siri non diventerà la tua fidanzata virt...
Prezzi in crescita del 200% e forniture ...
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: 20:18.


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