CodeIgniter: как использовать предложение WHERE и предложение OR - PullRequest
24 голосов
/ 04 июня 2010

Я использую следующий код для выбора из базы данных MySQL с помощью веб-приложения Code Igniter:

$query = $this->db->get_where('mytable',array('id'=>10));

Это прекрасно работает! Но я хочу написать следующую инструкцию MySQL, используя библиотеку CI?

SELECT * FROM `mytable` WHERE `id`='10' OR `field`='value'

Есть идеи? Спасибо!

Ответы [ 6 ]

40 голосов
/ 04 июня 2010
$where = "name='Joe' AND status='boss' OR status='active'";

$this->db->where($where);
30 голосов
/ 04 июня 2010

Вы можете использовать or_where () для этого - пример из документации CI:

$this->db->where('name !=', $name);

$this->db->or_where('id >', $id); 

// Produces: WHERE name != 'Joe' OR id > 50
12 голосов
/ 15 октября 2012

Вы можете использовать это:

$this->db->select('*');
$this->db->from('mytable');
$this->db->where(name,'Joe');
$bind = array('boss', 'active');
$this->db->where_in('status', $bind);
6 голосов
/ 15 декабря 2014

Используется метод активной записи or_where:

$this->db->select("*")
->from("table_name")
->where("first", $first)
->or_where("second", $second);
2 голосов
/ 10 апреля 2017
$where = "name='Joe' AND status='boss' OR status='active'";

$this->db->where($where);

Несмотря на то, что я опаздываю на 3/4 месяца, вы все равно выполняете следующее после определения ваших предложений where ... $this->db->get("tbl_name");

1 голос
/ 21 февраля 2018

Что сработало для меня:

  $where = '';
   /* $this->db->like('ust.title',$query_data['search'])
        ->or_like('usr.f_name',$query_data['search'])
        ->or_like('usr.l_name',$query_data['search']);*/
        $where .= "(ust.title like '%".$query_data['search']."%'";
        $where .= " or usr.f_name like '%".$query_data['search']."%'";
        $where .= "or usr.l_name like '%".$query_data['search']."%')";
        $this->db->where($where);



$datas = $this->db->join(TBL_USERS.' AS usr','ust.user_id=usr.id')
            ->where_in('ust.id', $blog_list) 
            ->select('ust.*,usr.f_name as f_name,usr.email as email,usr.avatar as avatar, usr.sex as sex')
            ->get_where(TBL_GURU_BLOG.' AS ust',[
                'ust.deleted_at'     =>  NULL,
                'ust.status'     =>  1,
            ]); 

Я должен сделать это, чтобы создать запрос, подобный этому:

SELECT `ust`.*, `usr`.`f_name` as `f_name`, `usr`.`email` as `email`, `usr`.`avatar` as `avatar`, `usr`.`sex` as `sex` FROM `blog` AS `ust` JOIN `users` AS `usr` ON `ust`.`user_id`=`usr`.`id` WHERE (`ust`.`title` LIKE '%mer%' ESCAPE '!' OR  `usr`.`f_name` LIKE '%lok%' ESCAPE '!' OR  `usr`.`l_name` LIKE '%mer%' ESCAPE '!') AND `ust`.`id` IN('36', '37', '38') AND `ust`.`deleted_at` IS NULL AND `ust`.`status` = 1 ;
...