Torna indietro   Hardware Upgrade Forum > Software > Programmazione

NL-LC1 è il primo dissipatore a liquido AIO di Noctua: silenzio è la parola d'ordine
NL-LC1 è il primo dissipatore a liquido AIO di Noctua: silenzio è la parola d'ordine
Dopo anni di attesa e una lunga fase di sviluppo, Noctua entra nel mercato dei dissipatori a liquido AIO con la nuova serie NL-LC1. Forte dell'esperienza maturata nel raffreddamento ad aria, l'azienda austriaca promette di portare la propria filosofia fatta di qualità costruttiva, attenzione ai dettagli e silenziosità anche in questo segmento. Abbiamo provato il nuovo sistema per scoprire se riesce a distinguersi in un mercato ormai molto competitivo.
Boox Go 10.3 (Gen II) Lumi: il tablet e-ink con Android 15 e penna, dal prezzo super
Boox Go 10.3 (Gen II) Lumi: il tablet e-ink con Android 15 e penna, dal prezzo super
Arrivato sul mercato italiano a fine marzo, la serie Boox Go 10.3 (Gen II) offre Android 15, penna da 4096 livelli e retroilluminazione opzionale (nel modello da noi provato, Lumi, presente). La serie si compone di due tablet ePaper che fanno da e-reader, blocco note digitale e persino browser, tutto a un prezzo che fa dimenticare i prodotti di brand più blasonati
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
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 01-05-2013, 09:26   #1
mcgeek
Junior Member
 
Iscritto dal: Oct 2012
Messaggi: 4
[Java] Primo mini-programma

Salve a tutti dopo tanta teoria sono alle prese con la creazione del mio primo programmino e purtroppo il passaggio dalla teoria alla pratica non è proprio semplice.
In pratica vorrei costruire un piccolo programmino che permetta di creare un rubrica.
Ho già creato un semplicissimo database Persona con i campi nome, cognome, indirizzo, eta. Ora dovrei creare le classi java per inserire, modificare e visualizzare i dati di questo database, ma mi sto già perdendo
Qualcuno mi può dare qualche spunto su quali classi costruire e magari quali metodi e variabili dovrebbe avere ciascuna classe?
Grazie in anticipo
mcgeek è offline   Rispondi citando il messaggio o parte di esso
Old 01-05-2013, 11:04   #2
pabloski
Senior Member
 
Iscritto dal: Jan 2008
Messaggi: 8406
Beh, la cosa migliore è replicare la struttura del DB, cioè una classe Persona che ha come attributi gli stessi attributi dell'entità Persona del DB.
pabloski è offline   Rispondi citando il messaggio o parte di esso
Old 02-05-2013, 07:18   #3
mcgeek
Junior Member
 
Iscritto dal: Oct 2012
Messaggi: 4
Si creo la classe Persona però il mio dubbio è la connessione al database, mi conviene creare una nuova classe con i metodi per la connessione, modifica e visualizzazione dei dati o forse è meglio creare tre classi differenti una che gestisce l'inserimento dato, l'altra che gestisce la modifica e l'altra che ne gestisce la stampa a video?
mcgeek è offline   Rispondi citando il messaggio o parte di esso
Old 02-05-2013, 10:36   #4
pabloski
Senior Member
 
Iscritto dal: Jan 2008
Messaggi: 8406
Conviene una classe sola, perchè dovresti crearne tre?
pabloski è offline   Rispondi citando il messaggio o parte di esso
Old 03-05-2013, 18:59   #5
mt94
Member
 
Iscritto dal: Mar 2013
Città: Frascati
Messaggi: 31
Essendo il tuo primo programma in java, ti sconsiglio vivamente di cimentarti nella connessione al database (se intendevi connetterti ad un dbms tipo access o mysql), ti consiglio di capire bene il funzionamento delle classi e programmazione OOP.

Comunque se vuoi imparare l'interfaccia con il database, ti posto il codice di una classe per la connessione.

Codice:
/**
  * DBMS Class 1.0
  * @author Matteo Badoni
  *
  */
import java.sql.*;

import javax.swing.JOptionPane;
public class Dbms 
{
    // Attributi della classe, per la connessione al database  
    Connection db;
    String dbhost = "";   // Indirizzo del database, di solito è localhost
    String dbuser = "";   // Username dell'utente del database
    String dbpassword = "";  // Password 
    String dbname = "";   // Nome del database a cui connettersi

	// Costruttore
        public Dbms(String host, String user, String password, String name) 
	{
	      this.dbhost = host;
	      this.dbuser = user;
	      this.dbpassword = password;
	      this.dbname = name;
	}
	
	protected boolean connect()   // Metodo che permette di connettersi al database 
	{
		try
		{
		    Class.forName("com.mysql.jdbc.Driver").newInstance();  // Carica il driver per la connessione
		    this.db = DriverManager.getConnection("jdbc:mysql://" + this.dbhost + "/" + this.dbname, this.dbuser, this.dbpassword); // Si connette al DB
		    return true;

		}catch(Exception ex)
		{
			JOptionPane.showMessageDialog(null, "Errore: "+ex);
			return false;
		}
	}
	
        // Questo Metodo serve in caso si debba solo Proiettare o Selezionare dati, cioè una query SELECT

	public ResultSet execQuery(String sql)   
	{
		try
		{
			if(this.connect())
			{
				Statement st = (Statement) this.db.createStatement();
				 st.executeQuery(sql);
				 ResultSet rs = st.getResultSet ();
				 return rs;
			}
			else return null;
		}
		catch(Exception ex)
		{
			JOptionPane.showMessageDialog(null, "Errore: "+ex);
			return null;
		}
	}
	// Questo metodo, serve per eseguire tutte le query di manipolazione dati, INSERT DELETE ecc...
	public ResultSet execUpdate(String sql)
	{
		try
		{
			if(this.connect())
			{
				Statement st = (Statement) this.db.createStatement();
				 st.executeUpdate(sql);
				 ResultSet rs = st.getResultSet ();
				 return rs;
			}
			else return null;
		}
		catch(Exception ex)
		{
			JOptionPane.showMessageDialog(null, "Errore: "+ex);
			return null;
		}
	}
}

// Classe di Test

import java.sql.*;

public class test {

	/**
	 * @param args
	 * @throws SQLException 
	 */
	public static void main(String[] args) throws SQLException
	{
		
		Dbms db = new Dbms("localhost", "root", "", "test");  // Creo un oggetto di classe Dbms
	    
	    ResultSet rt = db.execQuery("SELECT * FROM nome_tabella");
	    
	    while(rt.next())
	    {
	    	System.out.println(rt.getString("campo1"));
                System.out.println(rt.getString("campo2"));
                // ecc...
	    }
	}

}
La prima parte la salvi come Dbms.java e la seconda come test.java

Questa classe funziona per mysql, modificando il driver di connessione e la stringa di connessione, può funzionare per qualsiasi DBMS.

Comunque nel caso non ti serva il database, una sola classe basta e avanza
__________________
Cpu: Amd FX 8350 - MOBO: Asrock 970 extreme3 (1.70) - Ram: Corsair DDR3 1600 4gb - Vga: Amd HD4890 1gb Ultima Versione - HDD: Western Digital Caviar Blue 1TB Sata3 + Seagate 360GB Sata2 - S.O: Windows 8 PRO 64bit
mt94 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


NL-LC1 è il primo dissipatore a liquido AIO di Noctua: silenzio è la parola d'ordine NL-LC1 è il primo dissipatore a liquido A...
Boox Go 10.3 (Gen II) Lumi: il tablet e-ink con Android 15 e penna, dal prezzo super Boox Go 10.3 (Gen II) Lumi: il tablet e-ink con ...
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...
Logitech G305 Lightspeed e G316 X 98: 8....
Qualcomm Snapdragon Reality Elite uffici...
Snapdragon START: arriva la piattaforma ...
Kioxia Exceria G3: il modella da 4 TB &e...
Gemini 3.5 Flash delude nei test Android...
DREAME X50 Ultra Complete a 749€ per il ...
Prezzi console handheld alle stelle: la ...
Toyota presenta il primo pickup elettric...
Prime Day anticipato, tutti gli smartpho...
Dyson V10 Konical: il primo aspirapolver...
FSR 4.1 su Radeon 6000, AMD spiega perch...
Hisense svela la gamma TV 2026: RGB Mini...
Narwal lancia gli sconti Prime Day 2026:...
SpaceX ha comprato Cursor: accordo da 60...
Commodore Callback 8020 è il tele...
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:54.


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