我正在尝试基于 perl 创建一个 cgi 来显示我的相册,现在我正在研究照片的排序功能。我将每张照片的信息存储在mysql中。要显示所有照片,我必须先获取信息。
这是问题所在:我希望从 mysql 获取的数据按每张照片的文件大小排序,但是 fetchrow_array() 的结果是根据插入 mysql 的时间排序的数据。
在mysql shell中,我测试了
SELECT * FROM album ORDER BY filesize;
它给出了按文件大小排序的预期结果。这是我的源代码的一部分:
#!/usr/bin/perl -w
use strict;
use CGI;
my $sort = 'filesize';
# Connect the database
my $dbh = do 'db.pl';
# Prepare to print out the pictures
my $query;
$query = $dbh->prepare("SELECT * FROM album ORDER BY ?") or die $DBI::errstr;
$query->execute($sort) or die $DBI::errstr;
# Print out all pictures
while( my @data = $query->fetchrow_array() ){
# Process fetched data
(my $id, my $user, my $filepath, my $filename, my $filesize, my $uploadtime, my $description, my $tfilepath, my $sessioninfo) = @data;
print '<fieldset>';
# Display thumbnail
print '<a href="', $filepath, '"><img src="', $tfilepath, '" title="', $description, '"></a>';
# Display filename
print '</br>';
print $filename;
print '</fieldset>';
}
# Finish printing out all fetched pictures
$query->finish;
我使用了错误的命令吗?或者我使用错误的方法来执行排序功能?感谢您的帮助!