MySQL クエリで予期しない結果が得られました。投稿のタイトルで自然に並べたいです(WordPressを実行していますが、これは関係ないと思います)。
アイデアを与えるために発生するタイトルの例を次に示します。
1-1-1a
1-13-5j
7-1
9-1-2
12-13-2a
私はかなりの調査を行い、私が使用したかった結果に最も近いものを使用しました
ORDER BY (posts.post_title+0) ASC
結果の 1 ページでまだ奇妙な結果が得られます。完全なクエリは次のとおりです。
SELECT rlt13_posts.post_title
FROM rlt13_posts
INNER JOIN rlt13_term_relationships ON (rlt13_posts.ID = rlt13_term_relationships.object_id)
INNER JOIN rlt13_postmeta ON (rlt13_posts.ID = rlt13_postmeta.post_id)
JOIN rlt13_icl_translations t ON rlt13_posts.ID = t.element_id
AND t.element_type IN ('post_rlt_rule')
JOIN rlt13_icl_languages l ON t.language_code=l.code
AND l.active=1
WHERE 1=1
AND (rlt13_term_relationships.term_taxonomy_id IN (92,417,418,419,420,421,422,423,424,425,426,427,428,429,430,431,432,433,434,435,436,437,438,439,440,441,442,443,444,445,446,447,448,449,450,451,452,453,454,455,456,457,458,501))
AND rlt13_posts.post_type = 'rlt_rule'
AND (rlt13_posts.post_status = 'publish')
AND ((rlt13_postmeta.meta_key = 'new_rule'
AND CAST(rlt13_postmeta.meta_value AS CHAR) = ''))
AND t.language_code='en'
GROUP BY rlt13_posts.ID
ORDER BY (rlt13_posts.post_title+0) ASC
そして、このクエリを実行すると、次の結果が得られます (範囲外の結果がきれいに配置されています)。
最後の 2 つの結果は、ちょっと不可解です。クエリは、他のページで期待される結果を提供します。クエリから次のステートメントを削除すると、前のクエリの下部にある 2 つの予期しない結果が自然な順序で正しく表示されることに気付きました。
このことを(文字通り)ソートするための助けがあれば幸いです!
AND (rlt13_term_relationships.term_taxonomy_id IN (92, ****))