List duplica dados duvida ?

30 respostas
M

boa noite coloquei um first pra ver se puxava o primeiro da lista em diante , mas ai ele puxa uma linha a menos.
ele puxa a quantidade de linhas certas do banco mas todas com o mesmo resultado

joguei um println pra ver se estava correndo certo , e pela saida ai vcs podem ver que esta certo , se precisar printo a classe get set ok .

oque vcs acham ?

30 Respostas

F

Já verificou o construtor da sua classe Serviço? quando a execução cair no while, coloque um breakpoint dentro do construtor, debugue por linha, e verifique se a lista “listaservico” esta sendo populada corretamente a cada interação do while, se a lista estiver populada corretamente, verifique o metódo que alimenta o jasper.

S

debuga linha a linha e posta o código pra nós, ao invés de printar.Dai dá pra ver melhor e ver todo o código.

M

é a lista que esta recebendo errado mas, revirei aqui e nao entendi porque ela recebe os valores errados.
no while se passa certinho os valores , mas a lista é preenchida errada

try {

String subrelatorio = "select * from servicos where COD_VENDA ='"+CODVEND.getText()+"'" ;
       con.ExecutaSQL(subrelatorio);

while (con.resultset.next()) {

listaservico.add(new servico(con.resultset.getString(servico), con.resultset.getString(quantida), con.resultset.getString(valor)));

/*       System.out.println(con.resultset.getString(“servico”));

System.out.println(con.resultset.getString(“quantida”));

System.out.println(con.resultset.getString(“valor”));*/

}

} catch (SQLException ex) {

Logger.getLogger(servico.class.getName()).log(Level.SEVERE, null, ex);

}

sera que fiz algo errado no contrutor da classe servico ?

package programa;

public class servico {

static private String servico ;

static private String quantidade ;

static private String valor ;
public servico( String servico , String quantidade , String valor){

this.servico = servico;

this.quantidade = quantidade ;

this.valor = valor ;

}
public String getServico() {
    return servico;
}

public void setServico(String servico) {
    this.servico = servico;
}

public String getQuantidade() {
    return quantidade;
}

public void setQuantidade(String quantidade) {
    this.quantidade = quantidade;
}


public String getValor() {
    return valor;
}

public void setValor(String valor) {
    this.valor = valor;
}

}

ja revieirei aqui mas nao entendo , a quantidade de valores que tem que aparecer vem normal mas todos com o ultimo valor da listaaa , é como se estivese sobreescrendo , mas por estar com o new nao era pra estar neh ?

S

posso ver sua classe de conexão com o Banco, bem como seu ExecutaSQL(),

tem alguma coisa errada ai.

M

opa

so vc pra salvar sandrao vo te mandar .

M

package programa;

import java.sql.Connection;

import java.sql.DriverManager;

import java.sql.ResultSet;

import java.sql.SQLException;

import java.sql.Statement;

import java.util.logging.Level;

import java.util.logging.Logger;

import javax.swing.JOptionPane;

/**
*

  • @author Mauro
    
    */
    
    public class conexao {
    
    private String driver = com.mysql.jdbc.Driver;
    
    private Connection conexao ;
    
    public Statement statement ;
    
    public ResultSet resultset ;
    
    public conexao(){
    
    }
    
    public boolean conectar (String url,String Usuario,String senha){
    
    try {
    
    Class.forName(driver);
    
    conexao = DriverManager.getConnection(“jdbc:mysql://localhost:3306/caixa?zeroDateTimeBehavior=convertToNull,root,evolution);
    
    return true;
    
    } catch (Exception e) {
    
    return false;
    
    }
    
    }
    
    public static Connection createConnection(){
    
    String url = jdbc:mysql://localhost:3306/caixa?zeroDateTimeBehavior=convertToNull; //Nome da base de dados
    
    String user = “root”; //nome do usuário do MySQL
    
    String password = “evolution”; //senha do MySQL
    
    Connection conexao = null;
    
    return conexao;
    

    }

    public boolean desconectar() {
     try {
         conexao.close();
         return true ;
     } catch (Exception e) {
         return false ;
     }
     }
    

    public boolean ExecutaSQL(String sql){

    try {
         statement = conexao.createStatement();
         resultset = statement.executeQuery(sql);
       
         return true ;
     } catch (Exception ex) {
         System.out.println(ex.getMessage());
         return false ;
     }
    

    }

    /<em>TESTE METODO UPDATE PARA INSERT UPDATE E DELETE</em>/
    
    public boolean Executaupdate(String up){
    
    try {
    
    statement = conexao.createStatement();
    
    statement.executeUpdate(up);
    
    return true ;
     } catch (Exception ex) {
         System.out.println(ex.getMessage());
         return false ;
     }
    

    }

    /<em>TESTE METODO UPDATE PARA INSERT UPDATE E DELETE</em>/
    
    String resultset(String nome_carro) {
    
    throw new UnsupportedOperationException(“Not supported yet.”); //To change body of generated methods, choose Tools | Templates.
    
    }
    

    }

pode pedir oque precisar cara to procurando o erro aqui tambem mas ta complicado , vlew sandro .

S

passa a classe onde está o método resultset.

M

pra pegar o resultset eu sempre estancio a classe conexao e pego o resultset de dentro do metodo ExecutaSQL

public boolean ExecutaSQL(String sql){

    try {
        statement = conexao.createStatement();
        resultset = statement.executeQuery(sql);
      
        return true ;
    } catch (Exception ex) {
        System.out.println(ex.getMessage());
        return false ;
    }

}

conexao con = new conexao();
con.resultset

sera que é por isso ?

S

é está bem confuso.

ainda estou tentando entender

M

se quiser que eu faça outra classe de de conexao aqui eu faço , mas usei ela puxando o resultset assim no programa inteiro ate agora nao deu problema .

S

não é necessário, só que é melhor usar o ResultSet local, pra ficar mais claro também.
tenta fazer assim

try {

            String subrelatorio = "select * from servicos where COD_VENDA ='"+CODVEND.getText()+"'" ;
       con.ExecutaSQL(subrelatorio);

ResultSet rs = con.resultset;

    while (rs.next()) {

listaservico.add(new servico(con.resultset.getString("servico"), con.resultset.getString("quantida"), con.resultset.getString("valor")));
/* System.out.println(con.resultset.getString("servico"));
System.out.println(con.resultset.getString("quantida"));
System.out.println(con.resultset.getString("valor"));*/
} 
} catch (SQLException ex) {
Logger.getLogger(servico.class.getName()).log(Level.SEVERE, null, ex);
}

testa e vê os resultados

outra coisa você já debugou o código?

debugando você sabem em que momento exato não está adicionando o primeiro objeto na lista.

M

VOU TESTAR AQUIII

M

é veio repetido ainda , nunca debuguei codigo , vou dar uma olahda como faz no youtube, e volto a te falar aqui oque deu vlew

S

se der um System.out.println(); na lista ela imprime normal?

faz o seguinte DEPOIS de popular a listaservico você cria um for que percorre a lista e imprime os resultados. assim

for (int i = 0; i < listaservico.size(); i++) {
        System.out.println(listaservico.get(i).getServico());
        System.out.println( listaservico.get(i).getQuantidade());
        System.out.println( listaservico.get(i).getValor());
    }

caso sim então o problema pode ser no seu Relatório.

M

eu fiz os valores imprimem repetidos tambem vou te mandar um print

M

primeiro executo o formulario depois clico no botao exibir lista pra pegar oque foi carregado blz , e sai repetido é na lista que esta gravando errado neh só pode , mas o porque sera ? kkk , o laço while passa um de cada vez certinho que nem vc ja viu

ow é algo aqui
listaservico.add(new servico(con.resultset.getString(“servico”), con.resultset.getString(“quantida”), con.resultset.getString(“valor”)));

ow algo na classe serviço neh ?

revirando aqui …

M

vou fazer do jeito que vc me pediu pra vc ver tambem .

S

e nesse ponto aqui, sai repetido?

while (con.resultset.next()) {
    listaservico.add(new servico(con.resultset.getString("servico"), con.resultset.getString("quantida"), con.resultset.getString("valor")));
    /* System.out.println(con.resultset.getString("servico"));
    System.out.println(con.resultset.getString("quantida"));
    System.out.println(con.resultset.getString("valor"));*/
    }

ative as linhas do println e veja o resultado.

M

nesse ponto ai nao sai repetido sai normal

M

executo pra chamar o formulario o laço whilhe com o con.result set traz normal vc viu

em seguida coloquei para exibiri a lista e os valores aparecem repetidos .

S

tente quebrar criando o objeto depois inserindo na lista;

while (rs.next()) {
servico sv = new servico(con.resultset.getString("servico"), con.resultset.getString("quantida"), con.resultset.getString("valor"));
listaservico.add(sv);
/* System.out.println(con.resultset.getString("servico"));
System.out.println(con.resultset.getString("quantida"));
System.out.println(con.resultset.getString("valor"));*/
} 
} catch (SQLException ex) {
Logger.getLogger(servico.class.getName()).log(Level.SEVERE, null, ex);
}
M

cara eu tinha tentando de fazer desse jeito, mas tentei de novo do jeito que vc me passou , e veio repetido , mas por vir repetido de novo adicionando de outro jeito, não é pra ser a lista neh .
pode ser que seja a classe servico sera ? a unica coisa que pode ser , mas essa classe nao tem segredo neh.

se pego um venda que so tem um produto vem normal
se pega mais de um eles vem repetidos
o while do resultset ta normal a lista tambem pelo que vimos esta certo o valor so passa pela classe servico neh ?

eu coloquei this pra ver e tambem , continuou na mesma.

package programa;

public class servico {

static private String servico ;

static private String quantidade ;

static private String valor ;

public servico (){
}

public servico( String servico , String quantidade , String valor){

this.servico = servico;

this.quantidade = quantidade ;

this.valor = valor ;

}
public String getServico() {
    return servico;
}

public void setServico(String servico) {
    this.servico = servico;
}

public String getQuantidade() {
    return quantidade;
}

public void setQuantidade(String quantidade) {
    this.quantidade = quantidade;
}


public String getValor() {
    return valor;
}

public void setValor(String valor) {
    this.valor = valor;
}

}

M

estou pesquisando aqui se tiver alguma ideia a hora que estiver de boa so deixar msg aqui muito obrigado mesmo sandrão vlew pelaa ajuda ate agora .

S

acho dificil ser na classe, muito provavelmente algo na lista

pode passar o trecho do código onde você está imprimindo a lista duplicada, e onde envia para o relatório?

M

package programa;

import java.sql.ResultSet;

import java.sql.SQLException;

import java.util.ArrayList;

import static java.util.Collections.list;

import java.util.HashMap;

import java.util.List;

import java.util.logging.Level;

import java.util.logging.Logger;

import javax.swing.JOptionPane;

import net.sf.jasperreports.engine.JRException;

import net.sf.jasperreports.engine.JRResultSetDataSource;

import net.sf.jasperreports.engine.JasperFillManager;

import net.sf.jasperreports.engine.JasperPrint;

import net.sf.jasperreports.view.JasperViewer;

public class Historico extends javax.swing.JFrame {

ArrayList<servico> listaservico = new ArrayList<servico>(); 

public Historico() {
    initComponents();
}

@SuppressWarnings("unchecked")
// <editor-fold defaultstate="collapsed" desc="Generated Code">                          
private void initComponents() {

    jPanel1 = new javax.swing.JPanel();
    jButton1 = new javax.swing.JButton();
    CODVEND = new javax.swing.JTextField();
    jLabel2 = new javax.swing.JLabel();
    jPanel2 = new javax.swing.JPanel();
    jButton2 = new javax.swing.JButton();
    jButton3 = new javax.swing.JButton();

    setDefaultCloseOperation(javax.swing.WindowConstants.DISPOSE_ON_CLOSE);
    setTitle("CONTROLE DE HISTORICOS ");

    jPanel1.setBorder(javax.swing.BorderFactory.createTitledBorder("HISTORICO POR CARRO"));

    jButton1.setIcon(new javax.swing.ImageIcon(getClass().getResource("/syscom/imagens/imprimir.JPG"))); // NOI18N
    jButton1.setText("BUSCAR HISTORICO POR VENDA");
    jButton1.addActionListener(new java.awt.event.ActionListener() {
        public void actionPerformed(java.awt.event.ActionEvent evt) {
            jButton1ActionPerformed(evt);
        }
    });

    CODVEND.setText("111");
    CODVEND.addActionListener(new java.awt.event.ActionListener() {
        public void actionPerformed(java.awt.event.ActionEvent evt) {
            CODVENDActionPerformed(evt);
        }
    });

    jLabel2.setText("Nº VENDA :");

    javax.swing.GroupLayout jPanel1Layout = new javax.swing.GroupLayout(jPanel1);
    jPanel1.setLayout(jPanel1Layout);
    jPanel1Layout.setHorizontalGroup(
        jPanel1Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
        .addGroup(jPanel1Layout.createSequentialGroup()
            .addGroup(jPanel1Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING, false)
                .addGroup(jPanel1Layout.createSequentialGroup()
                    .addComponent(jLabel2)
                    .addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
                    .addComponent(CODVEND))
                .addComponent(jButton1))
            .addContainerGap(javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE))
    );
    jPanel1Layout.setVerticalGroup(
        jPanel1Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
        .addGroup(jPanel1Layout.createSequentialGroup()
            .addGroup(jPanel1Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.BASELINE)
                .addComponent(jLabel2)
                .addComponent(CODVEND, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE))
            .addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
            .addComponent(jButton1)
            .addContainerGap())
    );

    javax.swing.GroupLayout jPanel2Layout = new javax.swing.GroupLayout(jPanel2);
    jPanel2.setLayout(jPanel2Layout);
    jPanel2Layout.setHorizontalGroup(
        jPanel2Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
        .addGap(0, 623, Short.MAX_VALUE)
    );
    jPanel2Layout.setVerticalGroup(
        jPanel2Layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
        .addGap(0, 100, Short.MAX_VALUE)
    );

    jButton2.setText("relatorio por venda 2   teste");
    jButton2.addActionListener(new java.awt.event.ActionListener() {
        public void actionPerformed(java.awt.event.ActionEvent evt) {
            jButton2ActionPerformed(evt);
        }
    });

    jButton3.setText("exibi lista");
    jButton3.addActionListener(new java.awt.event.ActionListener() {
        public void actionPerformed(java.awt.event.ActionEvent evt) {
            jButton3ActionPerformed(evt);
        }
    });

    javax.swing.GroupLayout layout = new javax.swing.GroupLayout(getContentPane());
    getContentPane().setLayout(layout);
    layout.setHorizontalGroup(
        layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
        .addGroup(layout.createSequentialGroup()
            .addGroup(layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
                .addGroup(layout.createSequentialGroup()
                    .addContainerGap()
                    .addGroup(layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
                        .addComponent(jPanel2, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)
                        .addGroup(layout.createSequentialGroup()
                            .addComponent(jPanel1, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE)
                            .addGap(0, 0, Short.MAX_VALUE))))
                .addGroup(layout.createSequentialGroup()
                    .addGap(230, 230, 230)
                    .addGroup(layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING, false)
                        .addComponent(jButton2, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE)
                        .addComponent(jButton3, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE))
                    .addGap(0, 0, Short.MAX_VALUE)))
            .addContainerGap())
    );
    layout.setVerticalGroup(
        layout.createParallelGroup(javax.swing.GroupLayout.Alignment.LEADING)
        .addGroup(layout.createSequentialGroup()
            .addContainerGap()
            .addComponent(jPanel1, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE)
            .addGap(94, 94, 94)
            .addComponent(jButton3)
            .addPreferredGap(javax.swing.LayoutStyle.ComponentPlacement.RELATED)
            .addComponent(jButton2)
            .addGap(18, 18, 18)
            .addComponent(jPanel2, javax.swing.GroupLayout.PREFERRED_SIZE, javax.swing.GroupLayout.DEFAULT_SIZE, javax.swing.GroupLayout.PREFERRED_SIZE)
            .addContainerGap(javax.swing.GroupLayout.DEFAULT_SIZE, Short.MAX_VALUE))
    );

    pack();
}// </editor-fold>                        

private void CODVENDActionPerformed(java.awt.event.ActionEvent evt) {                                        

}                                       

private void jButton1ActionPerformed(java.awt.event.ActionEvent evt) {                                         
   
 
  try {
       conexao con = new conexao();
       con.conectar("jdbc:mysql://localhost:3306/caixa?zeroDateTimeBehavior=convertToNull","root","evolution");
             
        String sql = "select * from vendas where COD_VENDA ='"+CODVEND.getText()+"'" ;
        con.ExecutaSQL(sql);
        JRResultSetDataSource relatresult = new JRResultSetDataSource(con.resultset);
try {

String subrelatorio = “select * from servicos where COD_VENDA =’”+CODVEND.getText()+"’" ;

con.ExecutaSQL(subrelatorio);

while (con.resultset.next()){

listaservico.add(new servico(con.resultset.getString(servico), con.resultset.getString(quantida), con.resultset.getString(valor)));

// servico sv = new servico(con.resultset.getString(“servico”), con.resultset.getString(“quantida”), con.resultset.getString(“valor”));

//  listaservico.add(sv);

/*    System.out.println(con.resultset.getString(“servico”));

System.out.println(con.resultset.getString(“quantida”));

System.out.println(con.resultset.getString(“valor”)); */

}

} catch (SQLException ex) {

Logger.getLogger(servico.class.getName()).log(Level.SEVERE, null, ex);

}
HashMap parametros = new HashMap();
        parametros.put("CODVEND",Integer.parseInt(CODVEND.getText()));       
        parametros.put("SUBREPORT_DIR", "src\\relatorios\\"); 
        parametros.put("REPORT_CONNECTION", con.createConnection());
        parametros.put("list", listaservico);
        JasperPrint jpPrint = JasperFillManager.fillReport("src\\relatorios\\relatoriovenda.jasper",parametros,relatresult);
        JasperViewer jv = new JasperViewer(jpPrint,false); 
        jv.setVisible(true);
       
    } catch (JRException e) {
        JOptionPane.showMessageDialog(rootPane, "erro ao chamar relatorio"+e);
  }

}                                        

private void jButton2ActionPerformed(java.awt.event.ActionEvent evt) {                                         
  
}                                        

private void jButton3ActionPerformed(java.awt.event.ActionEvent evt) {
for(servico x: listaservico){

System.out.println(x.getServico()+"\n"+x.getQuantidade()+"\n"+x.getValor());

}
}                                        

public static void main(String args[]) {
  
    java.awt.EventQueue.invokeLater(new Runnable() {
        public void run() {
            new Historico().setVisible(true);
        }
    });
}

// Variables declaration - do not modify                     
private javax.swing.JTextField CODVEND;
private javax.swing.JButton jButton1;
private javax.swing.JButton jButton2;
private javax.swing.JButton jButton3;
private javax.swing.JLabel jLabel2;
private javax.swing.JPanel jPanel1;
private javax.swing.JPanel jPanel2;
// End of variables declaration

}

M

SE quiser que te mande as duas partes especificas separadinhas eu te mando, ai mandei o codigo inteiro ai tem os dois a lista e enviando para o ireport ok

S

velho, não vi nada de errado, mas só quem tem o código mesmo pra verificar, o melhor jeito é debugando, assim vai te dizer certinho, já me salvou muitas vezes.

se quiser me mandar o projeto posso debugar aqui.

M

como faço pra te mandar ?

S

te mandei uma mensagem, verifica lá

M

blz

Criado 4 de setembro de 2016
Ultima resposta 8 de set. de 2016
Respostas 30
Participantes 3