我正在尝试使用codeigniter将数组数据插入数据库。当我使用print_r()
乐趣打印这些值时。
它显示正确的结果,但是当我点击“保存”按钮时,它会在表格中插入空白值。
我只是想在处方表中存储多个药物名称,用于特定处方_我试图使用insert_batch函数插入数据,但它保存了空白记录
这是我的型号代码:
public function add_prescription($data) {
$data['medicine_name'] = $data['medicine_nm[]'];
print_r($data['medicine_name']);
$this->db->insert_batch('pre',$data);
return $this->db->insert_id($pre_id);
}
控制器代码 -
public function prescription($patient_id = NULL, $app_date = NULL, $hour = NULL , $min = NULL) {
//Check if user has logged in
if (!$this->session->userdata('user_name') || $this->session->userdata('user_name') == '') {
redirect('login/index/');
} else {
if ($this->form_validation->run() === FALSE) {
$data['medicine_nm[]']=$this->input->post('medicine_nm[]');
$this->patient_model->add_prescription($data);
}
}
}
答案 0 :(得分:5)
您需要json_encode
该数组,然后将其插入数据库,如
$data = json_encode($array);
$this->db->insert('column_name',$data);
在获取内容时,您需要decode
$data = json_decode($column_result);
希望这会对你有所帮助。
答案 1 :(得分:1)
试试这个
public function add_prescription($name) {
$data = array(
'medicine_name' => $name
);
$query = $this->db->insert('table_name',$data);
return $query->result_array();
}
希望这会对你有所帮助