将数据插入Yii中单个控制器的两个不同表中


Insert data in two different tables from single Controller in Yii

我有两个不同的表,我想一次在这两个表中插入数据。

一张表是相反的

verse(id, topic_id, surah_id, verse_text) // id is primary key, 

第二个表是verse_translations

verse_translations(id, verse_id, language_id, translations_text) // id is primary key, language_id is foreign key references with language table, // verse_id is foreign key references with verse table.

Verse创建文件(_form.php)

<div class="form">
    <?php $form = $this->beginWidget('CActiveForm', array('id'=>'verse-form', 'enableAjaxValidation'=>true)); ?>
    <p class="note">Fields with <span class="required">*</span> are required.</p>
    <div class="row">
        <?php echo $form->labelEx($model, 'verse_text'); ?>
        <?php echo $form->textArea($model, 'verse_text', array('rows'=>6, 'cols'=>50)); ?>
        <?php echo $form->error($model,'verse_text'); ?>
    </div>
    <div class="row">
        <?php echo $form->labelEx($model, 'verse_translations'); ?>
        <p class="<?php echo "tran".$model->id ?>">
            <?php 
                $errors = array_filter($model->verseTranslations);
                if(!empty($errors)) {
                    foreach($model->verseTranslations as $vt) {
                        echo $form->textArea($model, 'translation_text', array('value'=>$vt['translation_text'], 'rows'=>6, 'cols'=>50));
                    } 
                } 
            ?>
        </p>    
    </div>
    <div class="row buttons">
        <?php echo CHtml::submitButton($model->isNewRecord ? 'Create' : 'Save'); ?>
    </div>
<?php $this->endWidget(); ?>
</div><!-- form -->

正如您在_form文件中看到的,我已经调用了verse_translations表中的数据。

现在我的问题是:

我如何保持textArea的值,它将进入控制器中的数组?以及如何从verse-create控制器在verse_translation表中插入数据。

_form文件的输出如下所示。

Verse创建控制器代码

public function actionCreate()
{
    $model=new Verse;
    // Uncomment the following line if AJAX validation is needed
    // $this->performAjaxValidation($model);
    if(isset($_POST['Verse']))
    {
        $model->attributes=$_POST['Verse'];
        if($model->save())
            $this->redirect(array('view','id'=>$model->id));
    }
    $this->render('create',array(
        'model'=>$model,
    ));
}

希望你理解清楚。

感谢

我认为你应该试试这个

    public function actionCreate()
    {
    $verse_model=new Verse;
    $verse_translation_model=new Verse_translations;
    if(isset($_POST['Verse']) && isset($_POST['Verse_translations']))
    {
    $verse_model->attributes=$_POST['Verse'];
    $verse_translation_model->attributes=$_POST['Verse_translations'];
    $verse_model->save();
    $verse_translation_model->save();
    echo 'data is saved in both tables';
    }
    $this->render('create',array('verse_model'=>$verse_model,'verse_translation_model'=>$verse_translation_model));
}

在create.php中的视图中

$this->renderPartial('_form',array('verse_model'=>$verse_model,'verse_translation_model'=>$verse_translation_model));

_form.php

<?php $form = $this->beginWidget('CActiveForm', array('id'=>'verse-form', 'enableAjaxValidation'=>true)); ?>
    <p class="note">Fields with <span class="required">*</span> are required.</p>
    <div class="row">
        <?php echo $form->labelEx($verse_model, 'verse_text'); ?>
        <?php echo $form->textArea($verse_model, 'verse_text', array('rows'=>6, 'cols'=>50)); ?>
        <?php echo $form->error($verse_model,'verse_text'); ?>
    </div>
<div class="row">
        <?php echo $form->labelEx($verse_model, 'topic_id'); ?>
        <?php echo $form->textArea($verse_model, 'topic_id', array('rows'=>6, 'cols'=>50)); ?>
        <?php echo $form->error($verse_model,'topic_id'); ?>
    </div>
<div class="row">
        <?php echo $form->labelEx($verse_model, 'surah_id'); ?>
        <?php echo $form->textArea($verse_model, 'surah_id', array('rows'=>6, 'cols'=>50)); ?>
        <?php echo $form->error($verse_model,'surah_id'); ?>
    </div>
<div class="row">
        <?php echo $form->labelEx($verse_transaction_model, 'verse_id'); ?>
        <?php echo $form->textArea($verse_transaction_model, 'verse_id', array('rows'=>6, 'cols'=>50)); ?>
        <?php echo $form->error($verse_transaction_model,'verse_id'); ?>
    </div>
<div class="row">
        <?php echo $form->labelEx($verse_transaction_model, 'translations_text'); ?>
        <?php echo $form->textArea($verse_transaction_model, 'translations_text', array('rows'=>6, 'cols'=>50)); ?>
        <?php echo $form->error($verse_transaction_model,'translations_text'); ?>
    </div>
<div class="row">
        <?php echo $form->labelEx($verse_transaction_model, 'language_id'); ?>
        <?php echo $form->textArea($verse_transaction_model, 'language_id', array('rows'=>6, 'cols'=>50)); ?>
        <?php echo $form->error($verse_transaction_model,'language_id'); ?>
    </div>

要存储在两个表(Model)中,必须为每个表创建两个模型对象。例如:

$v_model=新版本;//对于保存功能

$vt_model=新版本转换;//对于保存功能

将这些模型对象传递到视图文件并按如下方式使用。

对于verse模型文本框,您必须使用:

labelEx($v_model,'verse_text');

对于verse_tarnsction模型文本框,您必须使用:

labelEx($vt_model,'translation_text');

操作中(保存/更新):

$v_model->attributes=$_POST["Verse"];

if($v_model->save())

{$vt_model->attributes=$_POST["VerseTransactions"];

$vt_model->verse_id=$v_model->id$vt_model->save();

}