java - 使用 PreparedStatement 对 MySQL 中的记录进行排序

标签 java mysql swing sorting jdbc

我正在尝试编写一段代码,当用户单击“按名称排序”按钮时,我的程序将对我的数据库记录进行排序并将它们放入 JTable 中,将 2 个数据库表与 INNER JOIN 组合在一起。我设法通过使用结果集并选择例如升序来做到这一点。但是因为我不想有 2 个按钮,一个用于 ASC,一个用于 DESC,我想到了使用 preparedStatement 和一个 showInputDialog,用户可以在其中选择是要 ASC 还是 DESC 排序并执行该命令。另外,我记得我见过的一些程序使用了一个功能,当你第一次点击按钮时,它会按 DESC 排序,如果你再次按下它,就会按 ASC 排序(还没有在网上找到)。关于我的第一个我想,我试着去做,但我可以通过这个

ResultSetMetaData mdsort = rssort.getMetaData();

我应该有一个 ResultSet 变量 (rssort) 来使用 getMetaData(),但是如果我选择用我的 PreparedStatement 制作程序,我会在那里得到一个错误。有什么建议吗??

try{
    Connection conn = DriverManager.getConnection("jdbc:mysql://localhost/test1?user=me&password=12345");
    Statement stmtsort = conn.createStatement();
    ResultSet rssort = stmtsort.executeQuery("SELECT * FROM consoles INNER JOIN hardware ON consoles.id=hardware.id ORDER BY consoles.name ASC");
       // ERROR HERE!!! needs resultset,not preparedStatement
    ResultSetMetaData mdsort = rssort.getMetaData();
    columnCount = mdsort.getColumnCount();
    String[] colssort = new String[columnCount];
    for (i=1;i<= columnCount;i++)
       {
        colssort[i-1] = mdsort.getColumnName(i);
       }
   DefaultTableModel model = new DefaultTableModel(colssort,0);
    while (rssort.next())
       {
            Object[] rowsort = new Object[columnCount];
             for (i = 1 ; i <= columnCount ; i++)
             {
               rowsort[i-1] = rssort.getObject(i);
             }
        model.addRow(rowsort);
       }
      JTable table = new JTable(model);
      model.fireTableDataChanged();
      table.setCellSelectionEnabled(true);
      table.setColumnSelectionAllowed(true);
      table.setFillsViewportHeight(true);
      table.setSurrendersFocusOnKeystroke(true);
      table.setBounds(218,59,529,360);
      frame.getContentPane().add(table); 
      model.fireTableDataChanged();
      conn.close();
      stmtsort.close();
      rssort.close();
      } catch (SQLException case1)
                {case1.printStackTrace();
      } catch (Exception case2)
                {case2.printStackTrace();}
            }
        });

更新

好的,我设法用 getMetaData() 解决了这个问题,但现在的问题是我没有使用任何 ResultSet 变量/实例,也不能使用 next() 方法来创建我的数据库。

String name = "SELECT * FROM consoles INNER JOIN hardware ON consoles.id=hardware.id ORDER BY consoles.name ?";
PreparedStatement psname = conn.prepareStatement(name);
String strin =  JOptionPane.showInputDialog(null,"ASC or DESC order ? : ");
psname.setString(1,strin);
psname.executeUpdate();
ResultSetMetaData mdsort = psname.getMetaData();
int columnCount = mdsort.getColumnCount();
                     .
                     .
                     .
// error coming up here,because i deleted the ResultSet

 while (psname.next())
           .
           .
           .

最佳答案

最好制作更复杂的 TableModel。

那是更优的。

将 ResultSet 中的数据保存在原始 TableModel 中。 使用包装 TableModel 进行排序,也可能进行过滤。

使用 ResultSetMetaData 作为列类型,如果它是 Number(Integer、BigDecimal,...),则使用该类型而不是 Object 作为列类型:给出一个右对齐的列。

也许首先在互联网上搜索 ResultSetTableModel;其他人一定已经这样做了。

关于java - 使用 PreparedStatement 对 MySQL 中的记录进行排序,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25115733/

相关文章:

java - 如何在 Java 7 中使用默认访问修饰符访问构造函数

java - 随机(?)ElementNotVisibleException

mysql - 使用 VB.Net 连接到在线 MySQL 数据库

php - 在php中比较ip地址

java - java 和 R 与 Rserve 的连接

java - 如何在JavaFX中的两个AreaCharts之间填充?

PHP Mysql 从函数插入语句

java - BorderLayout.CENTER 和 BorderLayout.EAST 之间的 JSeparator?

java - 将 jtextfield 的值插入数据库,

Java - 有没有办法在 JList 中插入背景图像?