php - 从 mysql 表中提取唯一值并按出现次数排序

标签 php mysql

我在这方面遇到了一些麻烦,我找到了如何从多个列中获取唯一值,并且我知道如何正常排序,但我似乎无法混合两者

原始sql语句在这里:

$sql="SELECT DISTINCT UserID, UserIP FROM Visits WHERE PageID='".$_GET['p']."'";

它只获取两个值都是唯一的第一个实例,因此执行“mysql_numrows”操作不起作用。

这是来自获取数组循环内部,它可以很好地计算出现次数,但此时排序有点太晚了

$sql5="SELECT Date, VisitID FROM Visits WHERE PageID='".$_GET['p']."' AND UserID='".$userid."' AND UserIP='".$userip."' ORDER BY Date";
$result5 = mysql_query($sql5);
$num5 = mysql_numrows($result5);

基本上,它应该根据两列获取唯一值,计算出现的次数,按计数排序,然后如果可能的话还可能按最高匹配日期排序

任何建议都会很棒,干杯:)
而且这只是一个个人网站,我实际上并没有对这些信息做任何事情,只是想学习更多的 php

最佳答案

尝试使用GROUP BY,如下所示:

SELECT UserID, UserIP FROM Visits 
WHERE PageID = ###
GROUP BY UserID, UserIP
ORDER BY COUNT(*) DESC, max(`Date`) DESC

关于php - 从 mysql 表中提取唯一值并按出现次数排序,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20964481/

相关文章:

Java 语句,加载数据返回生成的键

mysql - 多次 Union 和 Join 操作后求和列

php - Codeception验收测试同一页面上不同形式的完全相同的按钮

javascript - Yii ajax 验证不显示错误消息

php - 如何使用 PHP 在 Linux/Apache 上使用 Windows 身份验证连接到 SQL Server?

php - 选择两列中不同但按一分组

php - 在来自数据库的回显中显示文本区域格式

PHP 转义用户输入的文件名

java - Spring Boot 中 Repository 默认 "findById"函数的运行时是多少?

MySQL 错误 1045 (28000) : Access denied for user 'bill' @'localhost' (using password: YES)