我试图在状态= 0(未评级图像)和状态!= 1(评级图像)的多维数组中按修改日期降序(意思是最新的第一个)进行排序。
是否可以对数组进行排序,以便前 2 个遵循以下逻辑:
If (there are multiple versions of an image)
If (there is a version that has been rated)
If (there is a new unrated version of the image)
Display (the most recent version that has a rating) and
(the most recent unrated version) as top 2 of array
Else
Display (the most recent version that has a rating) as top 1
Else
Display (the most recent unrated version) as top 1
Else
Display (the only version) as top 1
下面是我更新的 PHP 代码(2013 年 9 月 6 日更新):
updateImageDisplayStatus($caseID,$patientID);
function updateImageDisplayStatus($caseid,$patientid) {
$connection = getMySqlConnection();
$sql = "SELECT image_name FROM images WHERE patientid = '{$patientid}' AND caseid = '{$caseid}' ";
$imageGroup = array();
$result = mysql_query($sql,$connection);
while($row = mysql_fetch_assoc($result)) {
$fileName = $row['image_name'];
$tmpName = $row['image_name'];
list($leftN,$rightN) = explode($caseid."_",$tmpName);
//$spltName = explode('_',$rightN);
$shortFileName = $rightN;
list($noExtensionFileName,$extension) = explode('.',$shortFileName);
//$extension = '.nii.gz';
list($groupName,$appendDate) = explode('_',$noExtensionFileName);
// echo $groupName = just the original name.
$sql_2 = "SELECT image1.image_name as i1_image_name
,image1.comments as i1_comments
,image1.status as i1_status
,image1.mod_date as i1_mod_date
,image2.image_name as i2_image_name
,image2.comments as i2_comments
,image2.status as i2_status
,image2.mod_date as i2_mod_date
FROM (SELECT CASE WHEN status = 0 THEN 1 ELSE 0 END as rated
,image_name
,comments
,status
,mod_date
FROM images
WHERE image_name like '%{$groupName}%'
ORDER BY 1 ASC, mod_date DESC
LIMIT 1
) image1
LEFT OUTER
JOIN images image2
ON image1.status > 0
AND image2.status = 0
AND image2.mod_date > image1.mod_date
AND image2.image_name like '%{$groupName}%'
AND patientid = '{$patientid}' AND caseid = '{$caseid}'
ORDER BY image2.mod_date DESC
LIMIT 1";
$result_2 = mysql_query($sql_2,$connection);
if($row = mysql_fetch_assoc($result_2)) {
$imageGroup[$groupName] = array();
$imageGroup[$groupName][] = array(
'image_name' => $row['i1_image_name'],
'comments' => $row['i1_comments'],
'status' => $row['i1_status'],
'mod_date' => $row['i1_mod_date']
);
if ( !empty( $row['i2_image_name'] ) ) {
$imageGroup[$groupName][] = array(
'image_name' => $row['i2_image_name'],
'comments' => $row['i2_comments'],
'status' => $row['i2_status'],
'mod_date' => $row['i2_mod_date']
);
}
}
echo "Group $groupName:<br />";
echo "Size of Group:".sizeof($imageGroup[$groupName]).'<br />';
echo $imageGroup[$groupName][0]['image_name'].'<br />';
echo $imageGroup[$groupName][1]['image_name'].'<br />';
}
}
更新:
感谢@gwc 建议让 SQL 完成工作。我忘了补充,搜索和排序的 1-2 幅图像必须在指定的 $caseid 和 $patientid 内。结果,第一条sql语句应该是:$sql = "SELECT image_name FROM images WHERE patientid = '{$patientid}' AND caseid = '{$caseid}' ";