大家好我在数据库中发送表单数据时遇到问题,保存所有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'),
];
}

答案 0 :(得分:0)
从我的规则,标签和成员中可以看到,可能是因为您正在使用虚拟成员,你不应该这样做。请注意,使用虚拟成员将覆盖用户输入中的任何值。由于您没有分配任何手动值,Yii只会清除所有值并将其留空。您也很可能已将null
设置为列中的默认值(如果数据为空),这就是您在每行中看到null
的原因。
要解决此问题,请从模型:
中删除这些行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;
这些虚拟属性的使用方式与数据库属性不同,我认为在您的情况下,您不需要这些属性。