Изпълнявам CodeIgniter, използвайки активни записи. По-долу е структурата на моята таблица:
id (int) user (int) is_complete (tinyint)
------------------------------------------------
1 24 1
2 24 1
3 24 NULL
4 24 0
5 24 0
Случай 1
$this->db->where('user', 24);
Запитване:
SELECT * FROM `table` WHERE `user` = 24
Работи и се връща:
id user is_complete
--------------------------
1 24 1
2 24 1
3 24 NULL
4 24 0
5 24 0
Случай 2
$this->db->where('user', 24);
$this->db->where('is_complete', 1);
Запитване:
SELECT * FROM `table` WHERE `user` = 24 AND `is_complete` = 1
Работи и се връща:
id user is_complete
--------------------------
1 24 1
2 24 1
Случай 3
$this->db->where('user', 24);
$this->db->where('is_complete !=', 1);
Запитване:
SELECT * FROM `table` WHERE `user` = 24 AND `is_complete` != 1
Не работи и се връща:
id user is_complete
--------------------------
4 24 0
5 24 0
Случай 4
$this->db->where('user', 24);
$this->db->where('is_complete <>', 1);
Запитване:
SELECT * FROM `table` WHERE `user` = 24 AND `is_complete` <> 1
Не работи и се връща:
id user is_complete
--------------------------
4 24 0
5 24 0
Необходим резултат
Той трябва да върне:
id user is_complete
--------------------------
3 24 NULL
4 24 0
5 24 0
Правя ли нещо нередно, използвайки метода where()
, или има по-добър начин да постигна това?
0
илиNULL
- получавате желания резултат? - person Ofir Baruch   schedule 12.09.20130
не работи,NULL
работи - person doitlikejustin   schedule 12.09.20130
работи,NULL
работи - person doitlikejustin   schedule 12.09.2013echo $this->db->last_query();
копирайте и поставете заявката в phpMyAdmin и проверете дали работи. - person Massimiliano Marini   schedule 12.09.2013NULL
стойности. - person doitlikejustin   schedule 12.09.2013null
$where_array = ('id IS NULL' => NULL);
- person Kyslik   schedule 13.09.2013