根据我的 UsersTableSeeder.php 类,我使用循环在我的数据库中植入虚假数据:
$numberOfUsers = 150;
DB::table('users')->delete();
$faker = Faker::create();
for ($i = 1; $i <= $numberOfUsers; $i++) {
DB::table('users')->insert([
'id' => $i,
'firstName' => $faker->firstName,
'lastName' => $faker->lastName,
'email' => $faker->email,
'password' => bcrypt("123"),
'created_at' => Carbon::now()->addDays((-5 * $i) - 2)->format('Y-m-d H:i:s'),
'updated_at' => Carbon::now()->addDays(-5 * $i)->format('Y-m-d H:i:s'),
]);
}
这里的问题是,当我生成日期时间值时,它有可能落在 DST 区域中,比如 2017-03-12 02:00:00 和 2017-03-12 02:59:59 之间(确实发生了)并且它给了我以下错误:
[PDOException]
SQLSTATE[22007]: Invalid datetime format: 1292 Incorrect datetime value: '2016-03-13 02:08:11' for column 'created_at' at row 1
现在我明白我不能将这样的值放入我的数据库中,因为我的数据库足够聪明,可以及时知道这个区域并没有完全退出。但是有什么办法可以让 Carbon 足够聪明以考虑 DST 吗?我不想用类似的东西手动检查它:
if ($my_date > 2017-03-12 02:00:00 && $my_date < 2017-03-12 02:59:59)
最佳答案
事实上 Carbon 可以处理 DST 区域。
$date = '2017-03-26 02:01:01';
$date = \Carbon\Carbon::parse($date, 'Europe/Berlin');
dd((string)$date);
结果在
// an extra hour was added automatically
"2017-03-26 03:01:01"
默认情况下,Laravel 对所有日期和日期时间操作(包括 Carbon)使用“UTC”。这个值可以在app/config.php中设置
如果您真的希望您的日期时间在数据库的“UTC”中被考虑,一个肮脏的解决方法可能是这样的:
编辑:
// calculate current offset to UTC:
$offset = \Carbon\Carbon::now('America/Montreal')->offsetHours;
'created_at' => Carbon::now('America/Montreal')->addHours(-4 + $i)->addDays((-1 * $i) - 2)->tz('UTC')->addHours($offset)->format('Y-m-d H:i:s')
关于php - Laravel Carbon 不考虑时区 DST,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43485258/
我在非Rails项目中使用ActiveRecord。在Rails中,我可以这样做:config.time_zone='EasternTime(US&Canada)'config.active_record.default_timezone='EasternTime(US&Canada)'但如果我不使用rails,我该如何设置时区? 最佳答案 ActiveRecord::Base.default_timezone='EasternTime(US&Canada)' 关于ruby-没有轨道的A
我有一个包含许多换行符和空格的字符串。我需要将它拆分成固定长度的子字符串。例如a="Thisissome\nText\nThisissometext"现在我想把它分成长度为17的字符串。所以现在它应该导致["Thisissome\nText","\nThisissometex","t"]评论:我的字符串可能包含任何字符(空格/单词等) 最佳答案 "Thisissome\nText\nThisissometext".scan(/.{1,17}/m)#=>["Thisissome\nText","\nThisissometex","t"
在我的场景中,Logstash收到的系统日志行的“时间戳”是UTC,我们在Elasticsearch输出中使用事件“时间戳”:output{elasticsearch{embedded=>falsehost=>localhostport=>9200protocol=>httpcluster=>'elasticsearch'index=>"syslog-%{+YYYY.MM.dd}"}}我的问题是,在UTC午夜,Logstash在外时区(GMT-4=>America/Montreal)结束前将日志发送到不同的索引,并且索引在20小时(晚上8点)之后没有日志,因为“时间戳”是UTC。我们已
按照目前的情况,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visitthehelpcenter指导。关闭9年前。我来自C、php和bash背景,很容易学习,因为它们都有相同的C结构,我可以将其与我已经知道的联系起来。然后2年前我学了Python并且学得很好,Python对我来说比Ruby更容易学。然后从去年开始,我一直在尝试学习Ruby,然后是Rails,我承认,直到现在我还是学不会,讽刺的是那些打着简单易学的烙印,但是对于我这样一个老练的程序员来说,我只是无法将它
我有一个时间对象T。向T添加N天的合理方法是什么?我想出的最好的感觉有点折磨:require'date'defadd_days(time,days)time.to_date.next_day(days).to_timeendP.S.:如果您在美国,正确答案必须满足:add_days(Time.new(2013,3,10,0),1)==Time.new(2013,3,11,0)如果您在欧盟,则正确答案必须满足:add_days(Time.new(2013,3,31,0),1)==Time.new(2013,4,1,0)P.P.S:这是一个Ruby问题,而不是Rails问题。
这是我的Controller:classMyController@list}format.json{render:json=>@list}endendendend...它所基于的助手:moduleMyHelperdefget_list_from_params(param=:id,&on_success)raw_id=params[param]beginid=Integer(raw_id)rescuerender:template=>"invalid_id",:locals=>{:id=>raw_id}elseyieldMyList.new(id)endendend...和我的功能测试(
这可能是一个愚蠢的问题,表明我对夏令时的基础知识缺乏了解,但根据标题,Time.dst?如何知道时间对象确实是真还是假?大概这必须通过日期和时区的组合来辨别,但这没有意义,因为时区中的低纬度不使用夏令时?因此肯定它必须需要位置来识别#dst??我错过了什么? 最佳答案 为了处理时区和夏令时,Ruby和其他所有东西一样,是callinglocaltime_rCfunction.这将时间放入名为tm的C结构中其中包括一个名为isdst的字段。Ruby正在读取该标志。localtime_r首先通过从全局tzname变量获取您的时区来计算i
我想将报告功能添加到我的rails应用程序中,而我现在正为使用哪种报告软件来创建pdf文档而苦苦挣扎。到目前为止,我确信Ruport或Prawn是最好的选择。在对它们进行了实验之后,我发现它们都非常强大,而且相当普遍,但它们也有明显的特点,我担心从长远来看,我可能会做出错误的选择。在一个大型复杂的应用程序中,ruport和prawn是如何进行长期比较的?可维护性?生成报告的代码会呈指数增长吗?代码会变得脆弱吗?可利用性?图书馆几年后还会积极维护吗?(ruportutil似乎有些过时…)可定制性?使用相同的代码库为不同的客户机生成不同的布局有多容易?最重要的是:在做出选择之前,我不知道还
使用mysql2做查询总是得到警告/usr/local/lib/ruby/gems/1.9.1/gems/mysql2-0.2.6/lib/active_record/connection_adapters/mysql2_adapter.rb:463:warning::database_timezoneoptionmustbe:utcor:local-defaultingto:local我确实看到了时区选项Mysql2现在支持两个时区选项::database_timezone-thisisthetimezoneMysql2willassumefieldsarealreadystored
按照目前的情况,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visitthehelpcenter指导。关闭10年前。我使用PHP的时间太长了,对它感到厌倦了。我也想学习一门新语言。我一直在使用Ruby并且喜欢它。我必须在Rails和Sinatra之间做出选择,那么您会推荐哪一个?Sinatra真的不能用来构建复杂的应用程序,它只能用于简单的应用程序吗?