Если вы используете PHP 5.2 или high, используйте DateTime, как указано выше. Эта статья поможет.
Исходя из ваших данных выше, я думаю, вы просто, ниже приведен пример кода для вашей проблемы выше
, в вашем контроллере вы можете присоединять условия, это также нетерпеливо загружает ваш запрос, поэтому ваша база данных просто вызывается только один раз [ 115]
ниже приведен пример для вашего контроллера
@header_groups = Group.joins(categories: :exams).
where("groups.published = ? AND exams = ?",true,true).
order("slug")
, и ваше представление будет отображать только на основе @header_groups, чтобы сдавать экзамены, вы можете использовать @header_examps = group.exams (помните, что вы также упоминали в своей модели Отношения, которые группа проходит по множеству экзаменов по категориям)
<% @header_groups.each do |group| %>
<li class="nav-item dropdown">
<a class="nav-link dropdown-toggle" href="#" id="dropdown-3" role="button" data-toggle="dropdown" aria-haspopup="true" aria-expanded="false">
<%= group.name %><span class="caret"></span>
</a>
<div class="dropdown-menu" aria-labelledby="dropdown-3">
<% @header_examps = group.exams %>
<% @header_exams.each do |exam| %>
<a class="dropdown-item" href="/<%= exam.group.slug %>/<%= exam.slug %>/">
<%= exam.name %>
</a>
<!--TODO: use <a class="active"> to denote the current page and possibly category-->
<% end %>
<div class="dropdown-divider"></div>
<a class="dropdown-item" href="/<%= group.slug %>/">
All <%= group.name %>
</a>
</div>
</li>
<% end %>
Обновление с оригинального плаката с окончательным рабочим кодом:
То, что в итоге сработало для меня, было небольшим вариантом этот ответ (Ответ, как написано выше, повторяет весь групповой цикл для каждого экзамена, а не только для каждой группы.)
Контроллер:
@header_groups_v3 = Group.where(published: TRUE).
order("slug")
Просмотр:
<% @header_groups_v3.each do |group| %>
<li class="nav-item dropdown">
<a class="nav-link dropdown-toggle" href="#" id="dropdown-3" role="button" data-toggle="dropdown" aria-haspopup="true" aria-expanded="false">
<%= group.name %><span class="caret"></span>
</a>
<div class="dropdown-menu" aria-labelledby="dropdown-3">
<% @header_examps = group.exams %>
<% @header_examps.each do |exam| %>
<a class="dropdown-item" href="/<%= exam.group.slug %>/<%= exam.slug %>/">
<%= exam.name %>
</a>
<!--TODO: use <a class="active"> to denote the current page and possibly category-->
<% end %>
<div class="dropdown-divider"></div>
<a class="dropdown-item" href="/<%= group.slug %>/">
All <%= group.name %>
</a>
</div>
</li>
<% end %>
С некоторой подстановкой кода и пропуском ненужных битов я читаю:
Group.where(published: TRUE).each do |group|
Exam.where(published: TRUE, group: group.id).each do |exam|
end
end
Это немного сбивает с толку, потому что Exam
не имеет столбца :group
, но есть Exam.where(group:)
Запрос ActiveRecord.
Вместо того, чтобы углубляться в ActiveRecord -> SQL-запросы, вы можете попробовать сначала сделать что-то вроде этого:
Group.where(published: true).includes(:exams).each do |group|
group.exams.each do |exam|
end
end