0

在为朋友建立网站时,数据库中有一行包含 39 个图像字段。在该字段中是图像的名称(例如“my_image.jpg”)而不是图像本身(BLOB)。即:image_01、image_02、image_03 等等。

我让 PHP 生成 while 循环并毫无问题地获取信息。我正在尝试将所有图像放入一个数组中,以便可以将该行中的图片显示为图库。

我希望有人可以为我提供前进的道路,因为我尝试过但没有成功。

从while循环:

$MEDIA_IMAGE_00 = $row["MEDIA_IMAGE_00"];
$MEDIA_IMAGE_01 = $row["MEDIA_IMAGE_01"];
$MEDIA_IMAGE_02 = $row["MEDIA_IMAGE_02"];

我需要回应

["propimages/$MEDIA_IMAGE_00", "", "", "$MEDIA_IMAGE_TEXT_00"],
["propimages/$MEDIA_IMAGE_01", "", "", "$MEDIA_IMAGE_TEXT_01"],
["propimages/$MEDIA_IMAGE_02", "", "", "$MEDIA_IMAGE_TEXT_02"]

让他们在画廊中展示。

编辑:

while($row = mysql_fetch_array($sqlSearch)){ 
   $propid = $row["propid"];
   $MEDIA_IMAGE_00 = $row["MEDIA_IMAGE_00"];
   $MEDIA_IMAGE_01 = $row["MEDIA_IMAGE_01"];
   $MEDIA_IMAGE_02 = $row["MEDIA_IMAGE_02"];

   $MEDIA_IMAGE_33 = $row["MEDIA_IMAGE_33"];
   $MEDIA_IMAGE_34 = $row["MEDIA_IMAGE_34"];
   $MEDIA_IMAGE_35 = $row["MEDIA_IMAGE_35"];
}
4

2 回答 2

1

我假设这$propid是标识行本身的内容,并且“MEDIA_IMAGE_TEXT”在同一行中可用:

$properties = array();
while ($row = mysql_fetch_array($sqlSearch)) {
    $propid = $row["propid"];
    $images = array();
    for ($i = 0; $i <= 35; ++$i) {
        $imageId = "MEDIA_IMAGE_" . str_pad($i, 2, '0', STR_PAD_LEFT);
        if ($row[$imageId]) {
            $images[] = array(
                $row[$imageId],
                '',
                '',
                $row["MEDIA_IMAGE_TEXT_" . str_pad($i, 2, '0', STR_PAD_LEFT)],
            );
        }
    }
    $properties[] = array(
        'id' => $propid,
        'images' => $images,
    );

    echo json_encode($properties);

它生成一个属性列表,每个属性都有一个 id 和一个图像数组;每张图片都包含位置(我猜)和标题/描述。

于 2012-05-27T09:55:34.760 回答
0

为什么不在你的 while 循环中构建一个图像数组?

$images = array()

$i = 0;

While(...) {
$images[] = $row["MEDIA_IMAGE_0$i"];
$i++;
[...]
}

你得到一个数组,你可以在 foreach 中使用并显示你的行。我认为按照应该可行的原则;)

于 2012-05-27T08:17:42.433 回答