Estoy usando .NET 2. Tengo mi archivo .XSD (Data Layer) y mi Business Logic.
El caso es que en el .XSD estoy poniendo esta consulta:
SELECT * from tabla where nombre LIKE ?
Yo quería encontrar cualquier campo que contuviera el string solicitado, es decir, si alguien buscaba “pa”, la sentencia debía regresar valores como “paco”, “palabra”, “pais”, etc. Pero con el LIKE
solamente regresaba el valor si la coincidencia era exacta.
Otros intentos que hice fueron:
SELECT * from tabla where nombre LIKE '%?%'
SELECT * from tabla where nombre LIKE %?%
SELECT * from tabla where nombre LIKE %?%
Ninguno sirve porque al parecer al definir la sentencia SQL en el archivo .XSD, el signo de interrogación no puede tener ningún comodín.
Entonces busqué alguna función que pudiera ayudarme, y al final lo logré. La sentencia debe quedar así:
SELECT * from tabla where (INSTR(nombre,?) > 0)
INSTR(str,substr)
devuelve la posición de la primera ocurrencia de substring
en la cadena de texto str
.
Así que si devuelve un número mayor a cero, significa que lo encontró.
Ahora bien, siendo más estrictos, lo que yo quería era que encontrara el principio de la palabra. Es decir, si alguien buscaba por “yo” debería encontrar “yolanda”, pero no “pelayo”. Entonces necesitaba algo que le indicara que buscara solamente al principio del campo.
Así es como lo logré:
SELECT * from tabla where nombre REGEXP CONCAT('^',?)
expr REGEXP pat
realiza una búsqueda de expresiones regulares en la cadena expr
usando el modelo pat
.
CONCAT(cad1, cad2, ...)
une cadenas de texto.
Es decir que al ejecutarse:SELECT * from tabla where nombre REGEXP CONCAT('^','yo')
Se convierte en:SELECT * from tabla where nombre REGEXP '^yo'
Como sabes, el símbolo ^
en expresiones regulares, significa el inicio de una palabra.
El signo ‘?’ es por si estás utilizando MySQL.
Si utilizas SQL Server, cambia el ‘?’ por ‘@Nombre’ o cualquiera que sea el nombre de tu parámetro.
Para mayor información:
http://dev.mysql.com/doc/refman/5.0/en/string-functions.html