Erro ao tentar consultar usando like

Olá amigos,

estou com um erro ao tentar fazer uma consulta ao BD usando o seguinte código:

package br.com.cobra; 

import java.sql.Connection; 
import java.sql.PreparedStatement; 
import java.sql.ResultSet; 
import java.sql.SQLException; 

public class TiraAspas { 
    
   private static String localidade; 
   private static String localidadeAux; 
   private static String aspa = "'"; 
   private static final String seleciona = "select distinct localidae FROM prefixos where localidae like '"+aspa+"'"; 
   //private static final String atualiza = "update prefixos set localidae='"+localidade+"' where localidae like '"+aspa+"'"; 
    
   public static void atualizaBanco(){ 
       
      Conexao conexao = new Conexao(); 
      Connection con = null; 
      try { 
         con = conexao.retornaConexao(); 
         if(con!=null){ 
             
            PreparedStatement ps = con.prepareStatement(seleciona); 
            ResultSet rs = ps.executeQuery(); 
             
            while(rs.next()){ 
               localidade = rs.getString("localidae"); 
               //localidadeAux = tiraAspas(localidade); 
               //ps.executeUpdate(atualiza); 
               System.out.println(localidade); 
            } 
             
         }else{ 
            System.out.println("Ocorreu um erro ao instanciar o bd!"); 
         } 
      } catch (SQLException e) { 
         e.printStackTrace(); 
      } 
       
   } 
    
   /*public static String tiraAspas(String aux){ 
      char aspa = aux.charAt(39); 
      char branco = aux.charAt(32); 
      aux.replace(aspa,branco); 
      return aux; 
   }*/ 
    
   public static void main (String[] args){ 
      atualizaBanco(); 
   } 

} 

O erro ocorre ao tentar consultar a aspa, pois quero todos os registros que contenham aspa, tentei fazer essa consulta em VB e também ocorre o mesmo erro.

Grato.

Afinal… qual é o erro?

bem like deve seguir este padrão:

deve ser este o erro.

:okok:

Amigo, eu estou querendo fazer uma consulta de todos os registros que contenham aspa simples (’).
PS: EU SEI COMO SE USA O CAMANDO LIKE, DETALHE, ESTOU USANDO O BANCO DE DADOS ACCESS!!!

Que eu saiba é pq vc está tentando fazer a pesquisa por aspas(’), e aspas no sql é reservado para caracteres, o que vc pode fazer pra solucionar esse problema é troque:

Por:

E em:

[code]try {
con = conexao.retornaConexao();
if(con!=null){

        PreparedStatement ps = con.prepareStatement(seleciona);
        //ADICIONAR
        ps.setString(1,aspas);
        ResultSet rs = ps.executeQuery();
         
        while(rs.next()){
           localidade = rs.getString("localidae");
           //localidadeAux = tiraAspas(localidade);
           //ps.executeUpdate(atualiza);
           System.out.println(localidade);
        } [/code]

Acho q é isso.[/code]

Só mais um detalhe, substitua:

por:

Acho q agora vai:)

Valeu Vagner, funcionou certinho, eu tava testando tanta coisa que até esqueci de passar em % mas blz, brigadão pelo help :grin:

Um abraço.