@Mike_Polit

Как создать цикл записи в базу данных?

Доброй ночи!

Есть многофайловая загрузка изображений, но в БД создается только одна строка!

А нужно, чтобы все пути загружаемых файлов записывались в БД!

Вот код загрузки изображений:

function upload_image()
{
  if(isset($_FILES['user_image']))
  {
    // Count total files
    $countfiles = count($_FILES['user_image']['name']);

    for($i=0;$i<$countfiles;$i++){
      $extension = explode('.', $_FILES['user_image']['name'][$i]);
      $new_name = rand() . '.' . $extension[1];
      $destination = '../portfolio/upload/' . $new_name;
      $thumbDestination = '../portfolio/upload/thumb/' . $new_name;
      
      move_uploaded_file($_FILES['user_image']['tmp_name'][$i], $destination);
      
      resize($destination, $thumbDestination, 300);
    }
    return $new_name;
  }
}


Вот код записи в БД:
if($_POST["operation"] == "Add")
	{
		$image = '';
		if($_FILES["user_image"]["name"] != '')
		{
			$image = upload_image();
		}
		$statement = $connection->prepare("
			INSERT INTO portfolio (image, image_mini) 
			VALUES (:image, :image_mini)
		");
		$result = $statement->execute(
			array(
				':image'		=>	$image,
				':image_mini'		=>	$image
			)
		);
		if(!empty($result))
		{
			echo 'Фото Добавлено';
		}
	}
  • Вопрос задан
  • 419 просмотров
Решения вопроса 1
@Mike_Polit Автор вопроса
function upload_image_array()
{ 
  $res = array();
   if(isset($_FILES['user_image']))
   {
    // Count total files
    $countfiles = count($_FILES['user_image']['name']);

    for($i=0;$i<$countfiles;$i++){
      $extension = explode('.', $_FILES['user_image']['name'][$i]);
      $new_name = rand() . '.' . $extension[1];
      $destination = '../portfolio/upload/' . $new_name;
      $thumbDestination = '../portfolio/upload/thumb/' . $new_name;

      move_uploaded_file($_FILES['user_image']['tmp_name'][$i], $destination);

      resize($destination, $thumbDestination, 300);
      $res[] = $new_name;
    }
    return $res;
   }
}


if($_POST["operation"] == "Add")
  {
    $images = array();
    if($_FILES["user_image"]["name"] != '')
    {
      $images = upload_image_array();
    }
    foreach ($images as $image){
     $statement = $connection->prepare("
       INSERT INTO portfolio (image, image_mini) 
       VALUES (:image, :image_mini)
     ");
     $result = $statement->execute(
       array(
       ':image'       =>  $image,
       ':image_mini'      =>  $image
       )
     );
    }
    if(!empty($result))
     {
       echo 'Фото Добавлено';
     }
  }
Ответ написан
Комментировать
Пригласить эксперта
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Войти через центр авторизации
Похожие вопросы
17 мая 2024, в 23:24
300 руб./в час
17 мая 2024, в 22:37
20000 руб./за проект
17 мая 2024, в 22:33
1000 руб./за проект