java - 将数据插入数据库时​​遇到问题

标签 java swing jdbc

当我使用下面的示例代码将数据输入数据库时​​,System.out.println("Insertion complete") 行显示在控制台上。当我去数据库时,发现存储的数据是一片空白。

我认为问题可能出在我的 sqlquery 上,但我没有发现它有任何问题。

这是我的代码示例:

public class SignUpFrame extends JFrame {

    public SignUpFrame() {

        super("SIGN UP");   
        setLayout(null);
        setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
        setSize(400, 400);
        setVisible(true);
        setResizable(false);
        setLocation(500, 250);
        getContentPane().setBackground(Color.WHITE);    

        ImageIcon FrameIcon = new ImageIcon("images/signup.png");
        JLabel frameicon = new JLabel(FrameIcon);
        frameicon.setBounds(150, 0, 100, 100);
        add(frameicon);


        JLabel firstNamelbl,LastNameLbl,EmailAddressLbl,PasswordLbl,ConfirmPasswordLbl;

        JTextField firstNametxt,LastNametxt,EmailAddresstxt;
        JPasswordField passwordtxt,ConfirmPasswordtxt;
        JButton OKbtn;
        JButton CANCELbtn;

        firstNamelbl  = new JLabel("FIRST NAME:");
        firstNametxt = new JTextField();
        firstNametxt.setBounds(150, 110, 200, 20);
        firstNamelbl.setBounds(50, 110, 100, 20);

        LastNameLbl = new JLabel("USERNAME:");
        LastNametxt = new JTextField();
        LastNametxt.setBounds(150, 140, 200, 20);
        LastNameLbl.setBounds(50,140, 100, 20);

        EmailAddressLbl = new JLabel("EMAIL ADDRESS:");
        EmailAddresstxt = new JTextField();
        EmailAddresstxt.setBounds(150, 170, 200, 20);
        EmailAddressLbl.setBounds(50, 170, 150, 20);

        PasswordLbl = new JLabel("PASSWORD:");
        passwordtxt = new JPasswordField();
        passwordtxt.setBounds(150, 200, 200, 20);
        PasswordLbl.setBounds(50, 200, 150, 20);

        ConfirmPasswordLbl = new JLabel("CONFIRM PASSWORD:");
        ConfirmPasswordtxt = new JPasswordField();
        ConfirmPasswordtxt.setBounds(200, 230, 150, 20);
        ConfirmPasswordLbl.setBounds(50, 230, 150, 20);

        add(firstNamelbl);
        add(firstNametxt);

        add(LastNameLbl);
        add(LastNametxt);

        add(EmailAddressLbl);
        add(EmailAddresstxt);

        add(PasswordLbl);
        add(passwordtxt);

        add(ConfirmPasswordLbl);
        add(ConfirmPasswordtxt);

        OKbtn = new JButton("OK");
        OKbtn.setBounds(100, 270, 50, 20);
        add(OKbtn);
        char [] pass = passwordtxt.getPassword();
        String passWord = new String(pass);


        String FIRSTNAME,USERNAME,EMAIL,PASSWORD;
         FIRSTNAME = firstNametxt.getText().toString();
         USERNAME =LastNametxt.getText().toString();
         EMAIL = EmailAddresstxt.getText().toString();
         PASSWORD = passWord;




        OKbtn.addActionListener(new ActionListener() {

            @Override
            public void actionPerformed(ActionEvent e) {


                String url = "jdbc:mysql://localhost:3306/System";
                String user = "root";
                String password = "";

                Connection con;
                try {
                    con = DriverManager.getConnection(url, user, password);
                    Statement statement = con.createStatement();
                    String sqlquery = "insert into signUp_tb "+
                                       "(FirstName,UserName,Email,Password) values ('"+FIRSTNAME+"','"+USERNAME+"','"+EMAIL+"','"+PASSWORD+"')";

                    statement.executeUpdate(sqlquery);
                    System.out.println("Insertion complete");
                } catch (SQLException e1) {
                    // TODO Auto-generated catch block
                    e1.printStackTrace();
                }

            }
        });




        CANCELbtn = new JButton("CANCEL");
        CANCELbtn.setBounds(170, 270, 100, 20);
        add(CANCELbtn);

        CANCELbtn.addActionListener(new ActionListener() {

            @Override
            public void actionPerformed(ActionEvent e) {
                setVisible(false);
                dispose();

            }
        });

    }


}

最佳答案

您需要在 ActionListener 中为 OK 按钮初始化您的 FIRSTNAMEUSERNAME 等。当没有输入数据时,您已经初始化了那些 Strings,这就是为什么一切都是空白的。您想要在用户按下按钮时 获取 JTextFields 值。之前没有。

在 SQLite 上测试。

OKbtn.addActionListener(new ActionListener() {

    @Override
    public void actionPerformed(ActionEvent e) {

        char [] pass = passwordTxt.getPassword();
        String PASSWORD = new String(pass);

        String FIRSTNAME,USERNAME,EMAIL;
        FIRSTNAME = firstNameTxt.getText();
        USERNAME = lastNameTxt.getText();
        EMAIL = emailAddressTxt.getText();


        String url = "jdbc:mysql://localhost:3306/System";
        String user = "root";
        String password = "";

        Connection con;
        try {
            con = DriverManager.getConnection(url, user, password);
            Statement statement = con.createStatement();
            String sqlquery = "insert into signUp_tb "+
                               "(FirstName,UserName,Email,Password) values ('"+FIRSTNAME+"','"+USERNAME+"','"+EMAIL+"','"+PASSWORD+"')";

            statement.executeUpdate(sqlquery);
            System.out.println("Insertion complete");
        } catch (SQLException e1) {
            // TODO Auto-generated catch block
            e1.printStackTrace();
        }

    }
});

setVisible(true) 应该是您做的最后一件事。应该看起来像:

SwingUtilities.invokeLater(() -> {
    this.setVisible(true);
});

因此您将从美国东部时间启动它。

编辑:关于 setLayout(null) - 尝试那些 A Visual Guide to Layout Managers .

Although it is possible to do without a layout manager, you should use a layout manager if at all possible. A layout manager makes it easier to adjust to look-and-feel-dependent component appearances, to different font sizes, to a container's changing size, and to different locales. Layout managers also can be reused easily by other containers, as well as other programs.

来自 Doing Without a Layout Manager (Absolute positioning)

关于java - 将数据插入数据库时​​遇到问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44585679/

相关文章:

java - 设置 Jlabel 格式 - JTextBox

Java:根据枚举中的列对 JTable 进行排序

java - 不同的数据库,不同的结果类型 'SELECT 1' 超过 jdbc : how to check the value?

java - 从 servlet 访问数据

java - Android 数据绑定(bind) : ConcurrentModificationException while using ternary operator in method parameter

java - 我在 xml 文件中传递参数,但系统仍将其值设为 param-val-not-found

java - 康威的生命游戏人口过剩?

java - 素数计算器需要太多时间(JAVA)

java - 在扩展 JPanel 的类中使用多个面板

java - 使用 JDBC 连接到 Mysql 时出现 ClassNotFoundException