$ model-> save()不使用实体

问题描述 投票:0回答:1

我正在慢慢学习CodeIgniter的第4版,偶然发现了一种奇怪的行为:

[使用我模型的save()方法时,它仅保存created_atupdated_at时间戳。

这里是有用的代码。

迁移

public function up()
{
    $this->forge->addField('id');
    $this->forge->addField([
        'title' => [
            'type' => 'varchar',
            'constraint' => 127
        ],
        'content' => [
            'type' => 'text'
        ],
        'slug' => [
            'type' => 'varchar',
            'constraint' => 127
        ],
        'created_at' => [
            'type' => 'datetime'
        ],
        'updated_at' => [
            'type' => 'datetime'
        ],
        'deleted_at' => [
            'type' => 'datetime',
            'null' => true
        ]
    ]);
    $this->forge->createTable('articles');
}

NOTE:可以正常工作,该表已在数据库中正确创建,如下所示。

+------------+--------------+------+-----+---------+----------------+
| Field      | Type         | Null | Key | Default | Extra          |
+------------+--------------+------+-----+---------+----------------+
| id         | int(9)       | NO   | PRI | NULL    | auto_increment |
| title      | varchar(127) | NO   |     | NULL    |                |
| content    | text         | NO   |     | NULL    |                |
| slug       | varchar(127) | NO   |     | NULL    |                |
| created_at | datetime     | NO   |     | NULL    |                |
| updated_at | datetime     | NO   |     | NULL    |                |
| deleted_at | datetime     | YES  |     | NULL    |                |
+------------+--------------+------+-----+---------+----------------+

实体

namespace App\Entities;

class Article
{
}

型号

namespace App\Models;

class ArticleModel extends \CodeIgniter\Model
{
    protected $table = 'articles';
    protected $returnType = 'App\Entities\Article';
    protected $allowedFields = ['title', 'content', 'slug'];
    protected $useTimestamps = true;
}

调用模型

我尝试使用以下代码从两个不同的地方调用模型:播种器和控制器。

$article = new \App\Entities\Article();
$article->title = 'Article Title';
$article->content = 'Article Content';

$model = new \App\Models\ArticleModel();
$model->save($article);
echo $model->getLastQuery();

两次,结果都是相同的。 echo显示以下内容。

INSERT INTO `articles` (`created_at`, `updated_at`) VALUES ('2019-10-09 02:25:56', '2019-10-09 02:25:56')

我不知道如何告诉我的模型(我认为是不良行为的原因),请考虑其$allowedFields以保存文章。

您看到问题了吗?

model entities codeigniter-4
1个回答
0
投票

事实证明,在这种情况下,模型的save()方法仅接受类CodeIgniter\Entitiy的对象。

要做的是使Article扩展该类:

namespace App\Entities;

class Article extends \CodeIgniter\Entitiy
{
}

这解决了问题。

© www.soinside.com 2019 - 2024. All rights reserved.