模型codeigniter上的查询数组

时间:2014-08-12 10:37:20

标签: php mysql arrays codeigniter models

我是学习CodeIgniter的学生,我有关于数据库的学校作业,我创建了一个项目,并在我的模型中运行查询,就像这样。

class Send_model extends CI_Model{        
   function hello(){ $table = $this->db->query("SELECT * FROM (`tbl1`) LEFT JOIN `tbl2` ON `tbl2`.`id` = `tbl1`.`child_id` LEFT JOIN `tbl3` ON `tbl3`.`id` = `tbl1`.`child_id` ");
    foreach($table->result() as  $row){
    $modbus[]= $row->modbus;
    $data []= $row->data;
    $alert[]= $row->alert;
    };
        $param0 = '&'.$modbus[0].'='.$data[0].':'.$alert[0]; 
        $param1 = '&'.$modbus[1].'='.$data[1].':'.$alert[1];
        $param2 = '&'.$modbus[2].'='.$data[2].':'.$alert[2];
        $param3 = '&'.$modbus[3].'='.$data[3].':'.$alert[3];
        $param4 = '&'.$modbus[4].'='.$data[4].':'.$alert[4];
        $param5 = '&'.$modbus[5].'='.$data[5].':'.$alert[5];
        $param6 = '&'.$modbus[6].'='.$data[6].':'.$alert[6];
        $param7 = '&'.$modbus[7].'='.$data[7].':'.$alert[7];
        $param8 = '&'.$modbus[8].'='.$data[8].':'.$alert[8];
        $param9 = '&'.$modbus[9].'='.$data[9].':'.$alert[9];
        $param10 = '&'.$modbus[10].'='.$data[10].':'.$alert[10];
        $param11= '&'.$modbus[11].'='.$data[11].':'.$alert[11];
        $param12 = '&'.$modbus[12].'='.$data[12].':'.$alert[12];
        $param13 = '&'.$modbus[13].'='.$data[13].':'.$alert[13];
        $param14 = '&'.$modbus[14].'='.$data[14].':'.$alert[14];
        $param15 = '&'.$modbus[15].'='.$data[15].':'.$alert[15];
        $param16 = '&'.$modbus[16].'='.$data[16].':'.$alert[16];
        $param17 = '&'.$modbus[17].'='.$data[17].':'.$alert[17];
        $param18 = '&'.$modbus[18].'='.$data[18].':'.$alert[18];
    $sent = $param0.$param1.$param3.$param4.$param5.$param6.$param7.$param8.$param9.$param10.$param11.$param12.$param13.$param13.$param14.$param15.$param16.$param17;

    return $sent;
}

我的控制器就像这样

class Send extend CI_Controller{
function data ()
{ 
$this->load->model('send_model');
$send = $this->model->send_model->hello();
echo $sent;
}
}
  • 我有一个问题,如果tbl1添加数据,那么我必须写代码添加到我的脚本
  • 有人可以帮我简化这段代码吗?

1 个答案:

答案 0 :(得分:3)

这是因为您通过创建19个$param变量来硬编码仅发送19行数据。在动态条件下,您可能有一个空记录集或数百条记录。将foreach循环的结构修改为以下内容:

$param = array();
foreach($table->result() as  $row){
$param[] = '&'.$row->modbus.'='.$row->data.':'.$row->alert;
} 
return $param;

希望它能回答你的问题。