Codeigniter объединяет запросыwhere_in и подобные активные записиPhp

Кемеровские программисты php общаются здесь
Ответить
Anonymous
 Codeigniter объединяет запросыwhere_in и подобные активные записи

Сообщение Anonymous »

У меня есть следующий запрос активной записи:

$this->db->select('id, email, first_name, last_name, current_location_state, current_location, avatar, avatar_fb');
$this->db->from('users');
$this->db->like('first_name', $search);
$this->db->or_like('last_name', $search);
$this->db->or_like("CONCAT(first_name, ' ', last_name)", $search);
$this->db->or_like('email', $search);
$this->db->where_in('id', $ids);


Это функция, имеющая массив $ids, содержащий идентификаторы моих друзей. Я хочу найти друзей, которые соответствуют моим запросам «Мне нравится», но имеют только один идентификатор в переменной $ids.

Я почти уверен, что мне нужно объединитьwhere_in и все подобные операторы, чтобы это было что-то вроде (WHERE_IN $ids && Like Statements).

Я не очень хорошо разбираюсь в MySQL, поэтому буду благодарен за любую помощь.

Спасибо!

function narrow_connections($search) {

//First get all this users connections...
$connections = $this->get_connections($this->session->userdata('user_id'), 0, 0);

if(empty($connections)) {
return array();
}else {

//Need to get an array of id's
$ids = array();
foreach($connections as $con) {
array_push($ids, $con['id']);
}

//Now that we have an array of ID's, find all users that have one of the ids (our connections), AND match a search term to narrow down
//the results.

$this->db->select('id, email, first_name, last_name, current_location_state, current_location, avatar, avatar_fb');
$this->db->from('users');
$this->db->like('first_name', $search);
$this->db->or_like('last_name', $search);
$this->db->or_like("CONCAT(first_name, ' ', last_name)", $search);
$this->db->or_like('email', $search);
$this->db->where_in('id', $ids);
$query = $this->db->get();
$data = array();

foreach ($query->result() as $row) {
$data[] = array(
'id' => $row->id,
'email' => $row->email,
'first_name' => $row->first_name,
'last_name' => $row->last_name,
'current_location_state' => $row->current_location_state,
'current_location' => $row->current_location,
'avatar' => $row->avatar,
'avatar_fb' => $row->avatar_fb,
);
}
return $data;

}
}


Подробнее здесь: https://stackoverflow.com/questions/214 ... rd-queries
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «Php»