如何列出数据库中最常订购的商品?

How to make a list of most ordered item on database?

我有一个类似 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';
}

    }  

一个index.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';

以及我想要 post "Best Selling Prints":

的视图
 <div>

<h2>Top Prints</h2>
    <ol>
       <li>1st print most bought</li>
       <li>2nd</li>
       <li>3rd</li>
    </ul>

现在,我的数据库有一个名为 "print_for_sale" 的 table,其中有 print_id 和 sale_id,我可以在其中查看每张印刷品的购买数量.

我该怎么做?我迷路了!

抱歉这么久post。

使用 COUNT 和 GROUP BY 获取所有印刷品及其销售数量的列表:

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

也就是说,如果我理解你的 table 是对的。