我对 sql 还很陌生,所以我很抱歉这是否是一个愚蠢的问题,但我已经绞尽脑汁一段时间了,在没有答案的情况下搜索谷歌,所以这是我最后的手段。
我一直在尝试在我的个人网站上创建一个最畅销的页面,该页面在过去 30 天内销售最畅销的商品。
使用数据库有两个表:产品和产品订单
产品总销量、总销量等相关信息,但产品订单有产品销售日期。
所以在我看来,产品唯一适合的就是标题、图片和价格。
所以我现在查看产品订单,其中包含产品 ID 和销售日期。
所以我的问题是如何对 id 进行分组,
例如,如果我有:
productid = 42, datesold = 2013-11-08 21:11:10
productid = 11, datesold = 2013-11-08 21:09:10
productid = 42, datesold = 2013-11-08 21:06:10
productid = 2, datesold = 2013-11-07 21:11:10
productid = 11, datesold = 2013-11-06 21:11:10
我将如何退回它,所以它基本上说
productid = 42 (sold 2 times)
productid = 11 (sold 2 times)
productid = 2 (sold 1 time)
甚至可以做这样的事情吗?
另外我认为我有左连接显示它但仍然无法获得组计数的逻辑
这是我的左连接逻辑,请记住它将是 pdo,这只是在我准备语句之前显示查询;)
$todaysdate = date('Ymd h:i:s', strtotime("现在 - 30 天前"));
SELECT * FROM product_order LEFT JOIN product ON product_order.productId=product.id
WHERE product_order.modifiedDate >= $todaysdate AND product_order.status = 2
ORDER BY product_order.modifiedDate DESC;
提前感谢您提供的任何帮助:)
编辑::::::::::::::::::::::::::::::::::::
我已经改变了它,但由于某种原因它抛出了一个重大错误:
SQLSTATE[42000]:语法错误或访问冲突:1064 您的 SQL 语法有错误;检查与您的 MySQL 服务器版本相对应的手册,以在第 4 行堆栈跟踪的“15:14:13 AND product_order.status = 2 AND product.status = 1 GROUP BY product_o”附近使用正确的语法:
这是sql查询:
$todaysdate = date('Y-m-d G:i:s', strtotime("now - 30 days ago"));
SELECT product.id, product.name, product.picture, product.mainImage, product_option_detail.price, COUNT(product_order.productId) AS NumberOfOrders FROM product_order
RIGHT JOIN product ON product_order.productId=product.id
INNER JOIN product_option_detail ON product_order.productId=product_option_detail.productId
WHERE product_order.modifiedDate >= {$createddate} AND product_order.status = 2 AND product.status = 1
GROUP BY product_order.productId
ORDER BY NumberOfOrders DESC;