Warning: file_get_contents(/data/phpspider/zhask/data//catemap/8/mysql/55.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Java 使用PreparedStatement对MySQL中的记录进行排序_Java_Mysql_Swing_Sorting_Jdbc - Fatal编程技术网

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

Java 使用PreparedStatement对MySQL中的记录进行排序,java,mysql,swing,sorting,jdbc,Java,Mysql,Swing,Sorting,Jdbc,我试图编写一个代码,当用户点击“按名称排序”按钮时,我的程序将对数据库中的记录进行排序,并将它们放入一个JTable中,将2个DB表与内部联接组合在一起。我已经通过使用一个结果集并选择升序来实现这一点。但是因为我不想有两个按钮,一个用于ASC,一个用于DESC,所以我考虑使用preparedStatement和showInputDialog,用户可以在其中选择是否要进行ASC或DESC排序并执行订单。此外,我还记得我见过的一些程序使用了一个功能,第一次单击按钮时,它会对DESC进行排序,如果再按

我试图编写一个代码,当用户点击“按名称排序”按钮时,我的程序将对数据库中的记录进行排序,并将它们放入一个JTable中,将2个DB表与内部联接组合在一起。我已经通过使用一个结果集并选择升序来实现这一点。但是因为我不想有两个按钮,一个用于ASC,一个用于DESC,所以我考虑使用preparedStatement和showInputDialog,用户可以在其中选择是否要进行ASC或DESC排序并执行订单。此外,我还记得我见过的一些程序使用了一个功能,第一次单击按钮时,它会对DESC进行排序,如果再按一次,它会按ASC排序(在WEB上没有找到)。关于我的第一个想法,我试图这样做,但我可以通过这个

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();}
            }
        });

最好使表格模型更复杂一点

这更为理想

将结果集中的数据保留在原始TableModel中。 使用包装表格模型进行排序,也可以进行筛选

对列类型使用ResultSetMetaData,如果它是数字(整数、BigDecimal,…),则对列类型使用该类型而不是对象:给出右对齐的列

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

试试看{
    try{
       conn = DriverManager.getConnection("jdbc:mysql://localhost/test1?user=me&password=12345");
       String strin =  JOptionPane.showInputDialog(null,"ASC or DESC order ? : ");
       stmtsortname = conn.createStatement();
       rssortname = stmtsortname.executeQuery("SELECT * FROM consoles INNER JOIN hardware ON consoles.id=hardware.id ORDER BY consoles.name "+strin);
       mdsortname = rssortname.getMetaData();
       columnCount = mdsortname.getColumnCount();
       String[] colssortname = new String[columnCount];
       for (i=1;i<= columnCount;i++)
            {
                colssortname[i-1] = mdsortname.getColumnName(i);
            }
       model = new DefaultTableModel(colssortname,0);
        while (rssortname.next())
           {
            Object[] rowsortname = new Object[columnCount];
             for (i = 1 ; i <= columnCount ; i++)
             {
               rowsortname[i-1] = rssortname.getObject(i);
             }
            model.addRow(rowsortname);
          }
    table = new JTable(model);
    model.fireTableDataChanged();
    table.setCellSelectionEnabled(true);
    table.setColumnSelectionAllowed(true)  
    table.setFillsViewportHeight(true);
    table.setSurrendersFocusOnKeystroke(true);
    table.setBounds(146,59,763,360);
    frame.getContentPane().add(table); 
    model.fireTableDataChanged();
    conn.close();
    stmtsortname.close();
    rssortname.close();
   } catch (SQLException case1)
      {
        case1.printStackTrace();
      }
     catch (Exception case2)
      {
        case2.printStackTrace();
      }
}
});
conn=DriverManager.getConnection(“jdbc:mysql://localhost/test1?user=me&password=12345"); 字符串strin=JOptionPane.showInputDialog(null,“ASC或DESC订单:”); stmtsortname=conn.createStatement(); rssortname=stmtsortname.executeQuery(“从控制台内部选择*连接控制台上的硬件。id=hardware.id按控制台排序。名称”+strin); mdsortname=rssortname.getMetaData(); columnCount=mdsortname.getColumnCount(); String[]colssortname=新字符串[columnCount];
对于(i=1;i如果出现错误,请包括实际的堆栈跟踪。此外,您的代码中没有使用
PreparedStatement
。您对花括号有问题。不同的方法可能是读取已排序的ASC数据(如您目前所做的那样)如果用户要求以相反的顺序查看,只需在代码中对生成的模型进行排序,而不是返回数据库。但我同意Ajit-我们需要查看您得到的错误。在我的帖子中更新了它,以便您可以查看我的代码
psname.executeUpdate();
…您没有更新…您需要使用返回结果集的preparedstatement方法。
    try{
       conn = DriverManager.getConnection("jdbc:mysql://localhost/test1?user=me&password=12345");
       String strin =  JOptionPane.showInputDialog(null,"ASC or DESC order ? : ");
       stmtsortname = conn.createStatement();
       rssortname = stmtsortname.executeQuery("SELECT * FROM consoles INNER JOIN hardware ON consoles.id=hardware.id ORDER BY consoles.name "+strin);
       mdsortname = rssortname.getMetaData();
       columnCount = mdsortname.getColumnCount();
       String[] colssortname = new String[columnCount];
       for (i=1;i<= columnCount;i++)
            {
                colssortname[i-1] = mdsortname.getColumnName(i);
            }
       model = new DefaultTableModel(colssortname,0);
        while (rssortname.next())
           {
            Object[] rowsortname = new Object[columnCount];
             for (i = 1 ; i <= columnCount ; i++)
             {
               rowsortname[i-1] = rssortname.getObject(i);
             }
            model.addRow(rowsortname);
          }
    table = new JTable(model);
    model.fireTableDataChanged();
    table.setCellSelectionEnabled(true);
    table.setColumnSelectionAllowed(true)  
    table.setFillsViewportHeight(true);
    table.setSurrendersFocusOnKeystroke(true);
    table.setBounds(146,59,763,360);
    frame.getContentPane().add(table); 
    model.fireTableDataChanged();
    conn.close();
    stmtsortname.close();
    rssortname.close();
   } catch (SQLException case1)
      {
        case1.printStackTrace();
      }
     catch (Exception case2)
      {
        case2.printStackTrace();
      }
}
});