4

我有 2 个查询:

$genres = $this->db->select('Group_Concat(intGenreId) strDJGenres')
                                ->from('tblDJGenres')
                                ->where('intDJId', $this->session->userdata('non_admin_userid'))
                                ->get()
                                ->row();

            $results = $this->db->select('tblTracks.*, tblGenres.strName as strGenreName')
                                ->from('tblTracks')
                                ->join('tblGenres', 'tblTracks.intGenreId = tblGenres.intGenreId', 'left')
                                ->where_in('tblTracks.intGenreId', $genres->strDJGenres)
                                ->get()
                                ->result();

第一个查询返回一个字符串,例如

'1,2,3,4,8,6,5,7,45,66'

我在第二个查询的 where_in 子句中使用它。问题是使用这个字符串,它正在编写如下 SQL:

SELECT `tblTracks`.*, `tblGenres`.`strName` as strGenreName FROM (`tblTracks`) LEFT JOIN `tblGenres` ON `tblTracks`.`intGenreId` = `tblGenres`.`intGenreId` WHERE `tblTracks`.`intGenreId` IN ('1,2,3,4,8,6,5,7,45,66') 

使用引号将其视为单个值。我怎样才能得到第二个查询来执行我想要的呢?IE

.... where `tblTracks`.`intGenreId` IN (1,2,3,4,8,6,5,7,45,66) 
4

2 回答 2

9

可以将多个值where_in作为array.


可以使用以下方法删除字符串开头和结尾的引号trim()

$dj_genres = trim($genres->strDJGenres, "'");

然后可以将此字符串转换为字符串数组,以传递给where_in第二个查询的子句。

$dj_genres_array = explode(",", $dj_genres);

或者,如果您需要一个整数数组

$dj_genres_int_array = array_map('intval', $dj_genres_array);

您可以将结果数组添加到第二个查询中:

// ...    
->where_in('tblTracks.intGenreId', $dj_genres_array)
// ...

或者:

// ...    
->where_in('tblTracks.intGenreId', $dj_genres_int_array)
// ...
于 2013-04-05T14:00:27.697 回答
1

JLeft 给出的答案:

可以使用以下函数删除字符串开头和结尾的引号:

$dj_genres = trim($genres->strDJGenres, "'");

然后可以将此字符串转换为字符串数组,以传递给第二个查询的 where_in 子句。

$dj_genres_array = explode(",", $dj_genres);

如果你需要一个整数数组,可以这样生成:

$dj_genres_int_array = array_map('intval', $dj_genres_array);

工作得很好......谢谢JLeft

于 2014-08-20T09:22:40.600 回答