- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我在下面有这个查询。所有表的关系都是一对一的关系,除了 ASSOCPRODUCTS 表,其中每个订单有两种产品。一切似乎都工作正常,除了我的查询仅返回一行,因此,当实际上有两个产品 ID 时,只会返回一个产品 ID。我明白为什么它只拉一个,因为每个 orderID 只有一个订单,但每个契约(Contract)有两个关联产品,我需要获取每个产品 id。在 Assocproducts 表中,每个产品都有自己的行,因为它与契约(Contract)表是一对多的。
是否可以使用内部联接获取该信息,或者我是否需要运行另一个查询?
$orderid = $_POST['orderid'];
$res = mysql_query ("
SELECT company.name as cname,
orders.datemade as datemade
orders.p1quantity as p1q,
orders.p2quantity as p2q,
assocproducts.productid as pid,
assocproducts.price as pprice,
inventory.name as pname,
inventory.quantity as pquantity
FROM orders
INNER JOIN contracts ON (contracts.id = orders.contractid)
INNER JOIN company ON (contracts.companyid = company.id)
INNER JOIN assocproducts ON (contracts.id = assocproducts.contractid)
INNER JOIN inventory ON (assocproducts.productid = inventory.id)
WHERE orders.id = " . $orderid);
$order = mysql_fetch_assoc($res);
如果我需要提供更多信息,请告诉我。
$order 不在循环中,因为我只需要显示该特定订单的订单信息。这是点击时的 AJAX 触发器。
谢谢!
最佳答案
我认为您说只返回一行是错误的。我创建了一个新架构,仅包含查询中使用的列,用示例数据填充它并获取所有匹配结果。我认为问题在于您对 mysql_fetch_assoc() 函数的使用。 this function 的语义很清楚:
Returns an associative array of strings that corresponds to the fetched row, or FALSE if there are no more rows.
所以我的猜测是你再也不会调用mysql_fetch_assoc()
了。
考虑到 INNER JOIN
的语义和您的数据约束,您的查询将始终生成 0 或 1 行。如果您不知道原因 - 请阅读 SQL JOIN types & behavior 。因此,您有两种选择来获取订单详细信息和相关产品的信息:
保留现有查询,但通过迭代所有行来更改从中检索数据的方式(请注意,订单信息将出现在所有提取的行中,并且对于所有行都相同):
$firstRow = true;
while (($order_product = mysql_fetch_assoc($res)) !== FALSE) {
if ($firstRow) {
// do something with order info
// but don't repeat it for consecutive rows
$firstRow = false;
}
// do something with currently fetched associated product info
}
这是一个品味问题,但我会选择第一个选项 - 它看起来不那么老套。
关于php - 多个内部联接和一对一//一对多关系,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13708277/
我有一张维护要求表和相关的每月执行频率 维护 +----------+------+ | maint_id | freq | +----------+------+ | 1 | 6
我目前有这些表: CREATE TABLE #SECURITY_TEMP (ID CHAR(30)) CREATE TABLE #SECURITY_TEMP_PRICE_HISTORY (ID CHA
我有一张维护要求表和相关的每月执行频率 维护 +----------+------+ | maint_id | freq | +----------+------+ | 1 | 6
我有一个如下所示的表格 表tbl_veh VIN Record DateChange 11223344 123A 6/24/2012 11223344
我的应用程序的数据模型 群组有很多用户 用户所属组 用户有很多打卡 冲床属于用户 冲床属于PayPeriod PayPeriod hasMany Punch 找电话 $groups = $this->
使用 Join 或 GroupJoin,是否有任何方法可以为父表和子表中的字段生成聚合值。给定一个 Orders 表和一个 OrderDetails 表,使用下面的 2 个步骤我可以从 Orders
我有一个包含用户 ID 和用户名的用户表。另一个表有一个兴趣列表,包括兴趣和姓名。第三个表是一个连接表,包含 userid 和interestid。 对于每对用户,我想获取他们共同兴趣的数量。我尝试了
假设我有下表: 表A a_name | age | country Jordan | 5 | Germany Molly | 6 | Spain Paris | 7 | France John | 7
数据源是 CSV 文件的集合,因此没有实际的数据库。这是与日本已有数十年历史的遗留系统的集成。 我有一个 c# 函数需要将 2 个 DataTables 和 2 个列名作为参数。我的函数需要对这两个数
我有一种情况要在具有数据的elasticsearch中编写搜索查询,如下所示 {id:"p1",person:{name:"name",age:"12"},relatedTO:{id:"p2"}} {
我想创建具有父子关系的文档。 我有如下数据 parent_id = null的父文档数据 { "id": 1, "work
我有以下按预期工作的 SQL: SELECT p.ACCT_ID AS [Acct], a.ACCT_NAME AS [AcctName], p.PD_NO AS [Period],
我想使用 CriteriaBuilder 在连接 2 个表的位置进行查询。在 MySQL 中,我尝试进行的查询如下所示: SELECT * FROM order LEFT JOIN item ON o
使用带有collection标签的域Service,如下所示: @Entity public class Service extends AbstractEntity { private st
我有一个解决方案,通过连接同一个表两次,但我想知道以下查询是否可以优化? select oc.name as father_occupation, o.name as mother_occupatio
我知道除了知道什么是“最喜欢的编程卡通”之外,stackoverflow 会对我有所帮助:P 这是接受的答案: Bill Karwin 感谢大家的帮助(我想给你们加倍投票) 我的查询结果是这样的(这是
我有两个表格,可以在附图中看到。 表 A 包含部门、月份和平均。 表 B 包含月份、年份、RangeStart、RangeEnd 和 颜色。 如果您查看表 B 的屏幕截图,您将看到每个月都有绿色、黄色
我有一个 Linq to sql 如下: var members=db.Members.Include(x=> x.Contact).Count(); 现在由于一些错误的数据,我的成员中的所有联系人都
我有两个表(用户和帖子),我想写出一个用户的所有帖子(以及其他内容)。我想我应该使用 JOIN 和 WHERE,但我在使用 WHERE 时遇到错误。 这是我的代码: SELECT username,
在 Hibernate 是我的持久性提供者的项目中,我可以使用“join fetch”表达式发出查询,Hibernate 将生成反射(reflect)该内容的 SQL:包含使用有效比较路径的联接表达式
我是一名优秀的程序员,十分优秀!