Remove Mysql row after specified time

前端 未结 5 1707
忘了有多久
忘了有多久 2020-12-21 06:46

I\'m trying to create a computer reservation system, where user chooses a computer and select the time how long he will be using this PC. In that time other persons can\'t r

相关标签:
5条回答
  • 2020-12-21 07:00

    To be complete in the solution, you need to run a CRON job which calls a query to remove all reservations that have a reservation_time + (15 * 60) < unix_timestamp().

    I am assuming you have a time that the reservation was placed or started and are using UNIX/Epoch Timestamps.

    Instead of doing a expires_now, if you know it will always be a fixed interval ie 15 minutes, you can do:

    DELETE FROM reservations WHERE  reservation_time + (15 * 60) < unix_timestamp() 
    

    Something you could look into is managing cron job's from PHP, http://www.highonphp.com/cron-job-manager.

    The above script will, when a reservation is created, insert an entry into /etc/cron.d/ and you could configure it to run at the expected reservation endtime. Then inside the php file which would be executed, you could do:

    DELETE FROM reservations WHERE id = :id
    
    0 讨论(0)
  • 2020-12-21 07:01

    The common way to handle this is to store an expires_at timestamp on the reservation row. Then your query to find any "open" reservations would have WHERE 'expires_at' < NOW() or something similar.

    0 讨论(0)
  • 2020-12-21 07:02

    This is an untested answer, that may only be a suggestion, but I just started looking at these, so am interested in feedback as well. i'm still working through possibilities and drawbacks, but it might well suit your need.

    Take a look at MySQL Events, an article about it is here, and official syntax at Mysql Docs.
    Per the article:

    An event is similar to a trigger. However, rather than running in response to a data change, events can be scheduled to run any number of times during a specific period. In effect, it’s a database-only cron job.

    Pondering this, I'd envision a procedure that deleted anything >1hr (if that's the expiration). This procedure would be TRIGGERED on new inserts to get rid of anything expired at that moment, but also in an event to run every 15 minutes or so so that automatic deletes by the trigger aren't dependant on somebody else adding a reservation to trigger that procedure.

    0 讨论(0)
  • 2020-12-21 07:11

    Normally I would do it this way:

    • when storing a reservation, store date_from and date_to both of datatype DATETIME
    • when checking if there is a computer free check for all computers and filter with WHERE '{$my_date}' >= date_to AND '{$my_date}' <= date_from - by this You should be able to get all the PCs that are not reserved within a certain time...
    0 讨论(0)
  • 2020-12-21 07:21

    If your server is linux, you can use cron jobs to check once a day every reservation dates. If these dates have expired .. modified field reserves to be available.

    0 讨论(0)
提交回复
热议问题