Как выполнить несколько запросов в Codeigniter, разделенных точкой с запятой - PullRequest
0 голосов
/ 31 мая 2019

У меня есть таблица посещаемости, и я хочу вставить в нее данные, если нет, и обновить, если есть, запрос в цикле работает нормально, но занимает слишком много времени. Поэтому, чтобы сократить время, я объединяю все запросы в виде строки, разделенной точкой с запятой. Результат получается после конкатенации в phpMyAdmin, но не в Codeigniter, любая догадка почему? Заранее спасибо.

function set_attendance()
    {
        $today = date('Y-m-d');
        $data = $this->input->post('member');
        $str='';
        foreach ($data as  $value) 
        {
            $query = $this->db->select('*')
                            ->from('attendance')
                            ->where('user_id',$value['user_id'])
                            ->where('date',$today)
                            ->get();

            if($query->num_rows()>0)
            {
                $obj = array(
                       'attendance'    => $value['status'],
                       'leavetype' => $value['leavetype'],
                );

                $where = "user_id =  '{$value['user_id']}' AND date = '{$today}'";

                $str .= $this->db->update_string('attendance', $obj, $where);
                $str.=';';
            }
            else
            {
                 $obj = array(
                        's-no'  => null,
                        'user_id' => $value['user_id'],
                        'date' => $today,
                        'regby'=>'t',
                        'leavetype' => $value['leavetype'],
                       'attendance'    => $value['status'],
                );
                $str .= $this->db->insert_string('attendance', $obj);
                 $str.=';';

            }

        }

        $this->db->query($str);
        $output = array('result'=>true);
        return $output ;
    }

1 Ответ

0 голосов
/ 31 мая 2019

Хорошо, я получаю ответ Просто запустите собственную функцию php multi_query ()

function set_attendance()
    {
        $today = date('Y-m-d');
        $data = $this->input->post('member');
        $str='';
        foreach ($data as  $value) 
        {
            $query = $this->db->select('*')
                            ->from('attendance')
                            ->where('user_id',$value['user_id'])
                            ->where('date',$today)
                            ->get();

            if($query->num_rows()>0)
            {
                $obj = array(
                       'attendance'    => $value['status'],
                       'leavetype' => $value['leavetype'],
                );

                $where = "user_id =  '{$value['user_id']}' AND date = '{$today}'";

                $str .= $this->db->update_string('attendance', $obj, $where);
                $str.=';';
            }
            else
            {
                 $obj = array(
                        's-no'  => null,
                        'user_id' => $value['user_id'],
                        'date' => $today,
                        'regby'=>'t',
                        'leavetype' => $value['leavetype'],
                       'attendance'    => $value['status'],
                );
                $str .= $this->db->insert_string('attendance', $obj);
                 $str.=';';

            }

        }
        $link = mysqli_connect('localhost','root','','yoga_panel');
        if(mysqli_multi_query($link,$str))
        {
            $output=array('result'=>true);
            return $output;
        } 
    }
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...