Amigo darkamerico, te comento lo que hace lo que puse en el SQL.
1) Mira que no se crucen los datos estando los valores ingresados fuera de los rangos existentes o sean iguales a los límites.
2) Mira que no se crucen los datos estando los valores ingresados dentro del rango existente.
3) Mira que el rango tenga el desde dentro del rango existente pero el hasta puede estar dentro o fuera
4) Lo mismo que el anterior pero alrevez, el desde puede estar fuera pero el hasta dentro.
Pongo ejemplo con tu caso
Inicio = 2 / Fin = 4
Ingresan:
Inicio = 1 / Fin = 5 --> Primera validacion de mi SQL
Inicio = 2 / Fin = 5 --> Segunda validacion de mi SQL
Inicio = 2 / Fin = 4 --> Tercera validacion de mi SQL
Inicio = 1 / Fin = 4 --> Cuarta Validacion de mi SQL
Con este ejemplo creo que te debería quedar mas claro porque todas esas validaciones. Creeme que fue analizado mucho de hacerlo asi por tema de performance y no hay otra forma de hacerlo.
mamcx, como haces en tu código para validar si solo el inicio esta dentro del rango y el fin esta fuera o viceversa?. Por lo que entendi no lo puede hacer, dime si me equivoco.
Saludos,
El Rayo
__________________
Si tienes una función o procedimiento con diez parámetros, probablemente hayas olvidado uno
|