Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Display, mini PC, periferiche e networking: le novità ASUS al CES 2026
Display, mini PC, periferiche e networking: le novità ASUS al CES 2026
Sono molte le novità che ASUS ha scelto di presentare al CES 2026 di Las Vegas, partendo da una gamma di soluzioni NUC con varie opzioni di processore passando sino agli schermi gaming con tecnologia OLED. Il tutto senza dimenticare le periferiche di input della gamma ROG e le soluzioni legate alla connettività domestica
Le novità ASUS per il 2026 nel settore dei PC desktop
Le novità ASUS per il 2026 nel settore dei PC desktop
Molte le novità anticipate da ASUS per il 2026 al CES di Las Vegas: da schede madri per processori AMD Ryzen top di gamma a chassis e ventole, passando per i kit di raffreddamento all in one integrati sino a una nuova scheda video GeForce RTX 5090. In sottofondo il tema dell'intelligenza artificiale con una workstation molto potente per installazioni non in datacenter
Le novità MSI del 2026 per i videogiocatori
Le novità MSI del 2026 per i videogiocatori
Con le nuove soluzioni della serie MEG, acronimo di MSI Enthusiast Gaming, l'azienda taiwanese vuole proporre per il 2026 una gamma di proposte desktop che si rivolgono direttamente all'utente più appassionato con schede madri, chassis e sistemi di raffreddamento. Non da ultimi troviamo anche gli alimentatori, che abbinano potenza a ricerca della massima sicurezza di funzionamento.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 01-05-2013, 10: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, 12: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, 08: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, 11: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, 19: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


Display, mini PC, periferiche e networking: le novità ASUS al CES 2026 Display, mini PC, periferiche e networking: le n...
Le novità ASUS per il 2026 nel settore dei PC desktop Le novità ASUS per il 2026 nel settore de...
Le novità MSI del 2026 per i videogiocatori Le novità MSI del 2026 per i videogiocato...
I nuovi schermi QD-OLED di quinta generazione di MSI, per i gamers I nuovi schermi QD-OLED di quinta generazione di...
Recensione vivo X300 Pro: è ancora lui il re della fotografia mobile, peccato per la batteria Recensione vivo X300 Pro: è ancora lui il...
Fibra di carbonio, lega di magnesio e 8....
Inaugurato il Padiglione Italia al CES 2...
AGON PRO AG276QSG2: NVIDIA G-Sync Pulsar...
MSI mostra la scheda madre consumer con ...
MSI rinnova l'intera offerta notebook al...
Laifen Wave Pro: debutta al CES lo spazz...
XGIMI Titan Noir Max: al CES il videopro...
Atlas di Boston Dynamics: il robot umano...
TV da 130 pollici ed elettrodomestici, p...
I giochi classici cambiano volto con RTX...
OpenAI testa la pubblicità in Cha...
Plaud riscrive il modo di prendere appun...
Narwal presenta a Las Vegas la nuova gam...
1000W solo per la scheda video: la GeFor...
NVIDIA espande GeForce NOW: nuove app Li...
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: 01:51.


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