JAVA-将mysql结果放入表中
我是Java新手,我正在尝试用表视图创建一个窗口。在此窗口中,我要删除、更新和插入数据等 最后看起来是这样的: 我从来没有这样做之前,任何人的提示或链接到良好的教程。我不是要你为我做编码,而是要学习如何创建一个动态表,在执行一个操作后可以重新加载该表。我找不到这方面的好教程。我的Java书也没有给出很好的例子 在PHP中我可以在5分钟内完成,但在JAVA中我不知道!不管怎样,我会用我所掌握的知识来找出如何做到这一点 我现在有以下Java代码:JAVA-将mysql结果放入表中,java,mysql,Java,Mysql,我是Java新手,我正在尝试用表视图创建一个窗口。在此窗口中,我要删除、更新和插入数据等 最后看起来是这样的: 我从来没有这样做之前,任何人的提示或链接到良好的教程。我不是要你为我做编码,而是要学习如何创建一个动态表,在执行一个操作后可以重新加载该表。我找不到这方面的好教程。我的Java书也没有给出很好的例子 在PHP中我可以在5分钟内完成,但在JAVA中我不知道!不管怎样,我会用我所掌握的知识来找出如何做到这一点 我现在有以下Java代码: import javax.swing.JFrame
import javax.swing.JFrame;
import javax.swing.JPanel;
import javax.swing.JScrollPane;
import javax.swing.JTable;
import java.awt.Dimension;
import java.awt.GridLayout;
import java.awt.event.MouseAdapter;
import java.awt.event.MouseEvent;
import java.sql.ResultSet;
import java.sql.SQLException;
public class test extends JPanel {
private boolean DEBUG = false;
public test() {
super(new GridLayout(1,0));
Database db = new Database();
String tabel = "testtabel";
ResultSet res = db.query("SELECT COUNT( * ) FROM `"+tabel+"`");
ResultSet res2 = db.query("SELECT COUNT( * ) FROM INFORMATION_SCHEMA.COLUMNS WHERE table_name = '"+tabel+"'");
int rows = 0;
int collums = 0;
try {
res.next();
res2.next();
rows = res.getInt(1);
collums = res2.getInt(1);
} catch (SQLException e1) {
// TODO Auto-generated catch block
e1.printStackTrace();
}
ResultSet clom = db.query("DESCRIBE `"+tabel+"`");
String[] columnNames = new String[collums];
int s = 0;
try {
while(clom.next()){
columnNames[s] = clom.getString(1);
s++;
}
} catch (SQLException e2) {
// TODO Auto-generated catch block
e2.printStackTrace();
}
Object[][] data = new Object[rows][collums];
ResultSet result = db.query("SELECT * FROM `"+tabel+"`");
int q = 0;
try {
while(result.next()){
for(int a=0; a<= (collums - 1); a++){
data[q][a] = result.getString(a + 1);
System.out.println(q + " - " + a);
}
q++;
}
} catch (SQLException e1) {
// TODO Auto-generated catch block
e1.printStackTrace();
}
final JTable table = new JTable(data, columnNames);
table.setPreferredScrollableViewportSize(new Dimension(500, 70));
table.setFillsViewportHeight(true);
if (DEBUG) {
table.addMouseListener(new MouseAdapter() {
public void mouseClicked(MouseEvent e) {
printDebugData(table);
}
});
}
//Create the scroll pane and add the table to it.
JScrollPane scrollPane = new JScrollPane(table);
//Add the scroll pane to this panel.
add(scrollPane);
}
private void printDebugData(JTable table) {
int numRows = table.getRowCount();
int numCols = table.getColumnCount();
javax.swing.table.TableModel model = table.getModel();
System.out.println("Value of data: ");
for (int i=0; i < numRows; i++) {
System.out.print(" row " + i + ":");
for (int j=0; j < numCols; j++) {
System.out.print(" " + model.getValueAt(i, j));
}
System.out.println();
}
System.out.println("--------------------------");
}
/**
* Create the GUI and show it. For thread safety,
* this method should be invoked from the
* event-dispatching thread.
*/
private static void createAndShowGUI() {
//Create and set up the window.
JFrame frame = new JFrame("SimpleTableDemo");
frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
//Create and set up the content pane.
test newContentPane = new test();
newContentPane.setOpaque(true); //content panes must be opaque
frame.setContentPane(newContentPane);
//Display the window.
frame.pack();
frame.setVisible(true);
}
public static void main(String[] args) {
//Schedule a job for the event-dispatching thread:
//creating and showing this application's GUI.
javax.swing.SwingUtilities.invokeLater(new Runnable() {
public void run() {
createAndShowGUI();
}
});
}
}
import javax.swing.JFrame;
导入javax.swing.JPanel;
导入javax.swing.JScrollPane;
导入javax.swing.JTable;
导入java.awt.Dimension;
导入java.awt.GridLayout;
导入java.awt.event.MouseAdapter;
导入java.awt.event.MouseEvent;
导入java.sql.ResultSet;
导入java.sql.SQLException;
公共类测试扩展了JPanel{
私有布尔调试=false;
公开考试(){
超级(新网格布局(1,0));
数据库db=新数据库();
字符串tabel=“testtabel”;
ResultSet res=db.query(“从`+tabel+“`”中选择计数(*);
ResultSet res2=db.query(“从信息_SCHEMA.COLUMNS中选择COUNT(*),其中table_name='“+tabel+”);
int行=0;
int=0;
试一试{
res.next();
res2.next();
行=res.getInt(1);
collums=res2.getInt(1);
}捕获(SQLException e1){
//TODO自动生成的捕捉块
e1.printStackTrace();
}
ResultSet clom=db.query(“descripe`+tabel+”);
String[]columnNames=新字符串[collums];
int s=0;
试一试{
while(clom.next()){
columnNames[s]=clom.getString(1);
s++;
}
}捕获(SQLException e2){
//TODO自动生成的捕捉块
e2.printStackTrace();
}
对象[][]数据=新对象[行][m];
ResultSet result=db.query(“从`+tabel+`中选择*”);
int q=0;
试一试{
while(result.next()){
for(int a=0;a很高兴您正在尝试学习一门新语言。Oracle文档页面非常有用。此链接应该对您正在尝试的工作非常有帮助,祝您好运
您指的是web表还是显示数据的Java Swing表?不是窗口内的表(JFrame)是的,我刚刚发现我需要声明数组中有多少个第一和第二个元素。如下所示:Object[][]data=new Object[2][6];
然后我可以向表中添加两行。但是在PHP中,我可以创建一个数组,然后添加我想要的任何内容。比如$array=array()$array[0][=“something”
。这让我很困惑!但是我将学习Java对于二维数组,只需要初始化列的数量。Object[][]data=new Object[2][];