1

こんにちは、データベースにフォーム データを送信すると問題が発生します。すべての NULL フィールドが保存されます。助言がありますか? 私のコントローラー

public function actionOffri()
   {
    $model = new Offri;

   if($model->load(Yii::$app->request->post())&& $model->validate() && $model->save())
       {
        Yii::$app->session->setFlash('success', 'Hai inserito i dati correttamente');
        return $this->render('offri', ['model' => $model]);
       }
}

私のモデルフィールド機能のルールと変数を追加しました。

public $name;
public function rules()
    {
        return [['name'],'string'.....
                 ....
               ];
}
私の完全なモデル

class Offri extends \yii\db\ActiveRecord
{
    /**
     * @inheritdoc
     */
    public static function tableName()
    {
        return 'viaggio';
    }

public $data_par;
public $ora_part;
public $data_arrivo;
public $ora_arrivo;
public $citta_part;
public $citta_arrivo;
public $wifi;
public $bagno;
public $ac_dc;
public $condizioni;
    /**
     * @inheritdoc
     */
    public function rules()
    {
        return [
            [['citta_part','citta_arrivo'], 'required'],
            [['citta_part','citta_arrivo'], 'string', 'max' => 255],
            [['posti_disponibili', 'conferma_utenze', 'accounts_id_account', 'posti_max', 'wifi', 'bagno', 'ac_dc'], 'integer'],
            [['prezzo'], 'number'],
            [['accounts_id_account'], 'required'],
            [['citta_part', 'via_part', 'citta_arrivo', 'via_arrivo', 'veicolo'], 'string', 'max' => 45],
            [['note'], 'string', 'max' => 255],
            [['accounts_id_account'], 'exist', 'skipOnError' => true, 'targetClass' => Accounts::className(), 'targetAttribute' => ['accounts_id_account' => 'id_account']],
        ];
    }

    /**
     * @inheritdoc
     */
    public function attributeLabels()
    {
        return [
            'id_viaggio' => Yii::t('app', 'Id Viaggio'),
            'citta_part' => Yii::t('app', 'Citta Part'),
            'via_part' => Yii::t('app', 'Via Part'),
            'ora_part' => Yii::t('app', 'Ora Part'),
            'data_part' => Yii::t('app', 'Data Part'),
            'posti_disponibili' => Yii::t('app', 'Posti Disponibili'),
            'conferma_utenze' => Yii::t('app', 'Conferma Utenze'),
            'prezzo' => Yii::t('app', 'Prezzo'),
            'note' => Yii::t('app', 'Note'),
            'accounts_id_account' => Yii::t('app', 'Accounts Id Account'),
            'citta_arrivo' => Yii::t('app', 'Citta Arrivo'),
            'data_arrivo' => Yii::t('app', 'Data Arrivo'),
            'ora_arrivo' => Yii::t('app', 'Ora Arrivo'),
            'via_arrivo' => Yii::t('app', 'Via Arrivo'),
            'veicolo' => Yii::t('app', 'Veicolo'),
            'posti_max' => Yii::t('app', 'Posti Max'),
            'wifi' => Yii::t('app', 'Wifi'),
            'bagno' => Yii::t('app', 'Bagno'),
            'ac_dc' => Yii::t('app', 'Ac Dc'),
        ];
    }

4

1 に答える 1

0

ruleslabelsmembersからわかることから、仮想メンバーを使用すべきではない場所で使用している可能性があります。仮想メンバーを使用すると、ユーザーの入力からの値が上書きされることに注意してください。手動で値を割り当てていないので、Yii はすべてをクリアして空のままにします。また、列のデフォルト値として設定している可能性が最も高いnullです(データが空の場合)。そのためnull、すべての行に表示されています。

この問題を解決するには、Modelから次の行を削除します。

public $data_par;
public $ora_part;
public $data_arrivo;
public $ora_arrivo;
public $citta_part;
public $citta_arrivo;
public $wifi;
public $bagno;
public $ac_dc;
public $condizioni;

これらの仮想属性は、DB 属性とは異なる方法で使用されています。あなたの場合、ここでは必要ないと思います。

于 2016-08-11T20:05:19.133 に答える