- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
到目前为止,我正在开发一个 Laravel-5 项目,我想构建某种事件日志。我确实有一个查询,它组合了多个表并为我提供了所需的数据,但是当我尝试将数据显示在屏幕上时,事情就出错了。
这是我现在在 ProfileController 中使用的查询:
$activity = DB::select("SELECT user_id, created_at, source, project_id
FROM (
SELECT id as project_id, user_id, created_at, 'project' as source FROM projects
UNION ALL SELECT project_id, user_id, created_at, 'comment' as source FROM comments
UNION ALL SELECT project_id, user_id, created_at, 'favorite' as source FROM favorites
UNION ALL SELECT project_id, user_id, created_at, 'like' as source FROM likes
) as a
WHERE user_id = $id
ORDER BY created_at DESC");
这就是我的 profile.blade.php 中的代码:
<ul class="list-group">
@foreach($activity as $act)
@if($act->source == 'project')
<li class="list-group-item">{{ $act->user_id }} added a new project: {{ $act->project_id }}</li>
@elseif($act->source == 'like')
<li class="list-group-item">{{ $act->user_id }} likes {{ $act->project_id }}!</li>
@elseif($act->source == 'comment')
<li class="list-group-item">{{ $act->user_id }} commented on {{ $act->project_id }}</li>
@elseif($act->source == 'favorite')
<li class="list-group-item">{{ $act->user_id }} has {{ $act->project_id }} to his favourites!</li>
@endif
@endforeach
</ul>
这就是我的模型的样子:
class Project extends Model
{
protected $fillable = [
'title',
'description',
'user_id',
'snapshot',
'views'
];
public function creator() {
return $this->belongsTo('App\User', 'user_id', 'id');
}
public function tags() {
return $this->belongsToMany('App\Models\Tag');
}
}
<小时/>
class Likes extends Model
{
protected $fillable = [
'user_id',
'project_id'
];
public function like() {
return $this->belongsTo('App\User', 'user_id', 'id');
}
public function project() {
return $this->belongsTo('App\Models\Project', 'project_id', 'id');
}
}
<小时/>
class Comment extends Model
{
protected $fillable = [
'user_id',
'project_id',
'comment'
];
public function poster() {
return $this->belongsTo('App\User', 'user_id', 'id');
}
public function project() {
return $this->belongsTo('App\Models\Project', 'project_id', 'id');
}
}
<小时/>
class Favorite extends Model
{
protected $fillable = [
'user_id',
'project_id'
];
public function favorite() {
return $this->belongsTo('App\User', 'user_id', 'id');
}
public function project() {
return $this->belongsTo('App\Models\Project', 'project_id', 'id');
}
}
现在我知道我只是要求在 Blade 页面上提供 user_id 或 project_id,我这样做是因为 $act->creator->name 或 $act->project->title 之类的东西会给我错误如下:
Undefined property: stdClass::$creator
或
Undefined property: stdClass::$project
我确实知道这可能与我构建查询的方式有关,并且以这种方式混合表可能会使事情变得比应有的更加困难,但我似乎找不到构建此查询的方法在 Eloquent 中查询或找到一种方法来访问属于这些 user_id 和 project_id 的数据,而无需使用我在模型中创建的公共(public)函数。
最佳答案
使用当前设置,您无法从 Laravel 模型中受益,因为您需要循环访问不同的模型。我的建议是建立一个名为 Activity 的新表,其中包含 3 列:id、type、user_id。并使用多态关系。
此外,您还可以从事件/监听器中受益,以便在事件表中创建记录。您可以从排队监听器中受益,因此如果不会影响您的客户体验,则不会在线创建事件记录。
关于mysql - 拉拉维尔 5 : Trouble with putting correct data on screen after combining tables,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33844498/
假设我有一个论坛,其中包含用户/管理员可以访问/管理的主题。 当用户访问它时,我首先会检查主题是否存在;在我设置一个标志后,告诉系统用户是否已访问过该主题。 这将是基本代码: 1 if(
我有一个基类 MessageHandler 和 2 个派生类,MessageHandler_CB 和 MessageHandler_DQ。 派生类重新定义了 handleMessage(...) 方法
我已经在我的 NOOBS 操作系统上安装了 v4l2loopback,但它不起作用。 我已经检查过是否安装了 v4l2loopback,它是。但是当我输入 sudo modprobe v4l2loop
我们正处于项目的最后一步,我们无法摆脱这个问题。 基本上,我们正在开发的页面是在视频中创建章节的表单。对于创建的每个章节,验证后都会创建一张小“卡片”。我们希望用户能够通过单击每个章节卡中显示的 X
我是 C# 新手。也许我没有正确地实现 IEquatable,因为我的类型的对象应该被认为是相同的,但不是。 类(class): class CompPoint : IComparable {
在我的代码顶部,我需要询问用户是否想玩游戏。使用字符串函数查看他们答案的第一个字母并将其变为小写。如果他们的答案 == "y"然后玩游戏。我需要帮助将 Yes 的第一个字母小写。
我正在尝试导出我的数据库。我尝试过通过电子邮件并分享它。 问题是我想导出数据库的当前状态(以及其中的所有信息)。 我已经尝试过这段代码: func exportDatabase(){ var
我在分层情况下遇到 getcomponentat 问题。我进行了很多研究,发现以下线程实际上是我需要的,但它对我不起作用。我在线程中下载了代码并且它可以工作但是当我在我的项目中实现它时它没有。我可能正
我有麻烦了。带标题:我不知从哪里得到了 8px 的 margin !我希望我的标题附加到覆盖所有顶部区域而没有边距。但是我只用 margin :-8px; 得到这个东西但是对于不同的屏幕我需要设置其他
我创建了 2 个页脚,第二个页脚使用 css position: absolute 但结果是,第一个页脚不再起作用。 结果是这样的: 最佳答案 请分享您的代码以供理解。 如果您使用的是 positio
我有一个新手问题: bool _isPalindrome(const string& str) { return _isPalindrome(str.begin(), str.end());
我正在尝试构建一个蒙德里安艺术创作器,它允许您创建任意数量的矩形,每个矩形的大小都是随机的。我能够创建随机大小,但我遇到的麻烦是让它创建两个以上的随机矩形。 import turtle import
谁能告诉我为什么以下内容不匹配: >>> re.search(r'(\d{2, 10})', '153') 这个匹配: >>> re.search(r'\d{3}', '153') 最佳答案 re模
我已经为主屏幕构建了一个小部件,并在我的 AppWidgetProvider 类中声明了一些变量。这些变量是整数和 boolean 值。 我遇到的问题(它基本上是一个 Java 编程问题)是我分配给变
我的内存有问题。我不明白为什么当我的程序长时间运行时 Go 使用越来越多的内存(从不释放它)。 第一次分配后,程序使用了将近 9 MB 的内存。然后在 12 小时后,它开始以指数方式使用更多内存,直到
当我使用 g++ 编译以下代码时 class A {}; void foo(A&) {} int main() { foo(A()); return 0; } 我收到以下错误消息: > g++
我正在尝试在我的应用程序中的 iPhone 屏幕上拖动 UIImageView。 目前我设置的拖动功能很好,拖动图像确实可以在屏幕上移动它,问题是你不必拖动 ImageView 来移动它,你也可以在屏
我无法解释这种行为: 有时,我的图表会显示带有大量小数的轴的第一个或最后一个标签。 在我的图表选项中,yAxis 如下所示: yAxis : [{ alternateGridColor: "
我的 update() 函数遇到问题。在这里,在 svg.append('rect') 中,我有 .on('click'),我只需更改数据,然后运行 update(). 为什么这不起作用?我该如何
自从我切换到最近的 emacs 版本 (23.2) 附带的 CEDET 后,CEDET 不再可靠地工作。例如,我无法再重新生成 EDE 项目。 环顾四周后,似乎压缩包中缺少所有 CEDET 模板。有谁
我是一名优秀的程序员,十分优秀!