Исключение при подключении к JDBC MySQL - PullRequest
0 голосов
/ 20 февраля 2019

Добрый день: я учитель химии из Испании.Я не опытный программист, но я решил создать небольшую программу, чтобы помочь моим студентам с моим предметом.Я создаю эту небольшую программу на Java, где я пытаюсь соединиться с базой данных, чтобы получать ее информацию через атомный номер.На самом деле, я также хочу сделать это через другие параметры, но я не уверен, как это сделать.Дело в том, что оно возвращает исключение или неправильно подключается к базе данных.Я присваиваю полный код и снимок экрана с моей базой данных (кстати, когда я пытаюсь загрузить данные в базу, это работает.):

package chemInterface;

import java.awt.BorderLayout;
import java.awt.EventQueue;

import javax.swing.JFrame;
import javax.swing.JPanel;
import javax.swing.border.EmptyBorder;



import java.awt.Color;
import java.awt.Font;
import javax.swing.JLabel;
import javax.swing.JPasswordField;
import javax.swing.JTextField;
import javax.swing.JButton;
import java.awt.event.ActionListener;
import java.sql.DriverManager;
import java.sql.SQLException;
import java.sql.Statement;
import java.sql.Connection;
import java.sql.ResultSet;
import java.awt.event.ActionEvent;

public class Oxidaciones extends JFrame {

private JPanel contentPane;
private JPasswordField pass;
private JTextField smb;
private JTextField elm;
private JTextField ox;
private JTextField nat;
private JTextField mat;

/**
 * Launch the application.
 */
public static void main(String[] args) {
    EventQueue.invokeLater(new Runnable() {
        public void run() {
            try {
                Oxidaciones frame = new Oxidaciones();
                frame.setVisible(true);
            } catch (Exception e) {
                e.printStackTrace();
            }
        }
    });
}

/**
 * Create the frame.
 */
public Oxidaciones() {
    setFont(new Font("Courier Prime", Font.PLAIN, 12));
    setTitle("Interface");
    setForeground(Color.BLUE);
    setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
    setBounds(100, 100, 450, 300);
    contentPane = new JPanel();
    contentPane.setForeground(Color.BLUE);
    contentPane.setBorder(new EmptyBorder(5, 5, 5, 5));
    setContentPane(contentPane);
    contentPane.setLayout(null);

    JLabel lblSmbolo = new JLabel("Smb");
    lblSmbolo.setFont(new Font("Courier Prime", Font.PLAIN, 11));
    lblSmbolo.setBounds(10, 30, 67, 14);
    contentPane.add(lblSmbolo);

    JLabel lblElemento = new JLabel("Elm");
    lblElemento.setFont(new Font("Courier Prime", Font.PLAIN, 11));
    lblElemento.setBounds(10, 52, 67, 14);
    contentPane.add(lblElemento);

    JLabel lblOxidacin = new JLabel("Ox");
    lblOxidacin.setFont(new Font("Courier Prime", Font.PLAIN, 11));
    lblOxidacin.setBounds(10, 77, 67, 14);
    contentPane.add(lblOxidacin);

    JLabel lblNAtmico = new JLabel("NAt");
    lblNAtmico.setFont(new Font("Courier Prime", Font.PLAIN, 11));
    lblNAtmico.setBounds(10, 102, 86, 14);
    contentPane.add(lblNAtmico);

    JLabel lblMAtmica = new JLabel("MAt");
    lblMAtmica.setFont(new Font("Courier Prime", Font.PLAIN, 11));
    lblMAtmica.setBounds(10, 127, 86, 14);
    contentPane.add(lblMAtmica);

    pass = new JPasswordField();
    pass.setBounds(90, 166, 67, 20);
    contentPane.add(pass);

    JLabel lblPass = new JLabel("Pass");
    lblPass.setFont(new Font("Courier Prime", Font.PLAIN, 11));
    lblPass.setBounds(10, 169, 67, 14);
    contentPane.add(lblPass);

    smb = new JTextField();
    smb.setBounds(67, 25, 86, 20);
    contentPane.add(smb);
    smb.setColumns(10);

    elm = new JTextField();
    elm.setColumns(10);
    elm.setBounds(67, 47, 86, 20);
    contentPane.add(elm);

    ox = new JTextField();
    ox.setColumns(10);
    ox.setBounds(67, 72, 86, 20);
    contentPane.add(ox);

    nat = new JTextField();
    nat.setColumns(10);
    nat.setBounds(67, 97, 86, 20);
    contentPane.add(nat);

    mat = new JTextField();
    mat.setColumns(10);
    mat.setBounds(67, 127, 86, 20);
    contentPane.add(mat);

    JLabel lblResultado = new JLabel("");
    lblResultado.setBounds(243, 232, 46, 14);
    contentPane.add(lblResultado);


    JButton compile = new JButton("Compile");
    compile.addActionListener(new ActionListener() {
        @SuppressWarnings("deprecation")
        public void actionPerformed(ActionEvent arg0) {


            //COMPILE Presionado



                //INSERT BETWEEN HERE

                ox.setText("");
                elm.setText("");
                mat.setText("");
                nat.setText("");
                smb.setText("");

                try {
                Connection conexion=DriverManager.getConnection("jdbc:mysql://localhost/chem","root" ,"");
                Statement comando=conexion.createStatement();
                ResultSet registro = comando.executeQuery("select elemento,simbolo,oxidacion,matom from form where natom="+nat.getText());
                if(registro.next()==true) {
                    smb.setText(registro.getString("simbolo"));
                    ox.setText(registro.getString("oxidacion"));
                    elm.setText(registro.getString("elemento"));
                    mat.setText(registro.getString("matom"));
                } else {lblResultado.setText("No existe");}
                conexion.close();
                } catch(SQLException ex) {setTitle(ex.toString());}





            //AND HERE  

            }






    });
    compile.setBounds(7, 194, 89, 23);
    contentPane.add(compile);

    JButton clear = new JButton("Clear");
    clear.setBounds(7, 228, 89, 23);
    contentPane.add(clear);

    JButton alta = new JButton("Alta");
    alta.addActionListener(new ActionListener() {
        public void actionPerformed(ActionEvent arg0) {


            //BOTON ALTA PRESIONADO

            lblResultado.setText("");

            try {
                  Connection conexion=DriverManager.getConnection("jdbc:mysql://localhost/chem","root", "");
                  Statement comando=conexion.createStatement();
                  comando.executeUpdate("insert into form(elemento,simbolo,oxidacion,natom,matom) values ('"+elm.getText()+"','"+smb.getText()+"','"+ox.getText()+"',"+nat.getText()+","+mat.getText()+")");
                  conexion.close();
                  lblResultado.setText("se registraron los datos");
                  elm.setText("");
                  ox.setText("");
                  nat.setText("");
                  mat.setText("");
                  smb.setText("");
                } catch(SQLException ex){
                  setTitle(ex.toString());
                }

        }
    });
    alta.setBounds(335, 228, 89, 23);
    contentPane.add(alta);


    cargarDriver();
}

private void cargarDriver() {
    try {
        Class.forName("com.mysql.jdbc.Driver");
    }
    catch(Exception ex) {
        setTitle(ex.toString());
    }
}
}

Вот моя база данных:

база данных phpmyadmin

И вот исключение при вставке 1 в NAt:

Фактическое исключение

Ответы [ 3 ]

0 голосов
/ 21 февраля 2019

Пожалуйста, попробуйте выполнить ваш SQL-запрос вручную с вашим клиентом БД.Для этого вы можете добавить подобный код или использовать отладку, чтобы получить строковое значение sql и проверить его:

String sqlString = "insert into form(elemento,simbolo,oxidacion,natom,matom) values ('"+elm.getText()+"','"+smb.getText()+"','"+ox.getText()+"',"+nat.getText()+","+mat.getText()+")";
System.out.println(sqlString);
comando.executeUpdate(sqlString);

Вам нужно получить фактическую строку SQL и проверить ее вручную, если она работает.

0 голосов
/ 22 февраля 2019

Взглянув на ваш код вокруг select запроса, вы запускаете

            nat.setText("");

, а затем

            ResultSet registro = comando.executeQuery("select elemento,simbolo,oxidacion,matom from form where natom="+nat.getText());

Что вы ожидаете nat.getText(), чтобы вернуться сюда?

Конечно, он вернет "", потому что это то, для чего вы установили текст nat.Затем вы просите свою базу данных выполнить следующий недопустимый запрос:

    select elemento,simbolo,oxidacion,matom from form where natom=

Запуск этого для базы данных MySQL вызовет ошибку на вашем скриншоте.

Я предполагаю, что это исправлениедля удаления строки nat.setText("");.

Однако вместо создания строк SQL с использованием конкатенации строк используйте PreparedStatement s вместо.

Замените строки

            Statement comando=conexion.createStatement();
            ResultSet registro = comando.executeQuery("select elemento,simbolo,oxidacion,matom from form where natom="+nat.getText());

с

            PreparedStatement comando=conexion.prepareStatement(
                "select elemento,simbolo,oxidacion,matom from form where natom=?");
            comando.setInt(1, Integer.parseInt(nat.getText()));
            ResultSet registro = comando.executeQuery();

и строками

              Statement comando=conexion.createStatement();
              comando.executeUpdate("insert into form(elemento,simbolo,oxidacion,natom,matom) values ('"+elm.getText()+"','"+smb.getText()+"','"+ox.getText()+"',"+nat.getText()+","+mat.getText()+")");

с

              Statement comando=conexion.prepareStatement(
                  "insert into form(elemento,simbolo,oxidacion,natom,matom) values (?,?,?,?,?)");
              comando.setString(1, elm.getText());
              comando.setString(2, smb.getText());
              comando.setString(3, ox.getText());
              comando.setString(4, Integer.parseInt(nat.getText()));
              comando.setString(5, Integer.parseInt(mat.getText()));
              comando.executeUpdate();

Вам также необходимо добавить некоторые ошибки-обработка вызовов Integer.parseInt(...): они будут выдавать NumberFormatException, если nat.getText() или mat.getText() не является допустимым целым числом.

0 голосов
/ 20 февраля 2019

Если бы вы могли присоединить или описать точно, что такое sqlException, это могло бы помочь, но из того, что я вижу, URL вашего соединения с базой данных искажен.Поэтому, вероятно, он не подключается к базе данных

Ваш URL: Connection conexion = DriverManager.getConnection("jdbc:mysql://localhost/chem","root" ,"");

Обычно вам нужно добавить номер порта, на котором работает база данных, поэтому измените:

"jdbc:mysql://localhost/chem"

to:

jdbc:mysql://localhost:3306/chem

или независимо от того, на каком порту работает ваша база данных, в Google это выглядит как номер порта по умолчанию 3360, но это зависит от того, как вы настроили свою базу данных.Но я думаю, что это должно решить вашу проблему

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...