java 如何实现点击一个查询成绩按钮后将数据库里相对应的内容显示在JTable里面

java 如何实现点击一个查询成绩按钮后将数据库里相对应的内容显示在JTable里面,第1张

使用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 通过检索搜索出某行的其中一个数据 将该行置顶并改变颜色 连数据库多列数据咋办等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/sjk/10182933.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-05-06
下一篇2023-05-06

发表评论

登录后才能评论

评论列表(0条)

    保存