Auxilio na Update

2 respostas
S

Preciso alterar o meu produto no banco de dados…
Produto tem nome e qtd.

esse eh o meu metodo no DAOProduto:

public class DAOProduto {

    private Produto produto;
    Connection con;
    
    public DAOProduto(){
        super();
        try{
            Class.forName("org.postgresql.Driver");
            con = DriverManager.getConnection("jdbc:postgresql://localhost:5432/almoxarifado","postgres","1234");
        } catch (ClassNotFoundException e){
            e.printStackTrace();
        }catch (SQLException e){
            e.printStackTrace();
        }
    }
    
    public DAOProduto(Produto produto){
        this.produto = produto;
        try{
            Class.forName("org.postgresql.Driver");
            con = DriverManager.getConnection("jdbc:postgresql://localhost:5432/almoxarifado","postgres","1234");
        } catch (ClassNotFoundException e){
            e.printStackTrace();
        }catch (SQLException e){
            e.printStackTrace();
        }
    }
    
    
    
    public boolean UpdateProduto(Produto produto){
        boolean retorno = false;
        
        String SQL = "UPDATE PRODUTO SET qtd = "+produto.getQtd()+" WHERE nome ="+produto.getNome()+"";
        try {
            PreparedStatement ps = con.prepareStatement(SQL);
            ps.setString(1, produto.getNome());
            ps.setInt(2, produto.getQtd());

            retorno = true;


        } catch (SQLException e) {
            // se houve algum erro, uma exceção é gerada para informar o erro
            e.printStackTrace(); //vejamos que erro foi gerado e quem o gerou
            retorno = false;
        } finally {


            try {
                con.close();
            } catch (SQLException onConClose) {
                //System.out.println("Houve erro no fechamento da conexão");
                onConClose.printStackTrace();
            }
        }
        return retorno;
    }

fica dando esse erro:

org.postgresql.util.PSQLException: O índice da coluna está fora do intervalo: 1, número de colunas: 0.
        at org.postgresql.core.v3.SimpleParameterList.bind(SimpleParameterList.java:52)
        at org.postgresql.core.v3.SimpleParameterList.setStringParameter(SimpleParameterList.java:117)
        at org.postgresql.jdbc2.AbstractJdbc2Statement.bindString(AbstractJdbc2Statement.java:2120)
        at org.postgresql.jdbc2.AbstractJdbc2Statement.setString(AbstractJdbc2Statement.java:1241)
        at org.postgresql.jdbc2.AbstractJdbc2Statement.setString(AbstractJdbc2Statement.java:1227)
        at DAO.DAOProduto.UpdateProduto(DAOProduto.java:51)
        at telas.ConsultaProduto.jButton2ActionPerformed(ConsultaProduto.java:315)
        at telas.ConsultaProduto.access$100(ConsultaProduto.java:20)
        at telas.ConsultaProduto$2.actionPerformed(ConsultaProduto.java:81)
        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:6038)
        at javax.swing.JComponent.processMouseEvent(JComponent.java:3260)
        at java.awt.Component.processEvent(Component.java:5803)
        at java.awt.Container.processEvent(Container.java:2058)
        at java.awt.Component.dispatchEventImpl(Component.java:4410)
        at java.awt.Container.dispatchEventImpl(Container.java:2116)
        at java.awt.Component.dispatchEvent(Component.java:4240)
        at java.awt.LightweightDispatcher.retargetMouseEvent(Container.java:4322)
        at java.awt.LightweightDispatcher.processMouseEvent(Container.java:3986)
        at java.awt.LightweightDispatcher.dispatchEvent(Container.java:3916)
        at java.awt.Container.dispatchEventImpl(Container.java:2102)
        at java.awt.Window.dispatchEventImpl(Window.java:2429)
        at java.awt.Component.dispatchEvent(Component.java:4240)
        at java.awt.EventQueue.dispatchEvent(EventQueue.java:599)
        at java.awt.EventDispatchThread.pumpOneEventForFilters(EventDispatchThread.java:273)
        at java.awt.EventDispatchThread.pumpEventsForFilter(EventDispatchThread.java:183)
        at java.awt.EventDispatchThread.pumpEventsForHierarchy(EventDispatchThread.java:173)
        at java.awt.EventDispatchThread.pumpEvents(EventDispatchThread.java:168)
        at java.awt.EventDispatchThread.pumpEvents(EventDispatchThread.java:160)
        at java.awt.EventDispatchThread.run(EventDispatchThread.java:121)

a linha 51 eh essa:

2 Respostas

H

O que acontece é que você está misturando uma Statement normal com uma PreparedStatement.

faça o seguinte, substitua seu código por este aqui:

String SQL = "UPDATE PRODUTO SET qtd = ? WHERE nome = ?";  
ps.setInt(1, produto.getQtd()); 
ps.setString(2, produto.getNome());

Em uma PreparedStatement tu não coloca os valores diretamente na query, tu tem que usar o curinga “?” e depois setar com o ps.setTipo().

F

sou iniciante nisso mais, ja tentou usar o hibernate?

Criado 10 de dezembro de 2009
Ultima resposta 11 de dez. de 2009
Respostas 2
Participantes 3