Gostaria de alterar um campo do banco de dados através de uma jtable.
Eu tenho uma TableModel, Dao.
Codigo Classe Dao Metodo Atualizar:
public void atualizar(Produto despesa) {
conectar();
String com = "UPDATE Produto SET " +
"despesa= '" + despesa.getDespesa() + "'," +
"estabelecimento= '" + despesa.getEstabelecimento() + "'," +
"datadadespesa='" + despesa.getDatadaDespesa() + "'," +
"valordadespesa='" + despesa.getValordaDespesa() + "'," +
"formadepagamento='" + despesa.getFormadePagamento() + "'," +
"datacheque='" + despesa.getDataCheque() + "' " +
"numerocheque='" + despesa.getNumeroCheque() + "' " +
"mes='" + despesa.getMes() + "' " +
" WHERE despesa = '" + despesa.getDespesa() + "'";
try {
comando.executeUpdate(com);
JOptionPane.showMessageDialog(null,"Operação realizada com sucesso!");
} catch (SQLException e){
e.printStackTrace();
} finally {
fechar();
}
}
Segue cpodigo que fiz para atualizar meu banco de dados:
private void btAlterarActionPerformed(java.awt.event.ActionEvent evt) {
if(evt.getSource()==btAlterar){
int row = tblBanco.getSelectedRow();
if (row != -1) {
despesa.setDespesa(tblBanco.getColumnName(0));
despesa.setEstabelecimento(tblBanco.getColumnName(1));
despesa.setDatadaDespesa(tblBanco.getColumnName(2));
despesa.setValordaDespesa(tblBanco.getColumnName(3));
despesa.setDataCheque(tblBanco.getColumnName(4));
despesa.setNumeroCheque(tblBanco.getColumnName(5));
despesa.setFormadePagamento(tblBanco.getColumnName(6));
daoProduto.atualizar(despesa);
} else {
// mostrar advertência?
}
PreencherTabela();
}
}
Mas deu erro:
ava.sql.SQLException: [Microsoft][Driver ODBC para Microsoft Access] Erro de sintaxe (operador faltando) na express?o de consulta ''Forma de Pagamento' numerocheque='Data do Cheque' mes='null''.
at sun.jdbc.odbc.JdbcOdbc.createSQLException(JdbcOdbc.java:6957)
at sun.jdbc.odbc.JdbcOdbc.standardError(JdbcOdbc.java:7114)
at sun.jdbc.odbc.JdbcOdbc.SQLExecDirect(JdbcOdbc.java:3110)
at sun.jdbc.odbc.JdbcOdbcStatement.execute(JdbcOdbcStatement.java:338)
at sun.jdbc.odbc.JdbcOdbcStatement.executeUpdate(JdbcOdbcStatement.java:288)
at dao.DaoProduto.atualizar(DaoProduto.java:73)
at Tela_Principal.btAlterarActionPerformed(Tela_Principal.java:483)
at Tela_Principal.access$1100(Tela_Principal.java:7)
at Tela_Principal$13.actionPerformed(Tela_Principal.java:191)
at javax.swing.AbstractButton.fireActionPerformed(AbstractButton.java:1995)
at javax.swing.AbstractButton$Handler.actionPerformed(AbstractButton.java:2318)
at javax.swing.DefaultButtonModel.fireActionPerformed(DefaultButtonModel.java:387)
at javax.swing.DefaultButtonModel.setPressed(DefaultButtonModel.java:242)
at javax.swing.plaf.basic.BasicButtonListener.mouseReleased(BasicButtonListener.java:236)
at java.awt.Component.processMouseEvent(Component.java:6267)
at javax.swing.JComponent.processMouseEvent(JComponent.java:3267)
at java.awt.Component.processEvent(Component.java:6032)
at java.awt.Container.processEvent(Container.java:2041)
at java.awt.Component.dispatchEventImpl(Component.java:4630)
at java.awt.Container.dispatchEventImpl(Container.java:2099)
at java.awt.Component.dispatchEvent(Component.java:4460)
at java.awt.LightweightDispatcher.retargetMouseEvent(Container.java:4577)
at java.awt.LightweightDispatcher.processMouseEvent(Container.java:4238)
at java.awt.LightweightDispatcher.dispatchEvent(Container.java:4168)
at java.awt.Container.dispatchEventImpl(Container.java:2085)
at java.awt.Window.dispatchEventImpl(Window.java:2478)
at java.awt.Component.dispatchEvent(Component.java:4460)
at java.awt.EventQueue.dispatchEvent(EventQueue.java:599)
Conexão Fechada
at java.awt.EventDispatchThread.pumpOneEventForFilters(EventDispatchThread.java:269)
at java.awt.EventDispatchThread.pumpEventsForFilter(EventDispatchThread.java:184)
at java.awt.EventDispatchThread.pumpEventsForHierarchy(EventDispatchThread.java:174)
at java.awt.EventDispatchThread.pumpEvents(EventDispatchThread.java:169)
at java.awt.EventDispatchThread.pumpEvents(EventDispatchThread.java:161)
at java.awt.EventDispatchThread.run(EventDispatchThread.java:122)
Conectado!