Как получить последнюю запись вставки - Yii 2

Я делаю заявку на создание штрих-кода в своем приложении, я хочу создать Barang, но в бланке выпуска я хочу, чтобы бланк выпуска автоматически заполнялся из последнего бланка выпуска, что я могу сделать, чтобы исправить это?

введите описание изображения здесь

это мой взгляд

<?php

use yii\helpers\Html;
use yii\widgets\ActiveForm;

/* @var $this yii\web\View */
/* @var $model backend\models\Barang */
/* @var $form yii\widgets\ActiveForm */
?>

<div class="barang-form">

    <?php $form = ActiveForm::begin(); ?>

    <?= $form->field($model, 'rm_code')->textInput(['maxlength' => true]) ?>

    <?= $form->field($model, 'nama_barang')->textInput(['maxlength' => true]) ?>

    <?= $form->field($model, 'berat')->textInput(['maxlength' => true]) ?>



    <?= $form->field($model, 'issue_slip')->textInput(['maxlength' => true]) ?>

    <div class="form-group">
        <?= Html::submitButton($model->isNewRecord ? 'Create' : 'Update', ['class' => $model->isNewRecord ? 'btn btn-success' : 'btn btn-primary']) ?>
    </div>

    <?php ActiveForm::end(); ?>

</div>

 <div class="row">
    <?= $form->field($model, 'berat')->textInput(['maxlength' => true]) ?>
    <?php echo  \Yii::$app->db->getLastInsertId('{{barang}}');?>

  </div>

2 ответа

Решение

В контроллере перед рендером

public function actionCreate()
{
    $model = new Barang();
    $modelForSlip = Barang::find()->orderBy(['id'=> SORT_DESC])->one();
    $model->issue_slip = $modelForSlip->issue_slip;

    if ($model->load(Yii::$app->request->post())){

       $model->waktu = date('Y-m-d h:m:s');
       $model->user = \Yii::$app->user->identity->username;
       $model->save();

        return $this->redirect(['view', 'id' => $model->id]);
    } else {
        return $this->render('create', [
            'model' => $model,
        ]);
         //$model->issue_slip= \Yii::$app->db->getLastInsertId();
    }
}

Допустим, это ваша функция создания:

 public function actionCreate()
    {
        $model = new Modal();

        if ($model->load(Yii::$app->request->post()) && $model->save()) {
             return $this->redirect(['update', 'id' => $model->Id]);
        } else {
            return $this->render('create', [
                'model' => $model,
            ]);
        }
    }

затем перенаправить на новую страницу с последней вставленной ID Теперь заставьте вас обновить функцию, как это

 public function actionUpdate($id)
        {
            $model2 = Model::findOne($id);
            $model = new Modal();
 $model->issue_slip = $model2['issue_slip'];




            if ($model->load(Yii::$app->request->post()) && $model->save()) {
                return $this->redirect(['view', 'id' => $model->Id]);
            } else {
                return $this->render('update', [
                    'model' => $model,
                ]);
            }
        }

В YII2 Вы можете получить последнюю вставленную запись после save() функционировать легко

лайк

 $model->save();
echo $model->Id 

или любой другой столбец, который вы хотите получить вместо issue_slip Вы можете использовать любой столбец, который вы хотите

Другие вопросы по тегам