Ajuda com busca no banco de dados

5 respostas
java
Gabriel_Gomes2

Boa noite, estou tentando fazer buscas no meu banco de dados atraves de uma interface, mas nao está dando certo, aparece o seguinte erro:

Exception in thread AWT-EventQueue-0 java.lang.NullPointerException

at interfaces.PainelPesquisarProduto.actionPerformed(PainelPesquisarProduto.java:112)

at javax.swing.AbstractButton.fireActionPerformed(AbstractButton.java:2022)

at javax.swing.AbstractButton$Handler.actionPerformed(AbstractButton.java:2348)

at javax.swing.DefaultButtonModel.fireActionPerformed(DefaultButtonModel.java:402)

at javax.swing.DefaultButtonModel.setPressed(DefaultButtonModel.java:259)

at javax.swing.plaf.basic.BasicButtonListener.mouseReleased(BasicButtonListener.java:252)

at java.awt.Component.processMouseEvent(Component.java:6539)

at javax.swing.JComponent.processMouseEvent(JComponent.java:3324)

at java.awt.Component.processEvent(Component.java:6304)

at java.awt.Container.processEvent(Container.java:2239)

at java.awt.Component.dispatchEventImpl(Component.java:4889)

at java.awt.Container.dispatchEventImpl(Container.java:2297)

at java.awt.Component.dispatchEvent(Component.java:4711)

at java.awt.LightweightDispatcher.retargetMouseEvent(Container.java:4904)

at java.awt.LightweightDispatcher.processMouseEvent(Container.java:4535)

at java.awt.LightweightDispatcher.dispatchEvent(Container.java:4476)

at java.awt.Container.dispatchEventImpl(Container.java:2283)

at java.awt.Window.dispatchEventImpl(Window.java:2746)

at java.awt.Component.dispatchEvent(Component.java:4711)

at java.awt.EventQueue.dispatchEventImpl(EventQueue.java:760)

at java.awt.EventQueue.access$500(EventQueue.java:97)

at java.awt.EventQueue$3.run(EventQueue.java:709)

at java.awt.EventQueue$3.run(EventQueue.java:703)

at java.security.AccessController.doPrivileged(Native Method)

at java.security.ProtectionDomain$JavaSecurityAccessImpl.doIntersectionPrivilege(ProtectionDomain.java:74)

at java.security.ProtectionDomain$JavaSecurityAccessImpl.doIntersectionPrivilege(ProtectionDomain.java:84)

at java.awt.EventQueue$4.run(EventQueue.java:733)

at java.awt.EventQueue$4.run(EventQueue.java:731)

at java.security.AccessController.doPrivileged(Native Method)

at java.security.ProtectionDomain$JavaSecurityAccessImpl.doIntersectionPrivilege(ProtectionDomain.java:74)

at java.awt.EventQueue.dispatchEvent(EventQueue.java:730)

at java.awt.EventDispatchThread.pumpOneEventForFilters(EventDispatchThread.java:205)

at java.awt.EventDispatchThread.pumpEventsForFilter(EventDispatchThread.java:116)

at java.awt.EventDispatchThread.pumpEventsForHierarchy(EventDispatchThread.java:105)

at java.awt.EventDispatchThread.pumpEvents(EventDispatchThread.java:101)

at java.awt.EventDispatchThread.pumpEvents(EventDispatchThread.java:93)

at java.awt.EventDispatchThread.run(EventDispatchThread.java:82)

O codigo da classe ProdutosDAO:

public ArrayList<Produtos> pesquisar(String nomeProduto){
	this.conexao = new ConnectionFactory().getConnection();
	String sql = "Select * from produtos where nomeProd like  ?";
	ArrayList<Produtos> listaProdutos = new ArrayList<>();

	try {
		PreparedStatement ps = conexao.prepareStatement(sql);
		ps.setString(1,nomeProduto+"%");
		ResultSet rs = ps.executeQuery();

		while(rs.next()) {
			Produtos produtos = new Produtos();

			produtos.setIdProduto(rs.getInt("idd"));
			produtos.setNomeProduto(rs.getString("nomee"));
			produtos.setPrecoProduto(rs.getString("preco"));
			produtos.setDescricaoProduto(rs.getString("descricao"));
			
			listaProdutos.add(produtos);
		}
	
		rs.close();
		ps.close();
		
		this.conexao.close();
		
		return listaProdutos;
	}
	catch (Exception e) {
		// TODO: handle exception
		return null;
	}
}

O codigo da interface:

if (e.getSource().equals(btnProcurar)) {
		ProdutosDAO pesquisar = new ProdutosDAO();
		ArrayList<Produtos> listaProdutos;

        listaProdutos = pesquisar.pesquisar(txtNomee.getText());
		
		int i = 1;
		
		for(Produtos produtos : listaProdutos){
			tabela.setValueAt(produtos.getIdProduto(), i, 0);
			tabela.setValueAt(produtos.getNomeProduto(), i, 1);
			tabela.setValueAt(produtos.getPrecoProduto(),i ,2);
			i++;
			
		}
}

Se alguém puder me ajudar, ficarei extremamente grato.

5 Respostas

rodriguesabner

Tem alguma coisa cadastrada no seu banco?

Gabriel_Gomes2

tem sim

rodriguesabner

o que tem nessa linha?

Gabriel_Gomes2

for(Produtos produtos : listaProdutos)

rodriguesabner

Lista vazia… Mostra o método pesquisar do ProdutosDAO

Criado 2 de novembro de 2019
Ultima resposta 3 de nov. de 2019
Respostas 5
Participantes 2