MySQL の複数フィールドの条件付き並べ替え?MySQL の順序は、クエリ ステートメント/関数を昇順で降順で並べ替えます

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 チャンネルにぜひご参加ください。

気に入ったらシェアして「いいね!」してください!あなたのシェアと「いいね!」が私たちの継続的なモチベーションです。

 

发表评论

バグのあるボックスの内容は公開されません。 必須アイテム * 标注

上へスクロール