Java - Guardar datos en una DB (myql) desde Netbean (java)

 
Vista:

Guardar datos en una DB (myql) desde Netbean (java)

Publicado por Juan (1 intervención) el 24/06/2018 08:43:22
Hola, no se si este tema ya existe o no, pero no tengo tiempo para buscar muy a fondo y tampoco encuentro mucho que ayude a este problema absurdo que olvide como solucionar (llevo tiempo lejos de msql y java)...

este es el asunto, tengo una agenda donde guardo nombre, numero, direccion y nota.


se debe guardar en una DB con id (autoincrementable) y toda la onda

pero al darle en guardar los datos me sale este error:
"Exception in thread "AWT-EventQueue-0" java.lang.UnsupportedOperationException: Not supported yet." y un bla bla bla gigante en rojo, no se guarda nningun dato ni se autoincrementa el ide de la DB

como lo soluciono?
tengo 2 ideas de por que pasa, pero no tengo solucion...
1. el id no lo detecta y me da el error por que el id debe ser not null, pero cocmo no le doy un numero en el programa no lo aumenta, y asi seria ridiculo incrementarlo desde el programa de manera automatica o manual ya que debe ser AU desde la base de datos
2. el archivo driver de conexion es viejo y necesito uno actual, pero no se de donde conseguir, solo encuentro el que ya tengo... ahi deberia buscar el codigo de java que no corre en el driver viejo pero no se cual es
esas 2 ideas me la dio un profesor hace un par de años atras y lo solucione, pero no recuerdo como.



este es el codigo del archivo de conexion
package conector:

[/code]

import abm_agenda.frm_agenda;
import java.sql.*;
import java.util.logging.Level;
import java.util.logging.Logger;
public class conexion {
public static String driver = "com.mysql.jdbc.Driver"; //"jdbc:mysql://localhost/"+bd o "com.mysql.jdbc.Driver"
public static String servidor = "localhost";
public static String puerto = "3306";
public static String baseDatos = "bd_agenda";
public static String usuario = "root";
public static String clave = "1234";
public static Connection conn;
public static Statement st;
public static boolean conexion() {
boolean valor = false;



try {
Class.forName(driver);
String url = "jdbc:mysql://" + servidor + ":" + puerto + "/" + baseDatos;
conn = DriverManager.getConnection(url, usuario, clave);
st = conn.createStatement();
valor = true;
DatabaseMetaData infoBD = conn.getMetaData();
System.out.println("estamos conectados a " + infoBD.getDatabaseProductName());
System.out.println("version " + infoBD.getDatabaseProductVersion());
} catch (ClassNotFoundException | SQLException ex) {
Logger.getLogger(conexion.class.getName()).log(Level.SEVERE, null, ex);
}
return valor;
}
public static boolean cerrar() {
boolean valor = false;
try {
st.close();
conn.close();
} catch (SQLException ex) {
Logger.getLogger(conexion.class.getName()).log(Level.SEVERE, null, ex);
}
return valor;
}
public static Connection getConn() {
return conn;
}
public static Statement getSt() {
return st;
}
public static void main(String[] args) {
conexion.conexion();
frm_agenda nuevo = new frm_agenda();
nuevo.setVisible(true);
//frm_agenda.setVisible(true);
}
public static Object getst() {
throw new UnsupportedOperationException("Not supported yet."); //To change body of generated methods, choose Tools | Templates.
}
}
[/code]



este es el codigo del frm, osea, donde estan los botones y los cuadros de texto

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
package abm_agenda;
 
import conector.conexion;
import java.sql.SQLException;
import java.util.logging.Level;
import java.util.logging.Logger;
import javax.swing.JOptionPane;
 
/**
 *
 * @author jose
 */
public class frm_agenda extends javax.swing.JFrame {
 
    private static boolean conexion() {
        throw new UnsupportedOperationException("Not supported yet."); //To change body of generated methods, choose Tools | Templates.
    }
 
    /**
     * Creates new form frm_agenda
     */
    public frm_agenda() {
        initComponents();
    }
 
    /**
     * This method is called from within the constructor to initialize the form.
     * WARNING: Do NOT modify this code. The content of this method is always
     * regenerated by the Form Editor.
     */
    @SuppressWarnings("unchecked")
    // <editor-fold defaultstate="collapsed" desc="Generated Code">                          
    private void initComponents() {
 
        numerotel_txt = new javax.swing.JTextField();
        nombre_txt = new javax.swing.JTextField();
        mail_txt = new javax.swing.JTextField();
        direccion_txt = new javax.swing.JTextField();
        nota_txt = new javax.swing.JTextField();
        cancelar_btn = new javax.swing.JToggleButton();
        salir_btn = new javax.swing.JToggleButton();
        modiicar_btn = new javax.swing.JToggleButton();
        aceptar_btn = new javax.swing.JToggleButton();
        jLabel1 = new javax.swing.JLabel();
        jLabel2 = new javax.swing.JLabel();
        jLabel3 = new javax.swing.JLabel();
        jLabel4 = new javax.swing.JLabel();
        jLabel5 = new javax.swing.JLabel();
        jLabel6 = new javax.swing.JLabel();
        id_contacto = new javax.swing.JTextField();
 
        setDefaultCloseOperation(javax.swing.WindowConstants.EXIT_ON_CLOSE);
        getContentPane().setLayout(new org.netbeans.lib.awtextra.AbsoluteLayout());
 
        numerotel_txt.addActionListener(new java.awt.event.ActionListener() {
            public void actionPerformed(java.awt.event.ActionEvent evt) {
                numerotel_txtActionPerformed(evt);
            }
        });
        getContentPane().add(numerotel_txt, new org.netbeans.lib.awtextra.AbsoluteConstraints(100, 120, 170, 30));
        getContentPane().add(nombre_txt, new org.netbeans.lib.awtextra.AbsoluteConstraints(100, 80, 170, 30));
        getContentPane().add(mail_txt, new org.netbeans.lib.awtextra.AbsoluteConstraints(100, 160, 170, 30));
        getContentPane().add(direccion_txt, new org.netbeans.lib.awtextra.AbsoluteConstraints(100, 200, 170, 30));
        getContentPane().add(nota_txt, new org.netbeans.lib.awtextra.AbsoluteConstraints(100, 240, 220, 80));
 
        cancelar_btn.setText("Cancelar");
        cancelar_btn.addActionListener(new java.awt.event.ActionListener() {
            public void actionPerformed(java.awt.event.ActionEvent evt) {
                cancelar_btnActionPerformed(evt);
            }
        });
        getContentPane().add(cancelar_btn, new org.netbeans.lib.awtextra.AbsoluteConstraints(280, 350, -1, -1));
 
        salir_btn.setText("Salir");
        salir_btn.addActionListener(new java.awt.event.ActionListener() {
            public void actionPerformed(java.awt.event.ActionEvent evt) {
                salir_btnActionPerformed(evt);
            }
        });
        getContentPane().add(salir_btn, new org.netbeans.lib.awtextra.AbsoluteConstraints(190, 350, 70, -1));
 
        modiicar_btn.setText("Modificar");
        getContentPane().add(modiicar_btn, new org.netbeans.lib.awtextra.AbsoluteConstraints(100, 350, -1, -1));
 
        aceptar_btn.setText("Aceptar");
        aceptar_btn.addActionListener(new java.awt.event.ActionListener() {
            public void actionPerformed(java.awt.event.ActionEvent evt) {
                aceptar_btnActionPerformed(evt);
            }
        });
        getContentPane().add(aceptar_btn, new org.netbeans.lib.awtextra.AbsoluteConstraints(10, 350, -1, -1));
 
        jLabel1.setText("Mail");
        getContentPane().add(jLabel1, new org.netbeans.lib.awtextra.AbsoluteConstraints(10, 170, -1, 20));
 
        jLabel2.setText("Direccion");
        getContentPane().add(jLabel2, new org.netbeans.lib.awtextra.AbsoluteConstraints(10, 210, -1, 20));
 
        jLabel3.setText("Nombre");
        getContentPane().add(jLabel3, new org.netbeans.lib.awtextra.AbsoluteConstraints(10, 90, -1, 20));
 
        jLabel4.setText("Nota");
        getContentPane().add(jLabel4, new org.netbeans.lib.awtextra.AbsoluteConstraints(10, 250, -1, 20));
 
        jLabel5.setText("N. de telefono");
        getContentPane().add(jLabel5, new org.netbeans.lib.awtextra.AbsoluteConstraints(10, 130, -1, 20));
 
        jLabel6.setFont(new java.awt.Font("Tahoma", 1, 18)); // NOI18N
        jLabel6.setText("Agenda");
        getContentPane().add(jLabel6, new org.netbeans.lib.awtextra.AbsoluteConstraints(150, 20, -1, -1));
        getContentPane().add(id_contacto, new org.netbeans.lib.awtextra.AbsoluteConstraints(290, 420, -1, -1));
 
        pack();
    }// </editor-fold>                        
 
    private void numerotel_txtActionPerformed(java.awt.event.ActionEvent evt) {
        // TODO add your handling code here:
    }
 
    private void aceptar_btnActionPerformed(java.awt.event.ActionEvent evt) {
      guardar(); //llamamos a la funcion guardar
    }
 
    private void salir_btnActionPerformed(java.awt.event.ActionEvent evt) {
     dispose(); //cerramos el programa
    }
 
    private void cancelar_btnActionPerformed(java.awt.event.ActionEvent evt) {
        cancelar();
//aca borramos todos los txt
    }
 
    /**
     * @param args the command line arguments
     */
    public static void main(String args[]) {
        /* Set the Nimbus look and feel */
        //<editor-fold defaultstate="collapsed" desc=" Look and feel setting code (optional) ">
        /* If Nimbus (introduced in Java SE 6) is not available, stay with the default look and feel.
         * For details see http://download.oracle.com/javase/tutorial/uiswing/lookandfeel/plaf.html 
         */
        try {
            for (javax.swing.UIManager.LookAndFeelInfo info : javax.swing.UIManager.getInstalledLookAndFeels()) {
                if ("Nimbus".equals(info.getName())) {
                    javax.swing.UIManager.setLookAndFeel(info.getClassName());
                    break;
                }
            }
        } catch (ClassNotFoundException ex) {
            java.util.logging.Logger.getLogger(frm_agenda.class.getName()).log(java.util.logging.Level.SEVERE, null, ex);
        } catch (InstantiationException ex) {
            java.util.logging.Logger.getLogger(frm_agenda.class.getName()).log(java.util.logging.Level.SEVERE, null, ex);
        } catch (IllegalAccessException ex) {
            java.util.logging.Logger.getLogger(frm_agenda.class.getName()).log(java.util.logging.Level.SEVERE, null, ex);
        } catch (javax.swing.UnsupportedLookAndFeelException ex) {
            java.util.logging.Logger.getLogger(frm_agenda.class.getName()).log(java.util.logging.Level.SEVERE, null, ex);
        }
        //</editor-fold>
 
        /* Create and display the form */
        java.awt.EventQueue.invokeLater(new Runnable() {
            public void run() {
                new frm_agenda().setVisible(true);
            }
        });
    }
 
    // Variables declaration - do not modify                     
    private javax.swing.JToggleButton aceptar_btn;
    private javax.swing.JToggleButton cancelar_btn;
    private javax.swing.JTextField direccion_txt;
    private javax.swing.JTextField id_contacto;
    private javax.swing.JLabel jLabel1;
    private javax.swing.JLabel jLabel2;
    private javax.swing.JLabel jLabel3;
    private javax.swing.JLabel jLabel4;
    private javax.swing.JLabel jLabel5;
    private javax.swing.JLabel jLabel6;
    private javax.swing.JTextField mail_txt;
    private javax.swing.JToggleButton modiicar_btn;
    private javax.swing.JTextField nombre_txt;
    private javax.swing.JTextField nota_txt;
    private javax.swing.JTextField numerotel_txt;
    private javax.swing.JToggleButton salir_btn;
    // End of variables declaration                   
 
            private void guardar(){
        if (frm_agenda.conexion()){
            String sql1 = "insert into agenda (nombre_contacto,telefono_contacto, mail_contacto, direccion_contacto, nota_contacto)"
                    + "values ('"
 
                    + nombre_txt.getText() + "','"
                    + numerotel_txt.getText() + "','"
                    + mail_txt.getText() + "','"
                    + direccion_txt.getText() + "','"
                    + nota_txt.getText() + "')";
            try {
                 conexion.getSt().executeUpdate(sql1);
                 JOptionPane.showMessageDialog(null, "Guardado", "Mensaje del Sistema", JOptionPane.INFORMATION_MESSAGE);
            } catch (SQLException ex) {
                Logger.getLogger(frm_agenda.class.getName()).log(Level.SEVERE, null, ex);
                //JOptionPane.showMessageDialog(null, "Error", "Mensaje del Sistema", JOptionPane.INFORMATION_MESSAGE);
            }
        }
}
 
           private void cancelar(){
                    nombre_txt.setText("");
                    numerotel_txt.setText("");
                    mail_txt.setText("");
                    direccion_txt.setText("");
                    nota_txt.setText("");
           }
 
}




Si pueden mostrarme el error y como solucionar sin tantos rodeos se los agradeceria mucho
Valora esta pregunta
Me gusta: Está pregunta es útil y esta claraNo me gusta: Está pregunta no esta clara o no es útil
0
Responder
Imágen de perfil de kingk
Val: 247
Ha mantenido su posición en Java (en relación al último mes)
Gráfica de Java

Guardar datos en una DB (myql) desde Netbean (java)

Publicado por kingk (108 intervenciones) el 25/06/2018 04:37:55
Hola, el problema podria estar en la condicion que utilizas:
if(frm_agenda.conexion()){
...
}
Valora esta respuesta
Me gusta: Está respuesta es útil y esta claraNo me gusta: Está respuesta no esta clara o no es útil
0
Comentar