
使用lablesettext("str");将查询出来的数据放进jllabe。
1,给查询按钮一个监听事件,点击触发。
2,连接数据库进行查询 *** 作,返回rs结果集。
3,获取rs结果集中的数据,例如获取表中字段为name的数据:string
name
=
rsgetstring("name")。
4,将数据插入到jlable。name_lablesettext(name);
5,刷新界面显示数据。framesetvisible(true);
1,点击data source,显示d出框,选择schemas勾选要在idea中展示的表如test_liu,点击ok就完成了,我们就可以在idea界面看到素有的mysql表了
最终解决方法:
1安装navicat,连接异常的数据库,检查用户的权限是否正常。
检查后,发现root账号的权限已经全部未设置。
2修改root权限。
调整完后,修改root密码,去掉上面添加的“skip-grant-tables”参数。
3重启数据库服务。
重启之后,一切正常。
不是很明白你的要求。具体的 *** 作是怎样的的呢?
假设数据库中有个学生表:
001 张三 20
002 李四 21
假设按姓名搜索,输入搜索条件“张”:
情况1、根据搜索条件直接搜索数据库记录(通常都是这样搜索),那从数据库搜索出的记录就只有姓名包含“张”的记录,然后JTable中也就只展示这些记录,就无所谓置顶不置顶啦。
情况2、只是根据搜索条件在当前JTable展示的数据中搜索,代码如下:
import javaawtBorderLayout;import javaawtGridLayout;
import javaawteventActionEvent;
import javaawteventActionListener;
import javaxswingJButton;
import javaxswingJFrame;
import javaxswingJLabel;
import javaxswingJPanel;
import javaxswingJScrollPane;
import javaxswingJTable;
import javaxswingJTextField;
import javaxswingborderEmptyBorder;
import javaxswingeventTableModelEvent;
import javaxswingeventTableModelListener;
public class JTableTest extends JFrame {
private JPanel searchPanel;
private JTextField numField;
private JButton searchByNumButton;
private JTextField nameField;
private JButton searchByNameButton;
private JTable table;
private TestTableModel tableModel;
public JTableTest() {
super("Simple JTable Test");
setSize(400, 300);
setDefaultCloseOperation(DISPOSE_ON_CLOSE);
searchPanel = new JPanel();
searchPanelsetBorder(new EmptyBorder(3, 3, 3, 3));
searchPanelsetLayout(new GridLayout(2, 3, 2, 3));
searchPaneladd(new JLabel("学号"));
numField = new JTextField(20);
searchPaneladd(numField);
searchByNumButton = new JButton("按学号搜索");
searchByNumButtonaddActionListener(new ActionListener() {
public void actionPerformed(ActionEvent event) {
tablegetSelectionModel()clearSelection();
tableModeldoSearchByNum(numFieldgetText());
}
});
searchPaneladd(searchByNumButton);
searchPaneladd(new JLabel("姓名"));
nameField = new JTextField(20);
searchPaneladd(nameField);
searchByNameButton = new JButton("按姓名搜索");
searchByNameButtonaddActionListener(new ActionListener() {
public void actionPerformed(ActionEvent event) {
tablegetSelectionModel()clearSelection();
tableModeldoSearchByName(nameFieldgetText());
}
});
searchPaneladd(searchByNameButton);
getContentPane()add(searchPanel, BorderLayoutNORTH);
tableModel = new TestTableModel();
tableModeladdTableModelListener(new TableModelListener() {
@Override
public void tableChanged(TableModelEvent e) {
if (tableModelgetHitRowCount() > 0) {
tablesetRowSelectionInterval(0, tableModelgetHitRowCount() - 1);
}
}
});
table = new JTable(tableModel);
JScrollPane jsp = new JScrollPane(table);
getContentPane()add(jsp, BorderLayoutCENTER);
}
public static void main(String[] args) {
JTableTest self = new JTableTest();
selfsetVisible(true);
}
}import javautilArrayList;
import javautilArrays;
import javautilList;
import javaxswingtableAbstractTableModel;
public class TestTableModel extends AbstractTableModel {
private List<Student> data = ArraysasList(new Student("001", "王二", 20), new Student("002",
"王二小", 19), new Student("003", "张三", 20), new Student("004", "张三丰", 21), new Student("005",
"李四", 21), new Student("006", "李四光", 19));
private List<Integer> searchHitRows = new ArrayList<Integer>();
@Override
public int getRowCount() {
return datasize();
}
@Override
public int getColumnCount() {
return 3;
}
@Override
public String getColumnName(int column) {
if (column == 0)
return "学号";
else if (column == 1)
return "姓名";
return "年龄";
}
@Override
public Object getValueAt(int rowIndex, int columnIndex) {
Student student = dataget(rowIndex);
if (columnIndex == 0)
return studentgetNum();
else if (columnIndex == 1)
return studentgetName();
return studentgetAge();
}
/ 按姓名搜索 /
public void doSearchByName(String key) {
searchHitRowsclear();
if (key == null || ""equals(key))
return;
for (int i = 0; i < datasize(); i++) {
Student studentI = dataget(i);
String value = studentIgetName();
if (valueindexOf(key) < 0)
continue;
int j = 0;
for (j = i - 1; j >= 0; j--) {
Student studentJ = dataget(j);
String valueJ = studentJgetName();
if (valueJindexOf(key) >= 0)
break;
}
Student temp = dataget(j + 1);
dataset(j + 1, studentI);
dataset(i, temp);
searchHitRowsadd(IntegervalueOf(j + 1));
}
fireTableDataChanged();
}
/ 按学号搜索 /
public void doSearchByNum(String key) {
searchHitRowsclear();
if (key == null || ""equals(key))
return;
for (int i = 0; i < datasize(); i++) {
Student studentI = dataget(i);
String value = studentIgetNum();
if (valueindexOf(key) < 0)
continue;
int j = 0;
for (j = i - 1; j >= 0; j--) {
Student studentJ = dataget(j);
String valueJ = studentJgetNum();
if (valueJindexOf(key) >= 0)
break;
}
Student temp = dataget(j + 1);
dataset(j + 1, studentI);
dataset(i, temp);
searchHitRowsadd(IntegervalueOf(j + 1));
}
fireTableDataChanged();
}
public void setData(List<Student> data) {
if (data == null)
throw new IllegalArgumentException("参数data不能为null。");
thisdata = data;
fireTableDataChanged();
}
public int getHitRowCount() {
return searchHitRowssize();
}
}
从数据库查询出记录后,转成Student对象列表调用TestTableModel的setData设置表格的数据。
过程如下:
1、建立按钮的事件响应方法,调用以下代码功能:
2、通过JDBC或其它方式连接数据库,执行查询,获取结果
3、将返回结果转换为一个二维数组,作为参数创建JTable
当然要功能更完善,以上方法有很多方面需要考虑和修改,如进行模块划分、使用TableModel而不是数组显示JTable、表头的显示等,这些需要根据目的逐个改进,但大体过程基本一样。
以上就是关于java 如何实现点击一个查询成绩按钮后将数据库里相对应的内容显示在JTable里面全部的内容,包括:java 如何实现点击一个查询成绩按钮后将数据库里相对应的内容显示在JTable里面、jtable链接数据库数据显示不全、java中JTable 通过检索搜索出某行的其中一个数据 将该行置顶并改变颜色 连数据库多列数据咋办等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)