能够完成提取数据库中表的数据显现到含有表格的窗体上,也能够将在表格中修正的内容写入数据库表中。
我完成以上功用时用了两个类,个中一个类是MyFrame,别的一个类是PutinStorage。
细致代码以下(以下代码均为完全代码,经测试胜利的):
PutinStorage类:
import java.sql.Connection; import java.sql.DriverManager; import java.sql.PreparedStatement; import java.sql.ResultSet; import java.sql.ResultSetMetaData; import java.sql.SQLException; import java.util.Vector; import javax.swing.JOptionPane; public class PutinStorage { // 获得数据库表数据 public static Vector getRows(){ String sql_url = "jdbc:mysql://localhost:3306/haha"; //数据库途径(平常都是如许写),test是数据库称号 String name = "root"; //用户名 String password = "123456"; //暗码 Connection conn; PreparedStatement preparedStatement = null; Vector rows = null; Vector columnHeads = null; try { Class.forName("com.mysql.jdbc.Driver"); //衔接驱动 conn = DriverManager.getConnection(sql_url, name, password); //衔接数据库 // if(!conn.isClosed()) // System.out.println("胜利衔接数据库"); preparedStatement = conn.prepareStatement("select * from aa"); ResultSet result1 = preparedStatement.executeQuery(); if(result1.wasNull()) JOptionPane.showMessageDialog(null, "效果集合无纪录"); rows = new Vector(); ResultSetMetaData rsmd = result1.getMetaData(); while(result1.next()){ rows.addElement(getNextRow(result1,rsmd)); } } catch (ClassNotFoundException e) { // TODO Auto-generated catch block System.out.println("未胜利加载驱动。"); e.printStackTrace(); } catch (SQLException e) { // TODO Auto-generated catch block System.out.println("未胜利翻开数据库。"); e.printStackTrace(); } return rows; } // 获得数据库表头 public static Vector getHead(){ String sql_url = "jdbc:mysql://localhost:3306/haha"; //数据库途径(平常都是如许写),test是数据库称号 String name = "root"; //用户名 String password = "123456"; //暗码 Connection conn; PreparedStatement preparedStatement = null; Vector columnHeads = null; try { Class.forName("com.mysql.jdbc.Driver"); //衔接驱动 conn = DriverManager.getConnection(sql_url, name, password); //衔接数据库 // if(!conn.isClosed()) // System.out.println("胜利衔接数据库"); preparedStatement = conn.prepareStatement("select * from aa"); ResultSet result1 = preparedStatement.executeQuery(); boolean moreRecords = result1.next(); if(!moreRecords) JOptionPane.showMessageDialog(null, "效果集合无纪录"); columnHeads = new Vector(); ResultSetMetaData rsmd = result1.getMetaData(); for(int i = 1; i <= rsmd.getColumnCount(); i++) columnHeads.addElement(rsmd.getColumnName(i)); } catch (ClassNotFoundException e) { // TODO Auto-generated catch block System.out.println("未胜利加载驱动。"); e.printStackTrace(); } catch (SQLException e) { // TODO Auto-generated catch block System.out.println("未胜利翻开数据库。"); e.printStackTrace(); } return columnHeads; } // 获得数据库中下一行数据 private static Vector getNextRow(ResultSet rs,ResultSetMetaData rsmd) throws SQLException{ Vector currentRow = new Vector(); for(int i = 1; i <= rsmd.getColumnCount(); i++){ currentRow.addElement(rs.getString(i)); } return currentRow; } /*//主函数 public static void main(String[] args){ getRows(); }*/ }
MyFrame类:
import java.awt.BorderLayout; import java.awt.FlowLayout; import java.awt.event.ActionEvent; import java.awt.event.ActionListener; import java.sql.Connection; import java.sql.DriverManager; import java.sql.PreparedStatement; import java.sql.SQLException; import java.util.Vector; import javax.swing.JButton; import javax.swing.JFrame; import javax.swing.JPanel; import javax.swing.JScrollPane; import javax.swing.JTable; import javax.swing.table.DefaultTableModel; import per.tushu.storage.PutinStorage; public class MyFrame extends JFrame{ DefaultTableModel tableModel; // 默许显现的表格 JButton add,del,exit,save; // 各处置惩罚按钮 JTable table; // 表格 JPanel panelUP; //增添信息的面板 // 组织函数 public MyFrame(){ this.setBounds(300, 200, 600, 450); // 设置窗体大小 this.setTitle("测试"); // 设置窗体称号 this.setLayout(new BorderLayout()); // 设置窗体的规划体式格局 // 新建各按钮组件 add = new JButton("增添"); del = new JButton("删除"); save = new JButton("保留"); exit = new JButton("退出"); panelUP = new JPanel(); // 新建按钮组件面板 panelUP.setLayout(new FlowLayout(FlowLayout.LEFT)); // 设置面板的规划体式格局 // 将各按钮组件顺次添加到面板中 panelUP.add(add); panelUP.add(del); panelUP.add(save); panelUP.add(exit); // 获得haha数据库的aa表的各行数据 Vector rowData = PutinStorage.getRows(); // 获得haha数据库的aa表的表头数据 Vector columnNames = PutinStorage.getHead(); // 新建表格 tableModel = new DefaultTableModel(rowData,columnNames); table = new JTable(tableModel); JScrollPane s = new JScrollPane(table); // 将面板和表格离别添加到窗体中 this.add(panelUP,BorderLayout.NORTH); this.add(s); // 事宜处置惩罚 MyEvent(); this.setVisible(true); // 显现窗体 this.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE); // 设置窗体可封闭 } // 事宜处置惩罚 public void MyEvent(){ // 增添 add.addActionListener(new ActionListener(){ @Override public void actionPerformed(ActionEvent arg0) { // 增添一行空缺地区 tableModel.addRow(new Vector()); } }); // 删除 del.addActionListener(new ActionListener(){ @Override public void actionPerformed(ActionEvent arg0) { // TODO Auto-generated method stub // 删除指定行 int rowcount = table.getSelectedRow(); if(rowcount >= 0){ tableModel.removeRow(rowcount); } } }); /** * 保留 * 我的解决办法是直接将aa表中的悉数数据删除, * 将表格中的一切内容获取到, * 然后将表格数据从新写入aa表 */ save.addActionListener(new ActionListener(){ @Override public void actionPerformed(ActionEvent e) { int column = table.getColumnCount(); // 表格列数 int row = table.getRowCount(); // 表格行数 // value数组寄存表格中的一切数据 String[][] value = new String[row][column]; for(int i = 0; i < row; i++){ for(int j = 0; j < column; j++){ value[i][j] = table.getValueAt(i, j).toString(); } } // 以下均为对数据库的操纵 String sql_url = "jdbc:mysql://localhost:3306/haha"; //数据库途径(平常都是如许写),haha是数据库称号 String name = "root"; //用户名 String password = "123456"; //暗码 Connection conn; PreparedStatement preparedStatement = null; try { Class.forName("com.mysql.jdbc.Driver"); //衔接驱动 conn = DriverManager.getConnection(sql_url, name, password); //衔接数据库 if(!conn.isClosed()) System.out.println("胜利衔接数据库"); // 删除aa表中一切数据 preparedStatement = conn.prepareStatement("delete from aa where true"); preparedStatement.executeUpdate(); // 将value数组中的数据顺次寄存到aa表中 for(int i = 0; i < row; i++){ preparedStatement = conn.prepareStatement("insert into aa values(" + Integer.parseInt(value[i][0]) + ",'" + value[i][1] + "')"); preparedStatement.executeUpdate(); } } catch (ClassNotFoundException e1) { // TODO Auto-generated catch block System.out.println("未胜利加载驱动。"); e1.printStackTrace(); } catch (SQLException e1) { // TODO Auto-generated catch block System.out.println("未胜利翻开数据库。"); e1.printStackTrace(); } // 保留后退出 System.exit(0); } }); // 退出 exit.addActionListener(new ActionListener(){ @Override public void actionPerformed(ActionEvent e) { // TODO Auto-generated method stub System.exit(0); } }); } // 主函数 public static void main(String[] args){ new MyFrame(); } }
实行以上代码的时刻,最初显现的窗体以下所示:
点击增添按钮并写入须要增添的内容(我增添了三次)以下图:
点击删除按钮,删除指定行(我删除了第2行和第4行),以下图:
点击保留按钮,会发明窗口也封闭了。这是你能够再从新实行代码,会发明涌现的表格页面与上图一样。
点击退出按钮,封闭窗口。
以上就是java怎样显现mysql的细致内容,更多请关注ki4网别的相干文章!