mysql - 如何确定记录的顺序作为连接查询的结果

标签 mysql sql database join

表格(来自 http://www.tutorialspoint.com/sql/sql-using-joins.htm ) 1)客户表:

 +----+----------+-----+-----------+----------+
| ID | NAME     | AGE | ADDRESS   | SALARY   |
+----+----------+-----+-----------+----------+
|  1 | Ramesh   |  32 | Ahmedabad |  2000.00 |
|  2 | Khilan   |  25 | Delhi     |  1500.00 |
|  3 | kaushik  |  23 | Kota      |  2000.00 |
|  4 | Chaitali |  25 | Mumbai    |  6500.00 |
|  5 | Hardik   |  27 | Bhopal    |  8500.00 |
|  6 | Komal    |  22 | MP        |  4500.00 |
|  7 | Muffy    |  24 | Indore    | 10000.00 |
+----+----------+-----+-----------+----------+

2) 订单表:

+-----+---------------------+-------------+--------+
|OID  | DATE                | CUSTOMER_ID | AMOUNT |
+-----+---------------------+-------------+--------+
| 102 | 2009-10-08 00:00:00 |           3 |   3000 |
| 100 | 2009-10-08 00:00:00 |           3 |   1500 |
| 101 | 2009-11-20 00:00:00 |           2 |   1560 |
| 103 | 2008-05-20 00:00:00 |           4 |   2060 |
+-----+---------------------+-------------+--------+

内连接查询是:

SELECT ID, NAME, AGE, AMOUNT
        FROM CUSTOMERS, ORDERS
        WHERE  CUSTOMERS.ID = ORDERS.CUSTOMER_ID;

显示的结果是:

+----+----------+-----+--------+
| ID | NAME     | AGE | AMOUNT |
+----+----------+-----+--------+
|  3 | kaushik  |  23 |   3000 |
|  3 | kaushik  |  23 |   1500 |
|  2 | Khilan   |  25 |   1560 |
|  4 | Chaitali |  25 |   2060 |
+----+----------+-----+--------+

我的问题:结果表是根据“ORDERS”表明确排序的,即结果表中 ID 列的排序是 3,3,2,4 acc。到订单表。为什么 ID 的排序不符合 CUSTOMERS 表,即为什么结果不符合

ID
2
3
3
4

以及相应的值。是否有某种规则?

最佳答案

您应该使用如下 order by

SELECT ID, NAME, AGE, AMOUNT
        FROM CUSTOMERS, ORDERS
        WHERE  CUSTOMERS.ID = ORDERS.CUSTOMER_ID order by ID asc;

关于mysql - 如何确定记录的顺序作为连接查询的结果,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25011306/

相关文章:

php - 通过PHP将SQL转换为HTML表-为什么不起作用?

mysql - 如何在 SQL 表中表示 X 和 Y 轴数据

mysql - 如何在mysql中使用in关键字时获取有序结果集

php - 使用多个 select 语句批量插入

mysql - 自定义电子商务 Web 应用程序中的关系数据库问题

php - MySQL 单例类与递归函数冲突(PHP)

mysql - 只有在mysql中不存在该过程时才创建存储过程

mysql - 如何根据另一个表的值使用 MySQL 选择一个值?

SQL Server 2005 - 返回带有存储过程的多个表是否有任何重大负面影响?

mysql - mysql/Innodb崩溃重启的主要原因