Torna indietro   Hardware Upgrade Forum > Software > Programmazione

KTC H27E6 a 300Hz e 1ms: come i rivali ma a metà prezzo
KTC H27E6 a 300Hz e 1ms: come i rivali ma a metà prezzo
KTC lancia il nuovo monitor gaming H27E6, un modello da 27 pollici che promette prestazioni estreme grazie al pannello Fast IPS con risoluzione 2K QHD (2560x1440). Il monitor si posiziona come una scelta cruciale per gli appassionati di eSport e i professionisti creativi, combinando una frequenza di aggiornamento di 300Hz e un tempo di risposta di 1ms con un'eccezionale fedeltà cromatica
Cineca inaugura Pitagora, il supercomputer Lenovo per la ricerca sulla fusione nucleare
Cineca inaugura Pitagora, il supercomputer Lenovo per la ricerca sulla fusione nucleare
Realizzato da Lenovo e installato presso il Cineca di Casalecchio di Reno, Pitagora offre circa 44 PFlop/s di potenza di calcolo ed è dedicato alla simulazione della fisica del plasma e allo studio dei materiali avanzati per la fusione, integrandosi nell’ecosistema del Tecnopolo di Bologna come infrastruttura strategica finanziata da EUROfusion e gestita in collaborazione con ENEA
Mova Z60 Ultra Roller Complete: pulisce bene grazie anche all'IA
Mova Z60 Ultra Roller Complete: pulisce bene grazie anche all'IA
Rullo di lavaggio dei pavimenti abbinato a un potente motore da 28.000 Pa e a bracci esterni che si estendono: queste, e molte altre, le caratteristiche tecniche di Z60 Ultra Roller Complete, l'ultimo robot di Mova che pulisce secondo le nostre preferenze oppure lasciando far tutto alla ricca logica di intelligenza artificiale integrata
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 14-06-2010, 18:28   #1
peppepayens
Member
 
Iscritto dal: Mar 2009
Città: milano
Messaggi: 46
aiuto problema in java

Prima di tutto buona sera a tutti
allora io devo fare un progetto che può inserire ricercare e cancellare oggetti in un database...
nello specifico il mio database deve essere formato di oggetti di una classe creata da me di nome CD un'altra DVD e poi un altra Libro...
è un progetto client server multithread con interfaccia grafica e database mysql...
allora mi sono bloccato in un punto, praticamente ho creato manualmente il database in mysql ed ho aggiunto la tabella inserisciCD dove poi posso inserire oggetti di tipo CD stessa cosa per DVD e per Libro(mi manca ora solo la parte di ricerca nel database e di cancellazioni di oggeti nel database).
ho collegato il mio bottone salva ad un action listener che manda attraverso il metodo Client.inserisciCD(parametri da inserire) l'oggetto che il client vuole caricare nel database.
questo è il server ora metto il client e poi il pannello che gestisce l'aciotn listener
Codice:
package Progetto;
import java.io.*;
import java.net.*;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
import java.sql.Statement;
import java.util.*;
import java.sql.*;
public class MultiThreadServer {
	
	private static ServerSocket serverSocket;
    private static final int PORT = 9878;
    private static Connection con;
    public static void main(String[] args) {
    	
     try{ 
    	 Class.forName("com.mysql.jdbc.Driver");
    	 String nomeDB = "ArchivioDB";
    	 String nomeUtente = "root";
    	 String pwdUtente = "root";
    	 con = DriverManager.getConnection("jdbc:mysql://localhost/" + nomeDB + "?user=" + nomeUtente + "&password=" + pwdUtente); 
//         boolean ris = con.createStatement().execute(Query.CreaArchivioCD);
//         if (ris){
//        	 System.out.println("Archivio CD");
//         }
     
     
     }catch(SQLException e) { 
    	 System.out.println("errore ");
    	 e.printStackTrace();
     }
     catch (ClassNotFoundException e) {
		e.printStackTrace();
     }
         
    	try {
            serverSocket = new ServerSocket(PORT);
            System.out.println("Server in attesa...");
            while(true) {
         	  //Wait for client...
            	Socket client = serverSocket.accept();
            	System.out.println("\nNuovo client accettato.\n");
            	ServerThread thread = new ServerThread(client,con);
                thread.start();
              // Esecuzione dei thread in base alla richiesta dei client
     
            }
    	}catch (IOException ioEx) {
            System.out.println("\nUnable to set up port!");
            ioEx.printStackTrace();
            System.exit(1);
        }
}
    
}

class ServerThread extends Thread {
	    Socket client;
	    ObjectInputStream input;
	    ObjectOutputStream output;
	    Connection con;

	    public ServerThread(Socket socket,Connection con ) {
	        //Set up reference to associated socket...
	        client = socket;
	        this.con=con;

	        try {
//	            input = new  ObjectInputStream(client.getInputStream());
//	            output = new PrintWriter(client.getOutputStream(),true);
	         	output = new ObjectOutputStream( socket.getOutputStream() );
	        	input = new ObjectInputStream( socket.getInputStream() );
	       

	        }
	        catch(IOException ioEx) {
	            ioEx.printStackTrace();
	        }
	    }
	    
	    public void run() {
	    	try {
				Object obj=input.readObject();
//				if(obj instanceof CD)
				if(obj.getClass().getName().equals("CD")){
					CD cd = (CD)obj;
					PreparedStatement ps = con.prepareStatement(Query.InsertCD);
					ps.setString(1,cd.getTitolo());
					ps.setString(2,cd.getAutore());
					ps.setInt(3,cd.getNumeroTracce());
					ps.setDouble(4,cd.getTempoEsecuzione());
					ps.setBoolean(5,cd.getPrestito());
					ps.setString(6,cd.getCommento());
					int res = ps.executeUpdate();
					if(res>0){
						output.writeObject( true );
						output.flush();
;
					} else 
						output.writeObject( true );
						output.flush();
					ps.close();
				}
} catch (IOException e) {
				e.printStackTrace();
			} catch (ClassNotFoundException e) {
				e.printStackTrace();
			} catch (SQLException e) {
				e.printStackTrace();
			}
	    }
}
peppepayens è offline   Rispondi citando il messaggio o parte di esso
Old 14-06-2010, 18:30   #2
peppepayens
Member
 
Iscritto dal: Mar 2009
Città: milano
Messaggi: 46
CLIENT:

Codice:
package Progetto;
import java.io.*;
import java.net.*;
import java.util.*;
public class Client {
	static ObjectInputStream ois;
	static ObjectOutputStream oos;
	private static InetAddress host;
	private static final int PORT = 9878;

	public static void main(String atgs[]) {
		try
		{
			host = InetAddress.getLocalHost();
		}
		catch(UnknownHostException uhEx)
		{
			System.out.println("\nHost ID not found!\n");
			System.exit(1);
		}
		GUIManager gui = new GUIManager();
	
	}
	
	public static boolean inserisciCD(CD inserireCD) {
		Socket socket = null;
		boolean res=false;
		try
		{
			socket = new Socket(host,PORT);
			ois = new ObjectInputStream(socket.getInputStream());
			oos = new ObjectOutputStream(socket.getOutputStream());
			oos.writeObject(inserireCD);
			oos.flush();
			
			Object dati = (CD)ois.readObject();

//			Scanner in =new Scanner(socket.getInputStream());
//			ObjectOutputStream ps = new ObjectOutputStream (socket.getOutputStream());
//			ps.writeObject(inserireCD);
//			if(in.nextBoolean()) 
//				res= true;
//			ois.close();
//			oos.close();
			
		}catch(IOException ioEx)
		{
			ioEx.printStackTrace();
		} catch (ClassNotFoundException e) {
			
			e.printStackTrace();
		}
		
		return res;
	
	}
	public static boolean inserisciDVD(DVD inserireDVD) {
		Socket socket = null;
		boolean res=false;
		try
		{
			socket = new Socket(host,PORT);
			Scanner in =new Scanner(socket.getInputStream());
			PrintStream ps = new PrintStream (socket.getOutputStream());
			ps.print(inserireDVD);
			if(in.nextBoolean()) 
				res= true;
			
			
		}catch(IOException ioEx)
		{
			ioEx.printStackTrace();
		}
		return res;
	}
	public static boolean inserisciLibro(Libro inserireLibro) {
		Socket socket = null;
		boolean res=false;
		try
		{
			socket = new Socket(host,PORT);
			Scanner in =new Scanner(socket.getInputStream());
			PrintStream ps = new PrintStream (socket.getOutputStream());
			ps.print(inserireLibro);
			if(in.nextBoolean()) {
				res= true;
			}
			
		}catch(IOException ioEx){
			ioEx.printStackTrace();
		}
		return res;
	}
}
peppepayens è offline   Rispondi citando il messaggio o parte di esso
Old 14-06-2010, 18:31   #3
peppepayens
Member
 
Iscritto dal: Mar 2009
Città: milano
Messaggi: 46
vi scongiuro è tutto il giornao che cerco di risolvere il problema
c'è un errore che non riesco a risolvere diciamo pure più di uno
Codice:
java.io.WriteAbortedException: writing aborted; java.io.NotSerializableException: Progetto.CD
	at java.io.ObjectInputStream.readObject0(Unknown Source)
	at java.io.ObjectInputStream.readObject(Unknown Source)
	at Progetto.ServerThread.run(MultiThreadServer.java:84)
Caused by: java.io.NotSerializableException: Progetto.CD
	at java.io.ObjectOutputStream.writeObject0(Unknown Source)
	at java.io.ObjectOutputStream.writeObject(Unknown Source)
	at Progetto.Client.inserisciCD(Client.java:33)
	at Progetto.PannelloInserimentoCD.actionPerformed(PannelloInserimentoCD.java:203)
	at javax.swing.AbstractButton.fireActionPerformed(Unknown Source)
	at javax.swing.AbstractButton$Handler.actionPerformed(Unknown Source)
	at javax.swing.DefaultButtonModel.fireActionPerformed(Unknown Source)
	at javax.swing.DefaultButtonModel.setPressed(Unknown Source)
	at javax.swing.plaf.basic.BasicButtonListener.mouseReleased(Unknown Source)
	at java.awt.Component.processMouseEvent(Unknown Source)
	at javax.swing.JComponent.processMouseEvent(Unknown Source)
	at java.awt.Component.processEvent(Unknown Source)
	at java.awt.Container.processEvent(Unknown Source)
	at java.awt.Component.dispatchEventImpl(Unknown Source)
	at java.awt.Container.dispatchEventImpl(Unknown Source)
	at java.awt.Component.dispatchEvent(Unknown Source)
	at java.awt.LightweightDispatcher.retargetMouseEvent(Unknown Source)
	at java.awt.LightweightDispatcher.processMouseEvent(Unknown Source)
	at java.awt.LightweightDispatcher.dispatchEvent(Unknown Source)
	at java.awt.Container.dispatchEventImpl(Unknown Source)
	at java.awt.Window.dispatchEventImpl(Unknown Source)
	at java.awt.Component.dispatchEvent(Unknown Source)
	at java.awt.EventQueue.dispatchEvent(Unknown Source)
	at java.awt.EventDispatchThread.pumpOneEventForFilters(Unknown Source)
	at java.awt.EventDispatchThread.pumpEventsForFilter(Unknown Source)
	at java.awt.EventDispatchThread.pumpEventsForHierarchy(Unknown Source)
	at java.awt.EventDispatchThread.pumpEvents(Unknown Source)
	at java.awt.EventDispatchThread.pumpEvents(Unknown Source)
	at java.awt.EventDispatchThread.run(Unknown Source)
peppepayens è offline   Rispondi citando il messaggio o parte di esso
Old 14-06-2010, 18:41   #4
ndakota
Senior Member
 
L'Avatar di ndakota
 
Iscritto dal: Oct 2006
Città: milano
Messaggi: 1439
La butto lì: CD implementa l'interfaccia Serializable?
ndakota è offline   Rispondi citando il messaggio o parte di esso
Old 14-06-2010, 19:46   #5
peppepayens
Member
 
Iscritto dal: Mar 2009
Città: milano
Messaggi: 46
giusto aahah ho dimenticato quello
però ho un altro problema col database mysql


java.sql.SQLException: Parameter index out of range (1 > number of parameters, which is 0).
at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:910)
at com.mysql.jdbc.PreparedStatement.setInternal(PreparedStatement.java:2569)
at com.mysql.jdbc.PreparedStatement.setString(PreparedStatement.java:3397)
at Progetto.ServerThread.run(MultiThreadServer.java:97)

questa è la classe col codice mysql:
Codice:
package Progetto;

public class Query {
	static String CreaArchivioCD = "CREATE TABLE archivio_CD ("+
									"titolo varchar(50) PRIMARY KEY,"+
									"autore varchar(50) NOT NULL,"+
									"n_tracceCD int NOT NULL,"+
									"tempo_esec decimal(4,2) NOT NULL,"+
									"possesso boolean NOT NULL,"+
									"commento varchar(255) NOT NULL )";
	

	static String CreaArchivioDVD = "CREATE TABLE archvio_dvd("+
									"titolo varchar(50) PRIMARY KEY,"+
									"regista varchar(50) NOT NULL,"+
									"tempo_esec int NOT NULL,"+
									"possesso boolean NOT NULL,"+
									"commento varchar(255) NOT NULL,";

	static String CreaArchivioLibro = "CREATE TABLE archivio_libro("+
								  	"titolo varchar(50) PRIMARY KEY,"+
								  	"autore varchar(50) NOT NULL,"+
								  	"casa_editrice varchar(50) NOT NULL,"+
								  	"anno_pub int NOT NULL,"+
								  	"n_pagine int NOT NULL,"+
								  	"possesso boolean NOT NULL,"+
								  	"commento varchar(255) NOT NULL)";

	static String InsertCD = "INSERT INTO Archivio_Cd (titolo,autore,n_tracce,tempo_esec,possesso,commento)"+
									"VALUES('?','?','?','?','?','?')";
	
	static String InsertDVD = "INSERT INTO ArchivioDvd (titolo,regista,tempo_esec,possesso,commento)"+
									"VALUES('?','?','?','?','?')";
	
	static String InsertLibro = "INSERT INTO ArchivioDvd (titolo,autore,casa_editrice,anno_pub,n_pagine,possesso,commento)"+
									"VALUES('?','?','?','?','?','?','?')";								
}
peppepayens è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


KTC H27E6 a 300Hz e 1ms: come i rivali ma a metà prezzo KTC H27E6 a 300Hz e 1ms: come i rivali ma a met&...
Cineca inaugura Pitagora, il supercomputer Lenovo per la ricerca sulla fusione nucleare Cineca inaugura Pitagora, il supercomputer Lenov...
Mova Z60 Ultra Roller Complete: pulisce bene grazie anche all'IA Mova Z60 Ultra Roller Complete: pulisce bene gra...
Renault Twingo E-Tech Electric: che prezzo! Renault Twingo E-Tech Electric: che prezzo!
Il cuore digitale di F1 a Biggin Hill: l'infrastruttura Lenovo dietro la produzione media Il cuore digitale di F1 a Biggin Hill: l'infrast...
GeForce RTX 50 SUPER cancellate o rimand...
Windows 11 si prepara a vibrare: Microso...
La “Burnout Season” colpisce l’Italia: i...
QNAP annuncia il JBOD TL-R6020Sep-RP: ol...
Siemens e NVIDIA uniscono le forze: arri...
Ricarica veloce e durata batteria: miti ...
Le "navi volanti" di Candela a...
Bambini su misura? Il caso della startup...
Iliad porta le SIM Express in edicola: r...
Offerte Amazon sui TV Mini LED Hisense 2...
Il silenzio digitale che fa male: come i...
Il responsabile del programma Cybertruck...
Domanda alle stelle per SSD e RAM: in Gi...
Zuckerberg vuole eliminare tutte le mala...
Otto suicidi, un solo chatbot: si moltip...
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: 21:35.


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