我想从数据库中获取查看次数最多的照片,但我不知道该如何做到这一点。这是我目前的 SQL:
SELECT * FROM photos AS p, viewers AS v
WHERE p.id = v.id_photo
GROUP BY v.id_photo
数据库:
CREATE TABLE IF NOT EXISTS `photos` (
`id` int(10) NOT NULL AUTO_INCREMENT,
`photo_filename` varchar(50) NOT NULL,
`photo_camera` varchar(150) NOT NULL,
`photo_taken` datetime NOT NULL,
`photo_resolution` varchar(10) NOT NULL,
`photo_exposure` varchar(10) NOT NULL,
`photo_iso` varchar(3) NOT NULL,
`photo_fnumber` varchar(10) NOT NULL,
`photo_focallength` varchar(10) NOT NULL,
`post_coordinates` text NOT NULL,
`post_description` text NOT NULL,
`post_uploaded` datetime NOT NULL,
`post_edited` datetime NOT NULL,
`checkbox_approxcoor` enum('0','1') NOT NULL DEFAULT '0',
PRIMARY KEY (`id`),
UNIQUE KEY `id` (`id`)
)
CREATE TABLE IF NOT EXISTS `viewers` (
`id` int(10) NOT NULL AUTO_INCREMENT,
`id_photo` int(10) DEFAULT '0',
`ipaddress` text NOT NULL,
`date_viewed` datetime NOT NULL,
PRIMARY KEY (`id`),
UNIQUE KEY `id` (`id`)
)
viewers
中的数据如下所示:
(1, 85, '3892a0ab97d6ff325f285b27b847070f', '2012-06-21 22:49:25'),
(2, 84, '3892a0ab97d6ff325f285b27b847070f', '2012-06-21 22:49:25'),
(3, 85, '3892a0ab97d6ff325f285b27b847070f', '2012-06-21 22:49:25');
数据库中的单个行,photos
了解此数据库中的行的外观:
(85, 'P1170986.JPG', 'Panasonic DMC-LX3', '2012-06-19 18:00:40', '3968x2232', '10/8000', '80', '50/10', '51/10', '', '', '2012-06-19 18:45:17', '0000-00-00 00:00:00', '0')
目前,SQL 仅打印 ID 为 84 的照片。在这种情况下,这是错误的 - 它应该打印出ID 为 85 的照片。
如何解决此问题?
提前谢谢。
您可能希望使用order by count(*) desc
查看次数最多的照片...有两种方法可以做到这一点。
简单的一个:向照片表添加一个作为计数器的字段,并在每次查看照片时更新该字段。
硬的:这将允许您将视图跟踪回用户。创建一个允许用户 ID、照片 ID 和计数器的新表。
每次用户查看新照片时,它都会与计数器一放在一起。当他或她再次查看它时,增加计数器。
然后使用分组依据和计数(用户 ID)构建一个复杂的查询有点像:
SELECT photoid , count(photoid) as howmuch FROM photostats WHERE 1 GROUP BY photoid ORDER BY howmuch DESC