Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Recensione Nothing Phone (4a) Pro: finalmente in alluminio, ma dal design sempre unico
Recensione Nothing Phone (4a) Pro: finalmente in alluminio, ma dal design sempre unico
Nothing Phone (4a) Pro cambia pelle: l'alluminio unibody sostituisce la trasparenza integrale, portando una solidità inedita. Sotto il cofano troviamo uno Snapdragon 7 Gen 4 che spinge forte, mentre il display è quasi da top dig amma. Con un teleobiettivo 3.5x e la Glyph Matrix evoluta, è la prova di maturità di Carl Pei. C'è qualche compromesso, ma a 499EUR la sostanza hardware e la sua unicità lo rendono un buon "flagship killer" in salsa 2026
WoW: Midnight, Blizzard mette il primo, storico mattone per l'housing e molto altro
WoW: Midnight, Blizzard mette il primo, storico mattone per l'housing e molto altro
Con Midnight, Blizzard tenta il colpaccio: il player housing sbarca finalmente su Azeroth insieme a una Quel'Thalas ricostruita da zero. Tra il dramma della famiglia Ventolesto e il nuovo Prey System, ecco com'è la nuova espansione di World of Warcraft
Ecovacs Goat O1200 LiDAR Pro: la prova del robot tagliaerba con tagliabordi integrato
Ecovacs Goat O1200 LiDAR Pro: la prova del robot tagliaerba con tagliabordi integrato
Nuova frontiera per i robot tagliaerba, con Ecovacs GOAT O1200 LiDAR Pro che riconosce l'ambiente in maniera perfetta, grazie a due sensori LiDAR, e dopo la falciatura può anche rifinire il bordo con il tagliabordi a filo integrato
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 14-07-2008, 10:55   #1
Alhazred
Senior Member
 
L'Avatar di Alhazred
 
Iscritto dal: Dec 2003
Messaggi: 1768
[JDBC] problemi con createStatement

Ho dei problemi con l'istruzione "Statement stmt = conn.createStatement();" presente nel seguente codice, mi ritorna sempre una nullpointerexception e non capisco il perché, ho già usato lo stesso codice in passato su un altro progetto ed ha sempre funzionato, ho anche provato a tirarlo fuori di nuovo per vedere se magari non fosse un problema di mysql o tomacat sul pc visto che li ho reinstallati e potevo aver sbagliato qualcosa, invece il vecchio progetto funziona correttamente.
Sapreste darmi una mano?
Codice:
public class AccountDAO {
  public static boolean login(String username, String password)
  {
    try
    {
      ConnectionManager connection = ConnectionManager.getInstance();
      Connection conn = connection.getConnection();
      Statement stmt = conn.createStatement();
      ResultSet rs = null;
      rs = stmt.executeQuery("SELECT username, password FROM account WHERE username='"+username+"' AND password='"+password+"';");
      if(rs.next() == false)
        return false;
      return true;				
    }
    catch (SQLException ex)
    {
      System.out.println("SQLException: " + ex.getMessage()); 
      System.out.println("SQLState: " + ex.getSQLState()); 
      System.out.println("VendorError: " + ex.getErrorCode()); 
    }
    return false;
  }
}
Alhazred è offline   Rispondi citando il messaggio o parte di esso
Old 14-07-2008, 11:23   #2
Ed_Bunker
Senior Member
 
L'Avatar di Ed_Bunker
 
Iscritto dal: Jan 2004
Città: Montignoso(MS)
Messaggi: 9498
Premesso che ti consiglio di usare PreparedStatement anziche' Statement... che cos'e' ConnectionManager ?!?

Il problema credo sia dovuto al fatto che fai una getConnection (Dovrebbe essere fatta dalla classe DriverManager) o senza avere le "credenziali" per accedere al db oppure perche' non hai caricato correttamente il driver.
__________________
"Il Meglio che si possa ottenere è evitare il peggio." I.C.
Ed_Bunker è offline   Rispondi citando il messaggio o parte di esso
Old 14-07-2008, 11:26   #3
banryu79
Senior Member
 
L'Avatar di banryu79
 
Iscritto dal: Oct 2007
Città: Padova
Messaggi: 4131
La chiamata createStatement tramite l'oggetto Connection sembra regolare, hai già provato a verificare se la connessione al db va a buon fine? (immagino di sì, ma chiedo lo stesso)
__________________

As long as you are basically literate in programming, you should be able to express any logical relationship you understand.
If you don’t understand a logical relationship, you can use the attempt to program it as a means to learn about it.
(Chris Crawford)
banryu79 è offline   Rispondi citando il messaggio o parte di esso
Old 14-07-2008, 16:03   #4
Alhazred
Senior Member
 
L'Avatar di Alhazred
 
Iscritto dal: Dec 2003
Messaggi: 1768
Questo è il ConnectionManager, lo uso su un altro progetto e funziona a dovere.
Codice:
import java.sql.*;

public class ConnectionManager 
{
	/**
	 * La singola istanza del ConnectionManager.
	 */
	private static ConnectionManager instance = null;
	
	/**
	 * La connessione al database.
	 */
	private static Connection conn = null;
	
	/**
	 * Consente di ottenere l'unica istanza della classe.
	 *  
	 * Il metodo è sincronizzato per gestire chiamate concorrenti da più thread.
	 *  
	 * @return l'unica istanza del ConnectionManager 
	 */
	public static synchronized ConnectionManager getInstance()
	{
		if (instance == null)
			instance = new ConnectionManager();
		
		return instance;
	}
	
	/**
	 * Invocato al momento della distruzione dell'oggetto.
	 *  
	 * Rilascia la connessione creata nel momento di creazione dell'istanza dell'oggetto.
	 */
	protected void finalize()
	{
		try
		{
			if (conn != null)
				conn.close();
		}
		catch (SQLException ex)
               {
                  System.out.println("SQLException: " + ex.getMessage()); 
                  System.out.println("SQLState: " + ex.getSQLState()); 
                  System.out.println("VendorError: " + ex.getErrorCode()); 
               } 		
	}
	
	/**
	 * Restituisce la connessione al database.
	 *  
	 * @return la connessione al database 
	 */
	public Connection getConnection() 
	{
		return conn;
	}
		
	/**
	 * Costruttore della classe.
	 *  
	 * Il costruttore è reso privato in accordo al pattern Singleton
	 */
	private ConnectionManager() 
	{
		try
		{
			Class.forName("com.mysql.jdbc.Driver").newInstance();
			conn = DriverManager.getConnection("jdbc:mysql://localhost/ricettelastminute?user=root&password=root");
		}
        catch (SQLException ex) 
        {
            System.out.println("SQLException: " + ex.getMessage()); 
            System.out.println("SQLState: " + ex.getSQLState()); 
            System.out.println("VendorError: " + ex.getErrorCode()); 
        } 
        catch (Exception ex)
        {
        	System.out.println("Exception: " + ex.getMessage());
        }
	}
}
Alhazred è offline   Rispondi citando il messaggio o parte di esso
Old 14-07-2008, 16:27   #5
Ed_Bunker
Senior Member
 
L'Avatar di Ed_Bunker
 
Iscritto dal: Jan 2004
Città: Montignoso(MS)
Messaggi: 9498
Controlla i parametri di connessione al db (Quelli che effettui nella classe che "implementa" il connection pool).
Sicuro che siano corretti e che ti permettano effettivamente di connetterti al db ?
__________________
"Il Meglio che si possa ottenere è evitare il peggio." I.C.
Ed_Bunker è offline   Rispondi citando il messaggio o parte di esso
Old 14-07-2008, 16:52   #6
Alhazred
Senior Member
 
L'Avatar di Alhazred
 
Iscritto dal: Dec 2003
Messaggi: 1768
Uso la stessa classe ConnectionManager per un altro progetto e in quest'altro cambia solo il nome del database nell'istruzione
conn = DriverManager.getConnection("jdbc:mysql://localhost/ricettelastminute?user=root&password=root");
bookshop al posto di ricettelastminute.

bookshop funziona senza problemi.
Alhazred è offline   Rispondi citando il messaggio o parte di esso
Old 15-07-2008, 09:00   #7
Alhazred
Senior Member
 
L'Avatar di Alhazred
 
Iscritto dal: Dec 2003
Messaggi: 1768
Risolto, non avevo importato mysql-connector.. in web-inf\lib, quindi non avveniva la connessione al db. Ora funziona.
Alhazred è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Recensione Nothing Phone (4a) Pro: finalmente in alluminio, ma dal design sempre unico Recensione Nothing Phone (4a) Pro: finalmente in...
WoW: Midnight, Blizzard mette il primo, storico mattone per l'housing e molto altro WoW: Midnight, Blizzard mette il primo, storico ...
Ecovacs Goat O1200 LiDAR Pro: la prova del robot tagliaerba con tagliabordi integrato Ecovacs Goat O1200 LiDAR Pro: la prova del robot...
Recensione Samsung Galaxy S26+: sfida l'Ultra, ma ha senso di esistere? Recensione Samsung Galaxy S26+: sfida l'Ultra, m...
Zeekr X e 7X provate: prezzi, autonomia fino a 615 km e ricarica in 13 minuti Zeekr X e 7X provate: prezzi, autonomia fino a 6...
Rimborso Netflix fino a 500 euro, come p...
DENZA debutta in Europa: Z9GT e D9 porta...
Steam potrebbe presto integrare un siste...
Claude Managed Agents in public beta: ad...
Ring Videocitofono Cablato + Telecamera ...
Windows 10, il supporto ESU viene esteso...
Motorola edge 60 neo a soli 251€: tripla...
Bollette più leggere? Octopus Ene...
Muse Spark è qui: Meta abbandona ...
Microsoft testa su Xbox Insiders la poss...
Climatizzatore 12000 BTU A++ con Wi-Fi a...
La crisi delle memorie farà ricca Samsun...
Il ventilatore Dyson che puoi indossare:...
Insta360 presenta Snap, lo schermo selfi...
Razer Kishi V2 a soli 59,99€ su Amazon: ...
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: 10:59.


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