การเรียงลำดับตามเงื่อนไขหลายช่องของ MySQL หรือไม่ ลำดับ MySQL โดยคำสั่ง/ฟังก์ชันแบบสอบถามจากมากไปหาน้อยและจากน้อยไปมาก

MySQLการเรียงลำดับตามเงื่อนไขแบบหลายช่อง?MySQL เรียงลำดับจากมากไปหาน้อยคำสั่ง/ฟังก์ชันจากมากไปน้อย

MySQL sort

เรารู้ว่าจะใช้คำสั่ง SQL SELECT เพื่ออ่านข้อมูลจากตาราง MySQL

ถ้าเราต้องการเรียงลำดับข้อมูลที่อ่าน เราสามารถใช้ MySQL's สั่งโดย เพื่อกำหนดฟิลด์ที่คุณต้องการเรียงลำดับตามวิธีการ แล้วส่งกลับผลการค้นหา

ไวยากรณ์

ต่อไปนี้คือคำสั่ง SQL SELECT ที่ใช้คำสั่งย่อย ORDER BY เพื่อเรียงลำดับข้อมูลการสืบค้นก่อนส่งคืนข้อมูล:

SELECT field1, field2,...fieldN table_name1, table_name2...
ORDER BY field1, [field2...] [ASC [DESC]]
  • คุณสามารถใช้เขตข้อมูลใดก็ได้เป็นเงื่อนไขการเรียงลำดับเพื่อส่งกลับผลลัพธ์ของคิวรีที่เรียงลำดับ
  • คุณสามารถตั้งค่าหลายฟิลด์เพื่อจัดเรียง
  • คุณสามารถใช้คีย์เวิร์ด ASC หรือ DESC เพื่อตั้งค่าผลลัพธ์ของคิวรีที่จะเรียงลำดับจากน้อยไปมากหรือจากมากไปน้อยโดยค่าเริ่มต้น จะอยู่ในลำดับจากน้อยไปมาก
  • คุณสามารถเพิ่มคำสั่ง WHERE...LIKE เพื่อกำหนดเงื่อนไข

การใช้คำสั่ง ORDER BY ในพรอมต์คำสั่ง

ต่อไปนี้จะใช้คำสั่ง ORDER BY ในคำสั่ง SQL SELECT เพื่ออ่านข้อมูลในตารางข้อมูล MySQL chenweiliang_tbl:

ตัวอย่าง

ลองดูตัวอย่างด้านล่างและผลลัพธ์จะถูกจัดเรียงจากน้อยไปมากและจากมากไปน้อย

SQL sort

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 และเรียงลำดับจากน้อยไปมากตามฟิลด์ submit_date


การใช้คำสั่ง ORDER BY ในสคริปต์ PHP

คุณสามารถใช้ฟังก์ชัน PHP mysqli_query() และคำสั่ง SQL SELECT เดียวกันกับคำสั่งย่อย ORDER BY เพื่อรับข้อมูล

ฟังก์ชันนี้ใช้เพื่อรันคำสั่ง SQL แล้วส่งออกข้อมูลที่สอบถามทั้งหมดผ่านฟังก์ชัน PHP mysqli_fetch_array()

ตัวอย่าง

ลองตัวอย่างต่อไปนี้ ข้อมูลที่สอบถามจะถูกส่งคืนในลำดับจากมากไปน้อยของฟิลด์ submit_date

MySQL สั่งซื้อโดยการทดสอบ:

<?
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);
?>

หวัง Chen Weiliang บล็อก ( https://www.chenweiliang.com/ ) แชร์ "MySQL multi-field conditional sorting? MySQL order by descending and ascending query/function" ซึ่งเป็นประโยชน์กับคุณ

ยินดีต้อนรับสู่การแบ่งปันลิงค์ของบทความนี้:https://www.chenweiliang.com/cwl-476.html

ยินดีต้อนรับสู่ช่อง Telegram ของบล็อกของ Chen Weiliang เพื่อรับข่าวสารล่าสุด!

🔔 เป็นคนแรกที่ได้รับ "คู่มือการใช้งานเครื่องมือ AI การตลาดเนื้อหา ChatGPT" อันทรงคุณค่าในไดเรกทอรีด้านบนของช่อง! 🌟
📚 คู่มือนี้มีคุณค่ามหาศาล 🌟 นี่เป็นโอกาสที่หายาก อย่าพลาด! ⏰⌛💨
แชร์และชอบถ้าคุณชอบ!
การแบ่งปันและไลค์ของคุณเป็นแรงจูงใจอย่างต่อเนื่องของเรา!

 

发表评论

ที่อยู่อีเมลของคุณจะไม่ถูกเผยแพร่ 必填项已用 * 标注