Java 无法将数据从JTable插入数据库
我正在编写一个程序,将数据从Java 无法将数据从JTable插入数据库,java,mysql,database,swing,jtable,Java,Mysql,Database,Swing,Jtable,我正在编写一个程序,将数据从JTable插入数据库。我没有收到任何错误或异常。即使对象也已正确填充。但是不知道executeUpdate语句失败的原因。下面是我的代码 import javax.swing.JFrame; import java.awt.*; import java.awt.event.*; import java.sql.Connection; import java.sql.DriverManager; import java.sql.PreparedStatement; i
JTable
插入数据库。我没有收到任何错误或异常。即使对象也已正确填充。但是不知道executeUpdate
语句失败的原因。下面是我的代码
import javax.swing.JFrame;
import java.awt.*;
import java.awt.event.*;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import javax.swing.*;
import javax.swing.table.*;
import javax.swing.event.*;
public class Table extends JFrame implements ActionListener, TableModelListener {
private JTable table;
private JButton addItem, cancel, save, load, search;
DefaultTableModel tableModel;
Object[] columnNames = new Object[]{
"Item No", "ItemName","UnitPrice", "Qty","TotalPrice","Supplier","Remarks"};
public Table() {
getContentPane().setLayout( new FlowLayout() );
tableModel = new DefaultTableModel(columnNames, 0);
tableModel.addTableModelListener( this );
table = new JTable(tableModel);
JScrollPane scrollPane = new JScrollPane(table);
table.setPreferredScrollableViewportSize(new Dimension(600, 400));
getContentPane().add(scrollPane);
addItem = new JButton( "Add" );
addItem.addActionListener( this );
getContentPane().add( addItem );
save = new JButton( "Save" );
save.addActionListener( this );
getContentPane().add( save );
cancel = new JButton( "Cancel" );
cancel.addActionListener( this );
getContentPane().add( cancel );
setVisible( true );
setSize( 640, 500 );
}
public void tableChanged( TableModelEvent e ) {
}
public void actionPerformed( ActionEvent evt ) {
int row = table.getSelectedRow();
int column = table.getSelectedColumn();
if(evt.getSource()== addItem)
{
tableModel.addRow(new Object[]{"","","","","","",""});
}
else if ( evt.getSource() == save )
saveCustomers();
}
private void saveCustomers() {
PreparedStatement pstm = null;
ResultSet rs;
int index=1;
int count=table.getRowCount();
try{
Class.forName("com.mysql.jdbc.Driver");
Connection connect =DriverManager.getConnection("jdbc:mysql://localhost/restaurant","root","root");
for(int i=0;i<count;i++){
Object obj1 = GetData(table, i, 0);
Object obj2 = GetData(table, i, 1);
Object obj3 = GetData(table, i, 2);
Object obj4 = GetData(table, i, 3);
Object obj5 = GetData(table, i, 4);
Object obj6 = GetData(table, i, 5);
Object obj7 = GetData(table, i, 6);
int value1= Integer.parseInt(obj1.toString());
System.out.println(value1);
String value2=obj2.toString();
double value3=Double.parseDouble(obj3.toString());
System.out.println(value2);
double value4=Double.parseDouble(obj4.toString());
System.out.println(value3);
double value5=Double.parseDouble(obj5.toString());
System.out.println(value5);
String value6=obj6.toString();
System.out.println(value6);
String value7=obj7.toString();
System.out.println(value7);
pstm=connect.prepareStatement("insert into stock values(?,?,?,?,?,?,?)");
System.out.println("Preperation");
pstm.setInt(1,value1);
pstm.setString(2,value2);
pstm.setDouble(3,value3);
pstm.setDouble(4, value4);
pstm.setDouble(5,value5);
pstm.setString(6, value6);
pstm.setString(7, value7);
index++;
}
System.out.println("execute");
pstm.executeUpdate();
System.out.println("saved Successfully");
}
catch(Exception e){}
}
public Object GetData(JTable table, int row_index, int col_index){
return table.getModel().getValueAt(row_index, col_index);
}
public static void main ( String[] args ) {
Table frm = new Table();
frm.setVisible(true);
frm.setSize( 640, 500 );
frm.setResizable(false);
WindowQuitter wquit = new WindowQuitter();
frm.addWindowListener( wquit );
}
}
class WindowQuitter extends WindowAdapter {
public void windowClosing( WindowEvent e ) {
System.exit( 0 );
}
}
import javax.swing.JFrame;
导入java.awt.*;
导入java.awt.event.*;
导入java.sql.Connection;
导入java.sql.DriverManager;
导入java.sql.PreparedStatement;
导入java.sql.ResultSet;
导入javax.swing.*;
导入javax.swing.table.*;
导入javax.swing.event.*;
公共类表扩展JFrame实现ActionListener、TableModelListener{
专用JTable表;
私有JButton addItem、取消、保存、加载、搜索;
DefaultTableModel表格模型;
对象[]列名称=新对象[]{
“项目编号”、“项目名称”、“单价”、“数量”、“总价”、“供应商”、“备注”};
公共表(){
getContentPane().setLayout(新的FlowLayout());
tableModel=新的DefaultTableModel(columnNames,0);
tableModel.addTableModelListener(此);
table=新的JTable(tableModel);
JScrollPane scrollPane=新的JScrollPane(表);
table.setPreferredScrollableViewportSize(新维度(600400));
getContentPane().add(滚动窗格);
addItem=新的按钮(“添加”);
addItem.addActionListener(此);
getContentPane().add(addItem);
保存=新的JButton(“保存”);
save.addActionListener(这个);
getContentPane()。添加(保存);
取消=新的JButton(“取消”);
cancel.addActionListener(此);
getContentPane()。添加(取消);
setVisible(真);
设置大小(640500);
}
公共作废表已更改(TableModelEvent e){
}
已执行的公共无效操作(操作事件evt){
int row=table.getSelectedRow();
int column=table.getSelectedColumn();
if(evt.getSource()==addItem)
{
addRow(新对象[]{“”、“”、“”、“”、“”、“”、“”、“”、“”、“”、“”、“”});
}
else if(evt.getSource()=保存)
储蓄客户();
}
私人客户(){
PreparedStatement pstm=null;
结果集rs;
int指数=1;
int count=table.getRowCount();
试一试{
Class.forName(“com.mysql.jdbc.Driver”);
Connection connect=DriverManager.getConnection(“jdbc:mysql://localhost/restaurant“,”根“,”根“);
对于(inti=0;i我不确定,但我认为您的连接url是错误的,请尝试以下方法
Connection con = ( Connection ) DriverManager.getConnection( "jdbc:mysql://localhost:3306/yourdatabasename", "yourmysqlid", "yourmysqlpassword" );
其中,3306
是本地主机上mysql的默认端口号。您的insert语句不正确,应使用:
connect.prepareStatement("insert into stock(field1,field2,field3,field4,field5,field6,field7) values(?,?,?,?,?,?,?)");
(用实际字段名替换字段!)
因为据我所知,您必须指出每个?
对应的字段
参见一些示例。“我没有收到任何错误或异常。”这并不奇怪,因为代码..catch(异常e){}
。忽略它们!将每个catch更改为catch(异常e){e.printStackTrace();}
这里我得到了一个java.lang.ClassNotFoundException:com.mysql.jdbc.Driver
,但是您可能会得到不同的异常。当我使用jtable1.getModel().getValueAt(I,0)获取数据时,
直到jtable1.getModel().getValueAt(I,4)
。我没有从表中获取最后一行。这会有什么问题?并且在线程“AWT-EventQueue-0”java.lang.NullPointerException中获取异常错误。url字符串“jdbc:mysqlL///
”也适用于默认值。