如何将数组元素名称保存到数据库?
How to save array element names to the database?
我的模型中有以下代码:
public function getData($property)
{
$data = array(
'a_4_1' => array(
'RUB',
'USD',
'JPY',
),
);
return $data[$property];
}
在我看来:
<?= $form->labelEx($model, 'a_4_1', array('class' => 'col-xs-12 col-sm-2 control-label')) ?>
<div class="col-xs-12 col-sm-3">
<?= $form->dropDownList($model, 'a_4_1',$model->getData('d_4_1'), array('class' => 'form-control')) ?>
<?= $form->error($model, 'a_4_1') ?>
</div>
当我将它保存到数据库时,它以整数格式保存数据(例如 1,2,..)
我需要将数组元素的名称保存到数据库中(例如 RUB、USD)(不是整数)。我该怎么做?
使用 array_combine()
更改数组的键值,如下所示:
array_combine($model->getData('d_4_1'),$model->getData('d_4_1'))
<?= $form->labelEx($model, 'a_4_1', array('class' => 'col-xs-12 col-sm-2 control-label')) ?>
<div class="col-xs-12 col-sm-3">
<?= $form->dropDownList($model, 'a_4_1',array_combine($model->getData('d_4_1'),$model->getData('d_4_1')), array('class' => 'form-control')) ?>
<?= $form->error($model, 'a_4_1') ?>
</div>
我的模型中有以下代码:
public function getData($property)
{
$data = array(
'a_4_1' => array(
'RUB',
'USD',
'JPY',
),
);
return $data[$property];
}
在我看来:
<?= $form->labelEx($model, 'a_4_1', array('class' => 'col-xs-12 col-sm-2 control-label')) ?>
<div class="col-xs-12 col-sm-3">
<?= $form->dropDownList($model, 'a_4_1',$model->getData('d_4_1'), array('class' => 'form-control')) ?>
<?= $form->error($model, 'a_4_1') ?>
</div>
当我将它保存到数据库时,它以整数格式保存数据(例如 1,2,..) 我需要将数组元素的名称保存到数据库中(例如 RUB、USD)(不是整数)。我该怎么做?
使用 array_combine()
更改数组的键值,如下所示:
array_combine($model->getData('d_4_1'),$model->getData('d_4_1'))
<?= $form->labelEx($model, 'a_4_1', array('class' => 'col-xs-12 col-sm-2 control-label')) ?>
<div class="col-xs-12 col-sm-3">
<?= $form->dropDownList($model, 'a_4_1',array_combine($model->getData('d_4_1'),$model->getData('d_4_1')), array('class' => 'form-control')) ?>
<?= $form->error($model, 'a_4_1') ?>
</div>