php - Codeigniter - 使用 Select2 更新多行
问题描述
当输入2个值collecting_id属性和2个值nama_driver属性,并在数据库中成功输入2行,
但是如果输入 2个值collect_id和 1 个值nama_driver,那么只有 1 行输入到数据库中。
如果我输入 2 个或更多collecting_id 和1 个nama_driver,数据库中只有1 行。我希望数据库中有 2 行或更多行具有相同的 nama_driver 值
这是我的控制器:
$collecting_id = $this->input->post('collecting_id');
$nama_driver = $this->input->post('nama_driver');
$data = array();
for ($i = 0; $i < count($collecting_id); $i++) {
$data[] = array(
'nama_driver' => $nama_driver[$i],
'collecting_id' => $collecting_id[$i]
);
}
$this->db->update_batch('process', $data, 'collecting_id');
{
$this->session->set_flashdata('msg','<strong>Data Deliveries Berhasil Diupdate.');
redirect('delivery/deliver_list');
}
这是我的观点:
<div class="col-md-6 col-sm-6 col-xs-12">
<div class="form-group">
<label>Paket</label>
<select class="js-example-basic-multiple form-control" name="collecting_id[]" multiple="multiple">
<?php
if(@$paket_incoming) :
foreach ($paket_incoming as $row) :
?>
<option value="<?php echo $row->collecting_id; ?>"><?php echo $row->collecting_id; ?></option>
<?php
endforeach;
endif;
?>
</select>
</div></div>
<div class="col-md-6 col-sm-6 col-xs-12">
<div class="form-group">
<label>Nama Driver</label>
<select class="js-example-basic-multiple form-control" name="nama_driver[]" multiple="multiple">
<?php
if(@$driver) :
foreach ($driver as $row) :
?>
<option value="<?php echo $row->nama; ?>"><?php echo $row->nama; ?></option>
<?php
endforeach;
endif;
?>
</select>
</div></div>
<div class="col-md-12">
<center><button type="submit" class="btn btn-primary">Simpan</button>
<a href="<?php echo base_url();?>delivery/delivery_list" class="btn btn-default">Batal</a></center>
</div></div>
解决方案
你只需要改变这个
for ($i = 0; $i < count($collecting_id); $i++) {
$data[] = array(
'nama_driver' => $nama_driver[$i],
'collecting_id' => $collecting_id[$i]
);
}
对此
for ($i = 0; $i < count($collecting_id); $i++) {
$tempdata = array(
'nama_driver' => $nama_driver[$i],
'collecting_id' => $collecting_id[$i]
);
array_push($data, $tempdata);
}
使用 array_push 。您的数组格式与 CI 预期的不同。
那么你可以使用:$this->db->update_batch('process', $data, 'collecting_id');
推荐阅读
- python - 将火花数据帧转换为平面文件 .csv
- python - 如何使用 Python 在 Zendesk 中查询工单列表?
- r - 将 randomForest 预测保存为向量
- sql - 从 MS-Access 中的 VBA 查询中取消选择多个字段
- python - 如何使用谷歌合作在输出中显示 Plotly 滑块?
- c++ - 如何在 Windows 进程回调中获取断开连接的设备信息(硬件 ID)?
- azure - 如何强制 Azure 帐户选择器
- debugging - 毕加索图像未通过 USB 调试加载,但在仿真期间工作正常
- python - 在 Python 中扩展项目级别的嵌套类列表
- python - 如何在 Python 3 中删除小数?