記事ディレクトリ
MySQLマルチフィールドの条件付きソート?MySQL クエリステートメント/関数の降順および昇順による並べ替え
MySQL ソート
SQL SELECT ステートメントを使用して MySQL テーブルからデータを読み取ることはわかっています。
読み取ったデータをソートする必要がある場合は、MySQL の ORDER BY 句を使用して、どのフィールドをどの方法で並べ替えるかを設定し、検索結果を返します。
文法
以下は、データを返す前に、ORDER BY 句を使用してクエリ データを並べ替える SQL SELECT ステートメントです。
SELECT field1, field2,...fieldN table_name1, table_name2... ORDER BY field1, [field2...] [ASC [DESC]]
- 任意のフィールドを並べ替え条件として使用して、並べ替えられたクエリ結果を返すことができます。
- 複数のフィールドを並べ替えに設定できます。
- ASC または DESC キーワードを使用して、クエリ結果を昇順または降順で並べ替えるように設定できます。デフォルトでは、昇順です。
- WHERE...LIKE 句を追加して条件を設定できます。
コマンド プロンプトで ORDER BY 句を使用する
次の例では、SQL SELECT ステートメントで ORDER BY 句を使用して、MySQL データ テーブル chenweiliang_tbl のデータを読み取ります。
インスタンス
以下の例を試してみてください。結果は昇順と降順でソートされます。
SQLソート
mysql> use chenweiliang; Database changed mysql> SELECT * from chenweiliang_tbl ORDER BY submission_date ASC; +-----------+---------------+---------------+-----------------+ | chenweiliang_id | chenweiliang_title | chenweiliang_author | submission_date | +-----------+---------------+---------------+-----------------+ | 3 | 学习 Java | chenweiliang.com | 2015-05-01 | | 4 | 学习 Python | chenweiliang.com | 2016-03-06 | | 1 | 学习 PHP | 陈沩亮博客 | 2017-04-12 | | 2 | 学习 MySQL | 陈沩亮博客 | 2017-04-12 | +-----------+---------------+---------------+-----------------+ 4 rows in set (0.01 sec) mysql> SELECT * from chenweiliang_tbl ORDER BY submission_date DESC; +-----------+---------------+---------------+-----------------+ | chenweiliang_id | chenweiliang_title | chenweiliang_author | submission_date | +-----------+---------------+---------------+-----------------+ | 1 | 学习 PHP | 陈沩亮博客 | 2017-04-12 | | 2 | 学习 MySQL | 陈沩亮博客 | 2017-04-12 | | 4 | 学习 Python | chenweiliang.com | 2016-03-06 | | 3 | 学习 Java | chenweiliang.com | 2015-05-01 | +-----------+---------------+---------------+-----------------+ 4 rows in set (0.01 sec)
chenweiliang_tbl テーブルのすべてのデータを読み取り、submission_date フィールドで昇順に並べ替えます。
PHP スクリプトで ORDER BY 句を使用する
PHP 関数 mysqli_query() と同じ SQL SELECT コマンドを ORDER BY 句とともに使用して、データを取得できます。
この関数は、SQL コマンドを実行し、PHP 関数 mysqli_fetch_array() を介してクエリされたすべてのデータを出力するために使用されます。
インスタンス
次の例を試してみてください。クエリされたデータは、submission_date フィールドの降順で返されます。
MySQL ORDER BY テスト:
<?
php
$dbhost = 'localhost:3306'; // mysql服务器主机地址
$dbuser = 'root'; // mysql用户名
$dbpass = '123456'; // mysql用户名密码
$conn = mysqli_connect($dbhost, $dbuser, $dbpass);
if(! $conn )
{
die('连接失败: ' . mysqli_error($conn));
}
// 设置编码,防止中文乱码
mysqli_query($conn , "set names utf8");
$sql = 'SELECT chenweiliang_id, chenweiliang_title,
chenweiliang_author, submission_date
FROM chenweiliang_tbl
ORDER BY submission_date ASC';
mysqli_select_db( $conn, 'chenweiliang' );
$retval = mysqli_query( $conn, $sql );
if(! $retval )
{
die('无法读取数据: ' . mysqli_error($conn));
}
echo '<h2>陈沩亮博客 MySQL ORDER BY 测试<h2>';
echo '<table border="1"><tr><td>教程 ID</td><td>标题</td><td>作者</td><td>提交日期</td></tr>';
while($row = mysqli_fetch_array($retval, MYSQL_ASSOC))
{
echo "<tr><td> {$row['chenweiliang_id']}</td> ".
"<td>{$row['chenweiliang_title']} </td> ".
"<td>{$row['chenweiliang_author']} </td> ".
"<td>{$row['submission_date']} </td> ".
"</tr>";
}
echo '</table>';
mysqli_close($conn);
?>Hope Chen Weiliang ブログ ( https://www.chenweiliang.com/ ) は、「MySQL の複数フィールドの条件付き並べ替え? 降順および昇順のクエリ ステートメント/関数による MySQL の順序」を共有しました。
この記事のリンクを共有することを歓迎します。https://www.chenweiliang.com/cwl-476.html
さらに多くの隠されたトリックのロックを解除するには、Telegram チャンネルにぜひご参加ください。
気に入ったらシェアして「いいね!」してください!あなたのシェアと「いいね!」が私たちの継続的なモチベーションです。