0

这个查询有什么区别:

$this->db->select('*');
$this->db->from('logs AS l');
$this->db->join('log_group_ref AS r', 'l.log_id = r.log_id');
$this->db->like('l.log_title', 'hello');
$this->db->or_like('l.log_content', 'hello');
$this->db->where('r.group_id', 1);

和这个:

SELECT * FROM logs as l
join log_group_ref as r
on l.log_id = r.log_id
where l.log_title like "%hello%"
or l.log_content like "%hello%"
and r.group_id = 1

当我运行 CI 活动记录方式时,我会得到与通用查询不同的结果。

当我故意将错误放在 CI 查询上时,例如从字段中删除一个字母以在控制台上查看错误,它会将 WHERE 子句移到 JOIN 子句之后。

我认为这会有所不同,因为我从两者那里得到了不同的结果。

知道如何解决这个问题吗?

或者我正在运行错误的查询?

更新:

根据要求,这是 CI 生成的查询:

Error Number: 1054

Unknown column 'r.group_i' in 'where clause'

SELECT `*` FROM (`logs` AS l)JOIN `log_group_ref` AS r ON 
`l`.`log_id` = `r`.`log_id`JOIN `users` AS u ON `u`.`user_id`=`l`.`log_author`WHERE 
`r`.`group_i` = '1' AND `l`.`log_title` LIKE '%at%'OR `l`.`log_content` LIKE '%at%'

Filename: C:\xampp\htdocs\done\system\database\DB_driver.php

Line Number: 330

在这里,我有意删除了最后一个 WHERE 子句中 r.group_id 中的“d”。

4

1 回答 1

0

你有一个不同,因为如果你选择它会有所不同

( someting like '%a'% or someting like '%b' ) and someting = 1
someting like '%a'% or ( someting like '%b'  and someting = 1)
someting like '%a'% or  someting like '%b'  and someting = 1

所以正如我在评论使用中所写的那样存在差异

$this->output->enable_profiler(TRUE);

要查看 CI 做了什么,您将查看查询和页面末尾以及大量 oder 数据,但要在 CI 中使用 (),您需要类似

$this->db->where('(someting like "%'.$a.'%" or someting like "%'.$b.'%" )',null,false)

我希望它有帮助

于 2013-03-07T09:06:34.850 回答