簡體   English   中英

cakePHP 3.0 HABTM關系保存數據

[英]cakePHP 3.0 HABTM relations save data

我想在cakePHP 3.0中制作本教程http://miftyisbored.com/complete-tutorial-habtm-relationships-cakephp/

我有3張桌子:食譜,配料和Ingredients_recipes。

制作食譜時,我想選擇配料。 然后,我想將recipe_id和Ingredient_id存儲在Ingredients_recipes表中,但是這樣做沒有成功。 我認為RecipesController中出了點問題。 有人可以幫助我或指出正確的方向嗎?

問題:

$ingredients = $this->Recipes->Ingredients->find('list', ['limit' => 200]);
// => THIS GIVES ME THE MESSAGE "The recipe could not be saved. Please, try again."

$ingredients = $this->Ingredients->find('list', ['limit' => 200]);
// => THIS GIVES ME THE ERROR "Call to a member function find() on boolean"

當我做var dump時(使用此$ this-> Recipes-> Ingredients-> find時),我得到了:

array(3) { 
   ["recipe_name"]=> string(4) "Test" 
   ["recipe_description"]=> string(4) "Test" 
   ["Recipe"]=> array(1) { 
      ["Ingredient"]=> array(1) { [0]=> string(1) "1" } 
   } 
}

表:

CREATE TABLE `recipes` (
  `recipe_id` int(11) NOT NULL auto_increment,
  `recipe_name` varchar(255) NOT NULL,
  `recipe_description` text NOT NULL,
  PRIMARY KEY  (`recipe_id`)
);
CREATE TABLE `ingredients` (
  `ingredient_id` int(11) NOT NULL auto_increment,
  `ingredient_name` varchar(255) NOT NULL,
  `ingredient_description` text NOT NULL,
  PRIMARY KEY  (`ingredient_id`)
);
CREATE TABLE `ingredients_recipes` (
  `ingredient_id` int(11) NOT NULL,
  `recipe_id` int(11) NOT NULL,
  PRIMARY KEY  (`ingredient_id`,`recipe_id`)
);

這是我的代碼如下:

模型>實體:

食譜

class Recipe extends Entity
{
    protected $_accessible = [
        'recipe_id' => true,
        'recipe_name' => true,
        'recipe_description' => true,
    ];
}

成分

class Ingredient extends Entity
{
    protected $_accessible = [
        'ingredient_id' => true,
        'ingredient_name' => true,
        'ingredient_description' => true,
    ];
}

IngredientsRecipe

class IngredientsRecipe extends Entity
{
    protected $_accessible = [
        'ingredient' => true,
        'recipe' => true,
    ];
}

型號>表格:

RecipesTable

class RecipesTable extends Table
{
    public function initialize(array $config)
    {
        $this->table('recipes');
        $this->displayField('recipe_name');
        $this->primaryKey('recipe_id');

        $this->belongsTo('Recipes', [
            'foreignKey' => 'recipe_id',
            'joinType' => 'INNER'
        ]);

        $this->belongsToMany('Ingredients', [
            'className' => 'Ingredients',
            'joinTable' => 'ingredients_recipes',
            'foreignKey' => 'recipe_id',
            'targetForeignKey' => 'ingredient_id' 
        ]);
    }
    public function validationDefault(Validator $validator)
    {
        $validator
            ->requirePresence('recipe_name', 'create')
            ->notEmpty('recipe_name')

            ->requirePresence('recipe_description', 'create')
            ->notEmpty('recipe_description')

            ->requirePresence('Ingredients', 'create')
            ->notEmpty('Ingredients');

        return $validator;
    }
}

IngredientsTable

class IngredientsTable extends Table
{
    public function initialize(array $config)
    {
        $this->table('ingredients');
        $this->displayField('ingredient_name');
        $this->primaryKey('ingredient_id');

        $this->belongsTo('Ingredients', [
            'foreignKey' => 'ingredient_id',
            'joinType' => 'INNER'
        ]);

        $this->belongsToMany('Recipies', [
            'className' => 'Recipies',
            'joinTable' => 'ingredients_recipes',
            'foreignKey' => 'ingredient_id',
            'targetForeignKey' => 'recipe_id' 
        ]);
    }
}

IngredientsRecipesTable

class IngredientsRecipesTable extends Table
{
    public function initialize(array $config)
    {
        $this->table('ingredients_recipes');

        $this->displayField('recipe_id');

        $this->primaryKey(['recipe_id', 'ingredient_id']);

        $this->belongsTo('Recipies', [
            'foreignKey' => 'recipe_id',
            'joinType' => 'INNER'
        ]);

        $this->belongsTo('Ingredients', [
            'foreignKey' => 'ingredient_id',
            'joinType' => 'INNER'
        ]);
    }

控制器:

的RecipesController

public function add()
{
    $recipe = $this->Recipes->newEntity();
    if ($this->request->is('post')) {
        $recipe = $this->Recipes->patchEntity($recipe, $this->request->data);
        // var_dump($this->request->data);
        if ($this->Recipes->save($recipe)){
            $this->Flash->success('The recipe has been saved.');
            return $this->redirect(['action' => 'index']);
        } else {
            $this->Flash->error('The recipe could not be saved. Please, try again.');
        }
    }
    $recipes = $this->Recipes->find('list', ['limit' => 200]);

    $ingredients = $this->Recipes->Ingredients->find('list', ['limit' => 200]);
    // => THIS GIVES ME THE MESSAGE "The recipe could not be saved. Please, try again."
    $ingredients = $this->Ingredients->find('list', ['limit' => 200]);
    // => THIS GIVES ME THE ERROR "Call to a member function find() on boolean"

    $this->set(compact('recipe', 'recipes', 'ingredients'));
    $this->set('_serialize', ['recipe']);
}

模板>食譜

add.ctp

<?= $this->Form->create($recipe); ?>
    <fieldset>
        <legend><?= __('Add Recipe') ?></legend>
        <?php
            echo $this->Form->input('recipe_name', array(
                'label' => 'Name'
                )
            );
            echo $this->Form->input('recipe_description', array(
                'label' => 'Description'
                )
            );

            echo $this->Form->input('Recipes.Ingredients', ['multiple'=>true]);
        ?>
    </fieldset>
    <?= $this->Form->button(__('Submit')) ?>
    <?= $this->Form->end() ?>

也許本教程可以對您有所幫助: http : //book.cakephp.org/3.0/en/tutorials-and-examples/bookmarks/intro.html

它確切地解釋了如何設置HABTM關系,如何將標簽添加到書簽等等。

祝你好運,編碼愉快:)

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM