我一直在尝试显示没有重复的行,但查询无法正常工作。我认为问题是一对多的关系,因为一个'intervaloHorario'有很多'citas'。因此,例如,我只想显示:“从 8:00 到 15:00(这是一个 intervaloHorario)”到日期(cita)“27/08/1988”。我该怎么办?
Controller
$this->Fechacita_Model->delete_duplicaterow();
型号
public function delete_duplicaterow() {
$this->db->select('
c.intervaloHorario','ci.cita'
);
$this->db->from('intervaloshorarios c');
$this->db->join('citas ci', 'ci.idCitas = c.idIntervaloHorario','left');
$this->db->group_by('c.idIntervaloHorario','ci.cita');
$query = $this->db->get();
return $query->num_rows();
}
模型(编辑)
$this->db->select(array('c.intervaloHorario', 'ci.cita'));
$this->db->distinct();
$this->db->from('intervaloshorarios c');
$this->db->join('citas ci', 'ci.idCitas = c.idIntervaloHorario', 'left');
$this->db->group_by('c.idIntervaloHorario', 'ci.cita');
$query = $this->db->get();
$this->db->last_query();
return $query->num_rows();
数据库
当前数据库
截图
当前列表(无序列表但重复存在)
最佳答案
您可以使用 $this->db->distinct()
并添加选择主键以删除重复项:
public function delete_duplicaterow() {
$this->db->select(array('c.intervaloHorario', 'ci.cita'));
$this->db->distinct();
$this->db->from('intervaloshorarios c');
$this->db->join('citas ci', 'ci.idCitas = c.idIntervaloHorario','left');
$this->db->group_by('c.idIntervaloHorario','ci.cita');
$query = $this->db->get();
return $query->num_rows();
}
关于php - Codeigniter 如何避免重复显示一对多关系,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44237761/