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

Php 从Yii中的单个控制器在两个不同的表中插入数据,php,arrays,yii,Php,Arrays,Yii,我有两个不同的表,我想一次在这两个表中插入数据 一张桌子是韵文 verse(id, topic_id, surah_id, verse_text) // id is primary key, 第二个表格是verse_翻译 verse_translations(id, verse_id, language_id, translations_text) // id is primary key, language_id is foreign key references with languag

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

一张桌子是韵文

verse(id, topic_id, surah_id, verse_text) // id is primary key, 
第二个表格是verse_翻译

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)

希望你能明白

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

$v_model=新诗;//用于保存功能

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

将这些模型对象传递给查看文件并按如下方式使用

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

标签($v_model,'verse_text')

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

labelEx($vt_model,'translation_text')

正在运行(保存/更新):

$v_model->attributes=$_POST[“韵文”]

如果($v_model->save())

{$vt_model->attributes=$_POST[“VerseTransactions”]

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

}


我想你应该试试这个

    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的视图中

<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 -->
$this->renderPartial('_form',array('verse_model'=>$verse_model,'verse_translation_model'=>$verse_translation_model));
<?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>
\u 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 -->
$this->renderPartial('_form',array('verse_model'=>$verse_model,'verse_translation_model'=>$verse_translation_model));
<?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>

带*的字段是必需的


您可以发布控制器编码吗?请发布您的操作代码