Como converter um List em um Int?

7 respostas
luiz_carlos80

Olá a todos, estou começando a programar em Java, e já estou desenvolvendo uma aplicação, gostaria de cumprimentar a todos do fórum e agradecer a todos aqueles que puderem me ajudar de alguma forma quando eu postar minhas dúvidas.

Estou precisando armazenar o retorno de um List, que retorna apenas um registro do banco de dados, em uma variável do tipo Int(inteira), melhor dizendo, converter essa List e armazenar na variável do tipo Int.

Como posso fazer isso ?

Desde já obrigado a todos.

7 Respostas

davidbuzatto

Como assim?
O que tem dentro da lista?

luiz_carlos80
davidbuzatto:
Como assim? O que tem dentro da lista?

Melhor dizendo, tenho um formulário para cadastrar fornecedor, o qual está na imagem anexa, com um botão Salvar.
No meu banco de dados, tenho 3 tabelas, uma chamada fornecedor, outra de estoque, e uma outra chamada estoque_fornecedor.

Estou querendo que só seja possível cadastrar um fornecedor caso o tipo de material que ele forneça selecionado no JCombobox esteja cadastrado na tabela de estoque. Estando cadastrado na tabela estoque, estou tentando pegar o código desse material e jogar no campo Codmaterial da tabela estoque_fornecedor, juntamente com o código do fornecedor já gerado nesse cadastro. Depois disso cadastrar o fornecedor na tabela fornecedor, mas essa última etapa já consigo.

Segue abaixo o meu código que fiz do método para buscar o tipo de material na tabela de estoque:

public List<fornecedor > buscatipomaterial(fornecedor sqle) throws SQLException{

      String sql = "select * from estoque where Tipomaterial like '%" + sqle + "%'";
      PreparedStatement stm = this.conexao.prepareStatement(sql);
      ResultSet rs = stm.executeQuery();
      List<fornecedor> listaTemp = new ArrayList<fornecedor>();
      while (rs.next())
       {
          fornecedor tpmt = new fornecedor();
          tpmt.setCodmaterial(rs.getInt("Codmaterial"));
          listaTemp.add(tpmt);
      }
       stm.close();
       conexao.close();
       return listaTemp;

  }

Repare que usei o setCodmaterial, que está numa outra classe do mesmo pacote que contém esse código.
Preciso pegar o getCodmaterial (que agora está como uma lista retornada do banco de dados) e converter ele para uma int para armazenar no banco de dados e não sei como fazer isso.

Se precisar de mais algum dado me fale.
Abraços.

fernandopaiva

bem…pelo que entendi vc quer converter uma string para int…pq o que o jcombo armazena e uma string…
sobre vc naum pode cadastrar se naum tiver na tabela, vc ja faz isso no seu select q preenche seu combo…
provavelmente o tipo de campo q vc esta querendo inserir na tabela e inteiro, bigint etc…
entaum para isso basta pegar o codigo q esta no seu jcombo q vc traz dessa tabela para inserir em outra

para isso converta com Integer.parseInt dando um getSelectedItem no seu jcombo q ja tem os codigos…
Integer.parseInt(combobox.getSelectedItem());

acho q e isso q entendi…agora converter uma lista em um inteiro fica meio estranho, acho q nem da pra fazer isso…
vc pode verificar o length dela…

qquer coisa posta ae.

luiz_carlos80

fernandopaiva:
bem…pelo que entendi vc quer converter uma string para int…pq o que o jcombo armazena e uma string…
sobre vc naum pode cadastrar se naum tiver na tabela, vc ja faz isso no seu select q preenche seu combo…
provavelmente o tipo de campo q vc esta querendo inserir na tabela e inteiro, bigint etc…
entaum para isso basta pegar o codigo q esta no seu jcombo q vc traz dessa tabela para inserir em outra

para isso converta com Integer.parseInt dando um getSelectedItem no seu jcombo q ja tem os codigos…
Integer.parseInt(combobox.getSelectedItem());

acho q e isso q entendi…agora converter uma lista em um inteiro fica meio estranho, acho q nem da pra fazer isso…
vc pode verificar o length dela…

qquer coisa posta ae.

Bom, teria como eu pegar apenas um item de uma lista e jogar em uma variável inteira?
Se eu conseguir fazer isso resolve boa parte da minha dificuldade.

fabiomedeirosf

Acho que já entendi… seu problema está com o combo.

Vc está com problemas ao listas os dados no combo, ou ao pegar o dado que o usuário selecionou no combo?

para pegar o valor selecionado, tem a propriedade: combo.getSelectItem(); ou algo similar.

Ele vai te retornar o objeto inteiro selecionado, para a String que quiser ou Integer…

Qualquer coisa, poste aí.

luiz_carlos80
fabiomedeirosf:
Acho que já entendi... seu problema está com o combo.

Vc está com problemas ao listas os dados no combo, ou ao pegar o dado que o usuário selecionou no combo?

para pegar o valor selecionado, tem a propriedade: combo.getSelectItem(); ou algo similar.

Ele vai te retornar o objeto inteiro selecionado, para a String que quiser ou Integer...

Qualquer coisa, poste aí.

Na verdade, meu problema agora é pegar apenas um item de um objeto do tipo List, para depois convertê-lo para inteiro e assim mandá-lo como argumento para um método que irá inserí-lo no banco de dados.

Segue abaixo meu código:

fornecedor novo; // fornecedor é uma classe que contém o getcodmaterial e o setcosmaterial
FornecedorDao dao; // no FornecedorDao tem o método getLista que irei colocar logo abaixo.

public void insereemestoque_fornecedor() throws SQLException{
        dao.getLista((String) cmbTipodematerial.getSelectedItem());


        //fornecedor = dao.getLista((String) cmbTipodematerial.getSelectedItem());
        for (int i = 0; i <listaE.size(); i++) {
           Codforn = (Integer.toString((listaE.get(i).getCodmaterial())));
        }

        Codforn2 = Integer.parseInt(Codforn); // talvez meu erro esteja aqui, mas não sei comop pegar apenas um item da lista para c
        Codmaterial = Integer.parseInt(tfCodmaterial.getText());
        dao.insereemestoque_fornecedor(novo);
    }

Abaixo o método getLista da classe FornecedorDao:

public void insereemestoque_fornecedor(fornecedor novo) throws SQLException {


        String sql = "insert into estoque_fornecedor (Codforn,Codmaterial) values" +
              "(?,?)";
        PreparedStatement stm = conexao.prepareStatement(sql);

        stm.setInt(1, novo.getCodigo());
        stm.setInt(2, novo.getCodmaterial());
      
        stm.execute();
        stm.close();
        conexao.close();
        JOptionPane.showMessageDialog(null, "Estoque_Fornecedor inserido com sucesso");

    }

:roll: :roll:

E agora o método cadastrarFornecedor, onde o novo do método insereemestoque_fornecedor() faz todos os setters:

public void cadastrarFornecedor() throws SQLException {
        //inicializando o c
        novo = new fornecedor();
        //ele pega os valores digitados nos tf e salva no banco
        novo.setRazaosocial(tfRazaosocial.getText());
        novo.setCnpj(tfCnpj.getText());
        novo.setNomeresponsavel(tfNomedoreponsavel.getText());
        novo.setEndereco(tfEndereco.getText());
        novo.setTelefone(tfTelefone.getText());
        novo.setFax(tfFax.getText());
        novo.setBairro(tfBairro.getText());
        novo.setCidade(tfCidade.getText());
        novo.setCep(tfCep.getText());
        novo.setEmailsite(tfEmailsite.getText());
        novo.setUf((String) cmbUf.getSelectedItem());
        novo.setDddtel(tfDddtel.getText());
        novo.setDddfax(tfDddfax.getText());
        novo.setTipodematerial((String) cmbTipodematerial.getSelectedItem());
        novo.setCodmaterial(Integer.parseInt(tfCodmaterial.getText()));
        //inicializando o dao
        dao = new FornecedorDao();
        dao.insereCadastro(novo);
    }
Ele está dando uma exceção, a qual eu coloquei no código abaixo:
14/11/2010 18:57:42 Fornecedor.forms.cad_Fornecedor btnSalvarActionPerformed
SEVERE: null
java.sql.SQLException: General error
        at sun.jdbc.odbc.JdbcOdbc.throwGenericSQLException(JdbcOdbc.java:7086)
        at sun.jdbc.odbc.JdbcOdbc.SQLAllocStmt(JdbcOdbc.java:173)
        at sun.jdbc.odbc.JdbcOdbcConnection.prepareStatement(JdbcOdbcConnection.java:465)
        at sun.jdbc.odbc.JdbcOdbcConnection.prepareStatement(JdbcOdbcConnection.java:443)
        at Fornecedor.dao.FornecedorDao.getLista(FornecedorDao.java:110)
        at Fornecedor.forms.cad_Fornecedor.insereemestoque_fornecedor(cad_Fornecedor.java:388)
        at Fornecedor.forms.cad_Fornecedor.btnSalvarActionPerformed(cad_Fornecedor.java:482)
        at Fornecedor.forms.cad_Fornecedor.access$100(cad_Fornecedor.java:31)
        at Fornecedor.forms.cad_Fornecedor$2.actionPerformed(cad_Fornecedor.java:302)
        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.AWTEventMulticaster.mouseReleased(AWTEventMulticaster.java:272)
        at java.awt.Component.processMouseEvent(Component.java:6263)
        at javax.swing.JComponent.processMouseEvent(JComponent.java:3267)
        at java.awt.Component.processEvent(Component.java:6028)
        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:4574)
        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:2475)
        at java.awt.Component.dispatchEvent(Component.java:4460)
        at java.awt.EventQueue.dispatchEvent(EventQueue.java:599)
        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)

Só preciso pegar um item da lista para armazenar no banco, se alguém puder por favor me dá um help.... :roll: :roll:

Abraços a todos.

N

Eu não sei se entendi mas pra que essa confusão toda? Eu achei que tudo que você tinha de fazer era:

int i = (Integer) ArrayList.get(posição do objeto da lista) para pegar o objeto da primeira posicao e converter para inteiro.

Se tiver muitos elementos misturados(inteiro, string, classes etc) e não for um intieor naquela posição, retorna um erro, daí você faz:

try(
int i = (Integer) ArrayList.get(posição do objeto da lista);}

catch(Exception e){

System.out.println(não é um inteiro aquele objeto da lista naquela posição);

}
Criado 14 de novembro de 2010
Ultima resposta 15 de nov. de 2010
Respostas 7
Participantes 5