ไดเรกทอรีบทความ
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 เพื่อรับข่าวสารล่าสุด!
📚 คู่มือนี้มีคุณค่ามหาศาล 🌟 นี่เป็นโอกาสที่หายาก อย่าพลาด! ⏰⌛💨
แชร์และชอบถ้าคุณชอบ!
การแบ่งปันและไลค์ของคุณเป็นแรงจูงใจอย่างต่อเนื่องของเรา!