douzong7283 2015-08-08 19:31
浏览 52
已采纳

OctoberCMS插件创作:有很多关系的问题 - 找不到类

I'm really struggling to get OctoberCMS relationships to work in a plugin that I'm writing. I have two tables: products and product_images. There is a one-to-many relationship between products and product_images.

In my products model, I have:

public $hasMany = [
    'product_images' => ['Bt/Shop/Models/ProductImages']
];

I have a model called ProductImages located in plugins/bt/shop/models/ProductImages.php. The model is defined as:

<?php namespace Bt\Shop\Models;

use Model;

class ProductImages extends Model
{
    public $table = 'bt_shop_product_images';

    protected $dates = ['published_at'];

    public static $allowedSortingOptions = array(
        'name asc' => 'Name (ascending)',
        'name desc' => 'Name (descending)',
        'updated_at asc' => 'Updated (ascending)',
        'updated_at desc' => 'Updated (descending)',
        'published_at asc' => 'Published (ascending)',
        'published_at desc' => 'Published (descending)',
    );

    public $preview = null;

    public $belongsTo = [
        'products' => ['Bt/Shop/Models/Products']
    ];

    ...

And the definition of my Products model looks like this:

<?php namespace Bt\Shop\Models;

use Model;

class Products extends Model
{

    public $table = 'bt_shop_products';

    protected $dates = ['published_at'];

    public static $allowedSortingOptions = array(
        'name asc' => 'Name (ascending)',
        'name desc' => 'Name (descending)',
        'updated_at asc' => 'Updated (ascending)',
        'updated_at desc' => 'Updated (descending)',
        'published_at asc' => 'Published (ascending)',
        'published_at desc' => 'Published (descending)',
    );

    public $preview = null;

    public $hasMany = [
        'product_images' => ['Bt/Shop/Models/ProductImages']
    ];

The error that I'm getting is:

Class 'ProductImages' not found

/var/www/mysite/public/vendor/october/rain/src/Database/Model.php line 772

I believe that when the Product hasMany relationship is being defined, somehow the code does not know about the ProductImages class. The code in Model.php, line 772 is:

public function hasMany($related, $primaryKey = null, $localKey = null, $relationName = null)
{
    if (is_null($relationName))
        $relationName = $this->getRelationCaller();

    $primaryKey = $primaryKey ?: $this->getForeignKey();
    $localKey = $localKey ?: $this->getKeyName();
    $instance = new $related;

    return new HasMany($instance->newQuery(), $this, $instance->getTable().'.'.$primaryKey, $localKey, $relationName);
}

In my case, the variable named $related is equal to Bt/Shop/Models/ProductImages. I printed it out to be sure.

Any suggestions?

  • 写回答

1条回答 默认 最新

  • dongsuoxi1790 2015-08-08 21:01
    关注

    I solved it. I was using forward slashes instead of back slashes in my belongsTo and hasMany definitions:

    Old (broken):

    public $belongsTo = [
        'products' => ['Bt/Shop/Models/Products']
    ];
    

    New (working):

    public $belongsTo = [
        'products' => ['Bt\Shop\Models\Products']
    ];
    

    Cheers, Bret

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥60 pb数据库修改或者求完整pb库存系统,需为pb自带数据库
  • ¥15 spss统计中二分类变量和有序变量的相关性分析可以用kendall相关分析吗?
  • ¥15 拟通过pc下指令到安卓系统,如果追求响应速度,尽可能无延迟,是不是用安卓模拟器会优于实体的安卓手机?如果是,可以快多少毫秒?
  • ¥20 神经网络Sequential name=sequential, built=False
  • ¥16 Qphython 用xlrd读取excel报错
  • ¥15 单片机学习顺序问题!!
  • ¥15 ikuai客户端多拨vpn,重启总是有个别重拨不上
  • ¥20 关于#anlogic#sdram#的问题,如何解决?(关键词-performance)
  • ¥15 相敏解调 matlab
  • ¥15 求lingo代码和思路