elhacker.net cabecera Bienvenido(a), Visitante. Por favor Ingresar o Registrarse
¿Perdiste tu email de activación?.

 

 


Tema destacado: Tutorial básico de Quickjs


+  Foro de elhacker.net
|-+  Programación
| |-+  Desarrollo Web
| | |-+  Bases de Datos (Moderador: Carloswaldo)
| | | |-+  [Pregunta]: ¿Cómo hacer esta consulta 2?
0 Usuarios y 1 Visitante están viendo este tema.
Páginas: [1] Ir Abajo Respuesta Imprimir
Autor Tema: [Pregunta]: ¿Cómo hacer esta consulta 2?  (Leído 182 veces)
Leguim


Desconectado Desconectado

Mensajes: 651



Ver Perfil
[Pregunta]: ¿Cómo hacer esta consulta 2?
« en: 23 Abril 2021, 00:07 am »

Hola,

bueno la anterior consulta ya la hace correctamente ahora tengo problemas con esta otra que es muy similar. Para este caso ya no va a eliminar las tentativas de un usuario si este llego a 6 sino que las va a eliminar si son 1 o 5 tentativas pero las eliminará si la fecha (unix) de creación tiene una antiguedad de 12 horas o más. (pero solo se evalua la más reciente)

Es decir, como son los unix no son mas que numeros enteros lo que hago para evaluar la mas reciente y ver si tiene esa antiguedad de 12 horas es tomar dentro de todos los registros/tentativas del usuario el unix mas grande.

Es decir:
Código
  1. $query = $con->prepare('DELETE FROM attempts WHERE id_user IN (SELECT A.id_user, MAX(A.unix_date) FROM attempts A INNER JOIN users U ON A.id_user = U.id_user WHERE (:unix_grace_delete_attempts >= MAX(A.unix_date)) AND U.login_banned = 0 GROUP BY A.id_user HAVING COUNT(*) >= 1 AND COUNT(*) <= 5');
  2. $query->execute(array(':unix_grace_delete_attempts' => $unix_grace_delete_attempts));
  3.  

Siempre uso BETWEEN en vez de hacer COUNT(*) >= 1 AND COUNT(*) <= 5 pero mientras mas simple de entender la consulta mejor para todos.

En relación a sobre qué es $unix_grace_delete_attempts lo que le estoy haciendo es restarle a el unix actual unas 12 horas.

Código
  1. $unix_now = time();
  2. $unix_grace_delete_attempts = strtotime('-12 hours', $unix_now);
  3.  


« Última modificación: 23 Abril 2021, 00:10 am por Leguim » En línea

Páginas: [1] Ir Arriba Respuesta Imprimir 

Ir a:  

Mensajes similares
Asunto Iniciado por Respuestas Vistas Último mensaje
Cómo hacer esta consulta SQL
Bases de Datos
Aikanáro Anário 1 3,484 Último mensaje 17 Septiembre 2011, 01:56 am
por fran800m
Como hacer esta consulta??
Bases de Datos
[u]nsigned 5 9,321 Último mensaje 22 Diciembre 2011, 14:01 pm
por |Miguel|
¿Cómo hacer esta consulta? « 1 2 »
Bases de Datos
KateLibby 12 5,849 Último mensaje 14 Mayo 2012, 11:53 am
por KateLibby
Como hacer esta consulta mysql desde php?
Bases de Datos
dyhsoluciones 1 2,374 Último mensaje 14 Julio 2012, 04:02 am
por Yoghurt
[Pregunta]: ¿Cómo puedo hacer esta consulta?
Bases de Datos
Leguim 6 408 Último mensaje 22 Abril 2021, 05:24 am
por Leguim
WAP2 - Aviso Legal - Powered by SMF 1.1.21 | SMF © 2006-2008, Simple Machines