sql >> Databasteknik >  >> RDS >> Mysql

Inaktivera viss rad i JTable med data från databasen

Försök med åsidosatt prepareRenderer() metod för att gråa ut raden baserat på data

Exempelkod:(använd första kolumns värde för att validera)

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

För knappar kontrollera för värde och gör ingenting.

Hur får man fram värdet på den valda raden?

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. uppdateringsuppsättning från inre anslutningsfråga gav fel

  2. Python MySQLdb iterera genom tabellen

  3. Hur man använder en ringdatastruktur i fönsterfunktioner

  4. Hur lägger man till inledande nolla i ett nummer i Oracle SQL-fråga?