我正在尝试按照状态= 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}' ";
答案 0 :(得分:1)
更新了SQL以限制在同一患者和病例中
如果我正确理解您的问题,您可以让SQL为您完成工作。不需要循环或数组。以下SQL应返回单行。不幸的是,我目前没有办法测试这个,所以我希望SQL中没有错误。这个SQL将替换你的$ sql_2:
SELECT image1.patientid
,image1.caseid
,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
,patientid
,caseid
,image_name
,comments
,status
,mod_date
FROM images
WHERE patientid = '{$patientid}'
AND caseid = '{$caseid}'
AND image_name like '%{$group_name}%'
ORDER BY 1 ASC, mod_date DESC
LIMIT 1
) image1
LEFT OUTER
JOIN images image2
ON image1.status > 0
AND image2.patientid = image1.patientid
AND image2.caseid = image1.caseid
AND image2.status = 0
AND image2.mod_date > image1.mod_date
AND image2.image_name like '%{$group_name}%'
ORDER BY image2.mod_date DESC
LIMIT 1
返回的行包含10列:
i1_ *列来自第一张图片,而i2_ *列来自第二张图片(如果有的话)。如果存在评级图像,则i1_ *将表示最近修改的评级图像,而i2_ *将表示在i1_ *图像之后修改的最近修改的未评级图像。如果没有在评级图像之后修改的未评级图像,则i2_ *将为NULL。如果没有评级图像,那么i1_ *将代表最近修改的未评级图像,i2_ *将为NULL。
<强>更新强>
以下是我看到它被使用的方式。
$sql_2 = "SELECT image1.patientid
,image1.caseid
,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
,patientid
,caseid
,image_name
,comments
,status
,mod_date
FROM images
WHERE image_name like '%{$group_name}%'
ORDER BY 1 ASC, mod_date DESC
LIMIT 1
) image1
LEFT OUTER
JOIN images image2
ON image1.status > 0
AND image2.patientid = image1.patientid
AND image2.caseid = image1.caseid
AND image2.status = 0
AND image2.mod_date > image1.mod_date
AND image2.image_name like '%{$group_name}%'
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']
);
}
}
取代:
if (!isset($imageGroup[$groupName]) {
$imageGroup[$groupName] = array();
$sql_2 = "SELECT * FROM images WHERE image_name like '%".$groupName."%'";
$result_2 = mysql_query($sql_2,$connection);
while($row - mysql_fetch_assoc($result_2)) {
$imageGroup[$groupName][] = array( // sort each field as
'image_name' => $row['image_name'],
'comments' => $row['comments'],
'status' => $row['status'], // determines whether image is rated or unrated
'mod_date' => $row['mod_date'] // the date we need to compare
);
}
}
else {
for ($i=0; $i <sizeof($imageGroup[$groupName]); $i++) {
if ($imageGroup[$groupName][$i]['status'] == 0) {
// compare??
}
if ($imageGroup[$groupName][$i]['status'] !== 0) {
// compare??
}
}
}
完成后,$imageGroup[$groupName]
将包含一个包含一个或两个元素的数组。
希望这是目标。 :)
答案 1 :(得分:0)
以下是您可以使用的旧代码:
class ProductHelper {
// sort products by name
static function sort_name_asc($a,$b) {
return strcmp($a['name'],$b['name']);
}
static function sort_name_desc($a,$b) {
return strcmp($b['name'],$a['name']);
}
// sort products by price
static function sort_price_asc($a,$b) {
return $a['price'] > $b['price'];
}
static function sort_price_desc($a,$b) {
return $a['price'] < $b['price'];
}
// sort products by last update
static function sort_date_asc($a,$b) {
return $a['created'] > $b['created'];
}
static function sort_date_desc($a,$b) {
return $a['created'] < $b['created'];
}
// sort array by sort_order
static function sort_sort_order($a,$b) {
return $a['sort_order'] > $b['sort_order'];
}
function sortProducts($products, $sortMode) {
if (!is_array($products)) return null;
usort($products, 'ProductHelper::sort_'.$sortMode);
return $products;
}
}
使用示例:
$ProductHelper = new ProductHelper();
$ProductHelper->sortProducts($array_of_products, "date_desc");