- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在编写一个程序,将数据从 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 );
}
}
最佳答案
我不确定,但我认为你的连接 url 是错误的,试试这个
Connection con = ( Connection ) DriverManager.getConnection( "jdbc:mysql://localhost:3306/yourdatabasename", "yourmysqlid", "yourmysqlpassword" );
其中 3306
是本地主机上 mysql 的默认端口号。
关于java - 无法将数据从 JTable 插入数据库,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10659310/
我已经多次看到我的问题被问到,但我从未看到我期望的答案。我已经在 JTable 中输入了数据库的元素,并且我希望能够通过一些 JButtons 删除/添加元素。问题是当我添加/删除时,修改在数据库
我正在使用 JTable 做一个项目,我想让我的表格单元格可编辑。我用过, public boolean isCellEditable(int row, int column) {
我正在编写一个应用程序包,其中包含一个主类,其中主方法与GUI类分开,GUI类包含一个带有jtabbedpane的jframe,它有两个选项卡,第一个选项卡包含一个jtable,称为jtable1,第
我制作了一个表格来将 Arraylist 中的数据加粗,但如果我删除该数据,我会希望该表格更新并取消对 Arraylist 中加粗的单元格的粗体显示。我该怎么做呢?或从另一个类关闭该类的实例 最佳答案
如果我的 JTable 的列未按字母顺序排列,我可以使用 getSelectedRows() 并毫无问题地获取它们的行的值。但是,如果用户单击列名并且行在该列中按字母顺序排列,则 getSelecte
我有一个 JTable,用户可以在其中在单元格中输入数据。然后有一个“保存”按钮,用于收集表格数据,将其格式化为 csv,并将其保存到文件中。 但是,如果用户将最后编辑的单元格保留在选定状态,并单击“
我编写了下面的代码,以便在当前 JTable 上进行选择时创建一个新的 JTable: makeTbale.addActionListener(new ActionListener() { pub
我正在使用 Swing 编写 Java 应用程序。我有两个表,我必须将内容从一个表复制到另一个表(复制)。问题是,如果我清除目标表行,那么我的源表行也会被删除。 如果我按 CopyAll,那么我会将
我一直致力于JTable,我的项目: 从数据库读取数据(我完成了这个任务并能够在JTable中显示)。 然后将数据按子组显示并保存到文件(文本/Excel)中。 我有 JTable 的基本知识,并且使
我有以下类(class): public class customer_master extends javax.swing.JInternalFrame { Connection con =
您好,我是 JAVA 的新手,在学习时正在开发 GUI。我创建了一个带有 ScrollPane 和 JTable 的 JFrame。当我增加 2 列以上时,第一行下方的数据不会显示。 此外,当我的 J
我正在进行项目的最后一部分,这是我遇到的最后问题之一。这部分用于编辑预订,即更改为特定预订预订的房间。我有 2 个 JTable,其中一个有可用房间,另一个有已预订的房间。两者都有单独的 Defaul
我有 2 个 JTable,我需要从表 2 中复制特定列(包括该列中的所有数据)并将其添加到表 1 中的下一个空闲列中。有人知道执行此操作的最佳方法吗? 谢谢 最佳答案 DefaultTableMod
美好的一天!我在 Jtable 方面遇到了困难。我已经阅读和浏览了各种教程,但我不太明白它的要点。我的问题是,我必须从 jtable (jTable1) 中选择包含 (ClientID、LastNam
我的 SERVER 表单上有一个 JTable,它是从 MySQL 数据库填充的,在构造函数中编码: String sql = "SELECT * from fiekorari"; t
我在我的项目上工作,我需要将一行从 JTable 复制到另一个 JTable,第二个 JTable 应该只是单行表。我为第一个 JTable 创建了 mouselistener,双击它应该复制行并将其
我有这段代码可以完全按预期工作 package com.grantbroadwater.signInAssistant.view; import java.awt.BorderLayout; impo
我有一个列表人员(在 jTable 中)并想将其导出到 excel 文件我需要每个人转到单独的工作表所以我需要拆分原始 jTable,但我不知道如何? 这就是我想做的? public void exp
我有一个包含 7 列和 2 行的 JTable。在我的 JTable 下方,我有一个 JTextField。当我在 JTextField 中输入内容时,我可以很容易地得到我输入的内容:String l
我正在尝试将一个 JTable 嵌套在另一个 JTable 的列中(使用 CellRenderer)。 示例(错误)输出: 为什么下面的例子没有输出表中表? import java.awt.Compo
我是一名优秀的程序员,十分优秀!