[quote=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í.[/quote]
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:
[code]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);
}[/code]
Abaixo o método getLista da classe FornecedorDao:
[code]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");
}[/code]
: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.