次のコードがあります。
$language_id=$this->get_language_id($language_code);
$english_id=$this->get_language_id('en');
$query="SELECT e.label_value, t.user_id, t.votes, t.approved, t.language_value FROM labels e left outer join labels t on e.label_value=t.label_value WHERE e.language=$english_id and t.language=$language_id and (t.approved=1 or t.user_id=$user_id) and e.label_value in (select distinct label_value from labels WHERE language=$english_id order by label_value limit $start_index, 30) order by e.label_value, t.votes";
$query=$this->db->query($query);
$data=$query->result_array();
しかし、次のエラーが発生しました。
This version of MySQL doesn't yet support 'LIMIT & IN/ALL/ANY/SOME subquery'
"select distinct label_value from labels WHERE language=$english_id order by label_value offset $start limit 30"
したがって、別のクエリで次の部分を実行する必要があります。助けてください、CodeIgniter を使用してどうすればよいですか?
アップデート:
テーブルありますlabels
(label_value, language_value, language) - PK,
user_id,
timestamp,
approved,
votes
そして、ラベル t.label_value、e.label_value (存在する)、e.user_id、e.votes、e.timestamp を使用して、このテーブルからすべてのクエリを取得する必要があります (たとえば、名前は t および e)。 =e.label_value (同じラベル)、t.language=45 (英語)、e.language=24 (私の言語)、および (e.user_id=121234 または e.approved=1)。しかし、すべてのエントリが必要で、if (t.label_value!=e.label_value) NULL フィールドでこのエントリを取得する必要があります。