我有一个类似mvc的商店。
我想列一张买得最多的物品清单(在这种情况下是印刷品,因为这是印刷品商店)。
我发现这非常困难,特别是因为我对php/mysql和这个mvc结构非常陌生……我希望这不是个坏问题。
我有这样一个model.php:
<?php
class model {
private $conn;
function __construct() {
$server = "localhost";
$login = "root";
$pass = "";
$db = "printstore";
$conn = new mysqli($server, $login, $pass, $db);
if ($conn->connect_error) {
die("Connection failed: " . $conn->connect_error);
} else {
$this->conn = $conn;
}
}
function __destruct() {
$this->conn->close();
}
function buildArr($result) {
$arr = array();
while ($row = $result->fetch_assoc()) {
array_push($arr, $row);
}
return $arr;
}
}
一个controller.php:
<?php
include 'model.php';
class Controller {
private $model;
function __construct() {
$this->model = new model();
}
function home() {
include 'views/home.php';
}
}
索引.php:
<?php
session_start();
include 'controller.php';
define("BASE_URL", 'http://' . $_SERVER['SERVER_NAME'] . '/printstore2/index.php/');
define("MAIN_BASE_URL", 'http://' . $_SERVER['SERVER_NAME'] . '/printstore2/');
$controller = new controller();
include 'views/templates/header.php';
if (isset($_SERVER['PATH_INFO'])) {
$url = explode("/", $_SERVER['PATH_INFO']);
$function_name = $url[1];
if (isset($url[1]) && $url[1] !== "") {
if (isset($url[2])) {
$controller->$function_name($url[2]);
} else {
$controller->$function_name();
}
} else {
$controller->home();
}
} else {
include 'views/home.php';
}
include 'views/templates/footer.php';
以及我想发布“畅销印刷品”的视图:
<div>
<h2>Top Prints</h2>
<ol>
<li>1st print most bought</li>
<li>2nd</li>
<li>3rd</li>
</ul>
现在,我的数据库中有一个名为“print_for_sale”的表,其中有print_id和sale_id,在这里我可以看到每一张照片被购买了多少张。
我该怎么做?我太迷路了!
对不起,我的职位太长了。
最佳答案
使用计数和分组方式
要获得所有指纹与销售数量的列表:
SELECT fk_print_id as printId, COUNT(print_for_sale_id) as saleCount
FROM print_for_sale
GROUP BY fk_print_id
ORDER BY saleCount DESC
也就是说,如果我听懂你的话。
关于php - 如何列出数据库中订购最多的商品?,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/28709485/