sql >> Database teknologi >  >> RDS >> Mysql

Deaktiver bestemt række i JTable ved hjælp af data fra databasen

Prøv med tilsidesat prepareRenderer() metode til at nedtone rækken baseret på data

Eksempelkode:(brug første kolonnes værdi til at validere)

Object[] columnNames = { "A", "B", "C", "D" };
Object[][] data = { 
        { "abc", new Double(850.503), 53, true },
        { "lmn", new Double(36.23254), 6, false }, 
        { "pqr", new Double(8.3), 7, false },
        { "xyz", new Double(246.0943), 23, true } };

JTable table = new JTable(data, columnNames) {
    @Override
    public java.awt.Component prepareRenderer(TableCellRenderer renderer, int row, int col) {
        java.awt.Component comp = super.prepareRenderer(renderer, row, col);
        Object value = getModel().getValueAt(row, 0);
        if (value.equals("lmn")) {
            comp.setBackground(Color.lightGray);
        }  else {
           comp.setBackground(Color.white);
        }
        return comp;
    }
};

For knapper, tjek for værdi og gør ingenting.

Hvordan får man værdien af ​​den valgte række?

if(table.getSelectedRow()!=-1){
    int rowIndex=table.getSelectedRow();
    Object value=table.getModel().getValueAt(rowIndex, 0);
    if(value.equals("lmn")){
        //do nothing
    }else{
        // perform desired operation
    }
}



  1. MySQL:Kopier tabel til en anden tabel med en ekstra kolonne

  2. MySql sammensat indeks

  3. Architecting for Security:En guide til MySQL

  4. CachedRowSet langsommere end ResultSet?