如何将 JTextField 中的数据保存到 mysql 数据库中?

Posted

技术标签:

【中文标题】如何将 JTextField 中的数据保存到 mysql 数据库中?【英文标题】:How can I save data from JTextField into the mysql database? 【发布时间】:2011-07-22 12:46:30 【问题描述】:
import java.awt.Panel;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.Statement;
import javax.swing.JButton;
import javax.swing.JFrame;
import javax.swing.JLabel;
import javax.swing.JTextField;
import com.mysql.jdbc.Connection;

public class one 

    JFrame frame = new JFrame("ghar hisab");
    JButton b = new JButton("save");
    Panel p = new Panel();
    JTextField f = new JTextField(20);
    JTextField f1 = new JTextField(20);
    JLabel l = new JLabel("Enter the first name");
    JLabel l1 = new JLabel("Enter the first name");
    String s1,s2;
    String ppl;
    int people;

    void display() throws Exception
        p.add(l);
        p.add(f);
        p.add(l1);
        p.add(f1);
        p.add(b);

        frame.setSize(400,400);

        frame.setVisible(true);
        frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
        frame.getContentPane().add(p);
        s1=f.getText();
        s2=f1.getText();


        Class.forName("com.mysql.jdbc.Driver");
        Connection con = (Connection) DriverManager.getConnection("jdbc:mysql://localhost:3306/people","root","desire");

        Statement stat = con.createStatement();
        //  String s3= "insert into name values s1 + s2";
        //  stat.executeUpdate(s3);

        stat.executeQuery("insert into name (first,last) values('"s1"','"s2"')");


        //  ResultSet rs= stat.executeQuery("insert into name (first,last) values("arun","yadav"));


        //while(rs.next())
        //      System.out.println(rs.getString(1)+" "+rs.getString(2));
        //  
    

当我尝试使用 s1 和 s2 更新数据库时,出现错误。

【问题讨论】:

这不是你的问题,但改变 Panel p = new Panel();到 JPanel p = new JPanel();,请不要将 AWT 与 Swing 混合使用 【参考方案1】:

不确定这可能是问题,但您的 stat.executeQuery(...) 声明是错误的,应该是:

stat.executeQuery("insert into name (first,last) values('"+s1+"','"+s2+"')");

要将字符串与变量连接使用+ 运算符。

【讨论】:

考虑接受/支持有用的答案。阅读:meta.stackexchange.com/questions/5234/… 另见SQL injection和magic links,例如faq。【参考方案2】:

将此代码复制并粘贴到您的项目中,这是 100% 的工作

数据插入方法:

public void insert()
   
    try 
    // connection string
        Class.forName("com.mysql.jdbc.Driver").newInstance();
        Connection con = DriverManager
                .getConnection("jdbc:mysql://localhost:3306/Project?user=root&password=root");
        Statement st = con.createStatement();

        st.executeUpdate("insert into Register VALUES('"
                + tf1.getText() + "','" + tf2.getText() + "','"
                + tf3.getText() + "','" + cb1.getSelectedItem()
                + "','" + tf4.getText() + "','" + tf5.getText()
                + "','" + tf6.getText() + "','" + tf7.getText()
                + "','" + tf8.getText() + "','" + tf9.getText()
                + "'," + "'" + tf10.getText() + "','"
                + tf11.getText() + "','" + tf12.getText() + "','"
                + tf13.getText() + "','" + tf14.getText() + "',"
                + "'" + tf15.getText() + "','" +tf16.getText()
                + "','" + tf17.getText() + "','" + tf18.getText()
                + "'," + "'" + tf19.getText() + "','"
                + p1.getText() + "','" + p2.getText() + "')");

        JOptionPane.showConfirmDialog(null, "Your Data Has been Inserted",
                "Result", JOptionPane.DEFAULT_OPTION,
                JOptionPane.PLAIN_MESSAGE);

        st.close();
        con.close();

    

    catch (Exception e1)

    
        System.out.println("Exception:" + e1);
    


然后使用按钮调用方法:

        b1.addActionListener(new ActionListener() 

        public void actionPerformed(ActionEvent arg0) 
            insert();
        

    );

【讨论】:

以上是关于如何将 JTextField 中的数据保存到 mysql 数据库中?的主要内容,如果未能解决你的问题,请参考以下文章

如何从 Jpanel 中的 JTextField 获取值并将其发送到其他 JPanel?

多个 JTextfield 的空字符串验证

如何将列表框项目保存到 my.settings

请问,Java编写界面,如何在 jtextfield 输入数据后,下次打开界面,内容还存在

如何从另一个 java 类中的 jTextField 或 jFormattedTextField 获取数据

在 JTextField 中保存值