1. java
  2. android
  3. c#
  4. .net
  5. javascript
  6. php
  7. jquery
  8. html
  9. sql

Erro com Select no FireBird

Tenho a seguinte função:

public List pesquisaPorNome(String marca) {
        try {
            List marcas = new ArrayList<MarcaMOD>();
            ps = conexao.prepareStatement("SELECT * FROM marca WHERE nome LIKE '%'?'%'");
            ps.setString(1, marca);

            ResultSet rs = ps.executeQuery();

            while (rs.next()) {
                MarcaMOD marcaItem = new MarcaMOD();
                marcaItem.setId(rs.getInt("id"));
                marcaItem.setNome(rs.getString("nome"));
                marcas.add(marcaItem);
            }
            return marcas;
        } catch (SQLException erro) {
            throw new RuntimeException(erro.getMessage());
        } finally {
            dispose();
        }
    }

Dá erro nesta linha::

ps = conexao.prepareStatement("SELECT * FROM marca WHERE nome LIKE '%'?'%'");

Olhem o erro:

Exception in thread "AWT-EventQueue-0" java.lang.RuntimeException: GDS Exception. 335544569. Dynamic SQL Error
SQL error code = -104
Token unknown - line 1, column 40
?
    at dao.MarcaDAO.pesquisaPorNome(MarcaDAO.java:138)
    at view.FormMarcaPesquisa.tfPesquisaKeyReleased(FormMarcaPesquisa.java:128)
    at view.FormMarcaPesquisa.access$100(FormMarcaPesquisa.java:7)
    at view.FormMarcaPesquisa$2.keyReleased(FormMarcaPesquisa.java:63)
    at java.awt.Component.processKeyEvent(Component.java:6486)
    at javax.swing.JComponent.processKeyEvent(JComponent.java:2830)
    at java.awt.Component.processEvent(Component.java:6302)
    at java.awt.Container.processEvent(Container.java:2234)...continua

Já verifiquei nome de banco, nome da tabela e nome dos campos, ta tudo ok...

  1. Você vai ver essas setas em qualquer página de pergunta. Com elas, você pode dizer se uma pergunta ou uma resposta foram relevantes ou não.
  2. Edite sua pergunta ou resposta caso queira alterar ou adicionar detalhes.
  3. Caso haja alguma dúvida sobre a pergunta, adicione um comentário. O espaço de respostas deve ser utilizado apenas para responder a pergunta.
  4. Se o autor da pergunta marcar uma resposta como solucionada, esta marca aparecerá.
  5. Clique aqui para mais detalhes sobre o funcionamento do GUJ!

1 resposta

Não é a resposta que estava procurando? Procure outras perguntas com as tags java ou faça a sua própria pergunta.