我在努力弄清楚如何使用perl比较MySQL日期和当前系统时间。Perl与MySQL比较日期
我有一个cron作业,如果当前系统日期/时间为过去的日期返回的记录/时间会发送通知运行的脚本:
应用程序显示一个表视图:
EventId Device Location
CC: 123 something BFE
TT: 456 anotherthing BFE
脚本如何工作是它在字段EventID中查找值,从ID(数字部分)中解析类型(CC:,TT:等)。该ID是另一个数据库/表中包含结束时间字段的唯一ID。 EventID本身不是唯一的,并且可能在表中有重复的项目。因为每个类型都有不同的数据库和/或表,所以存在每个“类型”的子例程。
目标是脚本每分钟运行一次并切换Expired的值。有可能会有某些东西过期,需要做出改变并随后取消。
该脚本工作正常,除了1个问题,这似乎与时区有关,基于我迄今收到的反馈。如果我不隐式设置当前系统时间为'America/New_York'($now
)的时区,则会关闭几个小时($notz
)。因此我需要找到一种方法来使从MySQL返回的日期与当前系统时间进行准确比较。
$now->set_time_zone('America/New_York')
似乎也不工作。
我不确定如何做到这一点,甚至如果我有迄今的代码是最好的办法(仍然相当新的Perl):
#!/usr/bin/perl
use DBI;
use DateTime;
use DateTime::Format::MySQL;
use Switch;
my $now = DateTime->now(time_zone => 'America/New_York');
my $notz = DateTime->now();
my $maindb = DBI=>connect(database);
my $seteventsql = qq { select * from view where EventId like 'IE:' or EventId like 'TT:' or EventId like 'CC:';};
my $commit = $livedb->prepare($seteventsql);
$commit->execute() || die "could not set event: $DBI::errstr";
while(@events = $commit->fetchrow_array()) {
(my $type, my $id) = split (/ /,$events[0]);
$id =~ s|\D||g;
switch ($type) {
case ('CC:') {check_expired_case($id);}
case ('TT:') {check_expired_task($id);}
case ('IE:') {check_expired_event($id);}
}
}
sub check_expired_case {
my $id = shift; #id = 123
my $sql = qq { select id, status_id, item_enddate from item where id = ?; };
my $exec = $itemdb->prepare($sql);
$exec->execute($id);
while(my @row = $exec->fetchrow_array()) {
my $status = $row[1];
my $end = DateTime::Format::MySQL->parse_datetime($row[2]);
if ($now > $end || $status ne 3 || $status ne 6) {
$sql = qq { update item set Expired = 1 where EventId = '$eventid';};
$maindb->do($sql)
}else{
$sql = qq { update item set Expired = 0 where EventId = '$eventid';};
$maindb->do($sql)
}
}
$exec->finish();
}
NoTZ: 2010-09-10T01:27:19
Now: 2010-09-09T21:27:19
End: 2010-09-10T17:00:00
在此先感谢。我希望我已经很好地解释了这一点,它很难解释所有事情的关系。
所以要澄清,你的代码将在“做什么”的路径,而不是“做点别的? – Ether 2010-09-09 00:59:03
实际生产中的脚本我有设置一个值的1或0数据库的当前时间是否是之前或结束时间后 – Mose 2010-09-09 01:06:54
@mose:我想确认你的代码错误地说,2010-09-08T20:03:38> 2010-09-10T17:00:00 – Ether 2010-09-09 01:08:20