我有一个CodeIgniter应用程序和一个具有以下结构的MySQL表:
Table shortlisted_candidates
id int PRIMARY KEY AUTO INCREMENT,
candidate_no int NOT NULL,
written_marks int,
viva_marks int
我想在此表中执行insert_batch
,但数据只会插入id
和candidate_no
列。
我知道Codeigniter Active Records Class为批量插入提供了$this->db->insert_batch()
函数,但它实际上是在整个表中插入数据,而我希望数据只插入到特定的列中。我怎样才能在CodeIgniter中实现这个目标?
请注意,id
是AUTO INCREMENT,PRIMARY KEY列。
我的控制器代码:
class Shortlisted_candidates extends MY_Controller
{
function __construct()
{
parent::__construct();
$this->load->database();
$this->load->model('Shortlisted_candidate');
$this->load->helper('url');
$this->load->helper('html');
$this->load->helper('form');
$this->output->enable_profiler(false);
}
function add(){
$data = array();
if ($_POST) {
$data['candidate_no'] = $this->input->post('candidate_no');
$this->Shortlisted_candidate->add_candidate_to_shortlist($data);
$this->session->set_flashdata('message', 'Data Successfully Added');
redirect('shortlisted_candidates/add');
}
}
}
我的型号代码:
class Shortlisted_candidate extends CI_Model
{
function __construct()
{
// Call the Model constructor
parent::__construct();
}
function add_candidate_to_shortlist($data){
//Following code inserts data in ALL COLUMNS
$this->db->insert_batch('shortlisted_candidates', $data);
//How to write active record batch insert query for inserting data in only `id` and `candidate_no` column?
}
}
答案 0 :(得分:2)
您需要修改以下控制器功能。
function add(){
$data = array();
if ($_POST) {
$data[0]['candidate_no'] = $this->input->post('candidate_no');
$this->Shortlisted_candidate->add_candidate_to_shortlist($data);
$this->session->set_flashdata('message', 'Data Successfully Added');
redirect('shortlisted_candidates/add');
}
}
除此之外,您需要修改表模式,以便设置其他字段的默认值。
答案 1 :(得分:1)
您可以定义要插入批次的列。所以你必须使你的数组看起来像
$data = array(
array(
'id' => $id,
'candidate_no' => $candidate_no
),
array(
'id' => $id,
'candidate_no' => $candidate_no
)
);
//now in controller
$this->Shortlisted_candidate->add_candidate_to_shortlist($data);
这将仅插入特定列,而不是整个表格列