С Новым годом! Форум программистов, компьютерный форум, киберфорум
PHP для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.86/7: Рейтинг темы: голосов - 7, средняя оценка - 4.86
0 / 0 / 0
Регистрация: 08.10.2015
Сообщений: 27

Занесение в базу

13.10.2016, 09:32. Показов 1363. Ответов 9
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Warning: mysqli:repare() expects exactly 1 parameter, 0 given in Z:\home\1beta.kz\www\store.php on line 39
выдает такую ошибку

код для добавления картинки в базу

таблица
SQL
1
2
3
4
5
6
7
8
CREATE TABLE binary_data (
id INT(4) NOT NULL AUTO_INCREMENT PRIMARY KEY,
description CHAR(50),
bin_data LONGBLOB,
filename CHAR(50),
filesize CHAR(50),
filetype CHAR(50)
);
store.php
HTML5
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
<html>
<head>
<meta http-equiv="content-type" content="text/html; charset=utf-8">
<title>Сохранение бинарных данных в базе данных MySQL</title>
</head>
<body>
<?php
 
// Код, который будет выполняться, если форма была оправлена:
if ($_POST['submit']) {
 
    // подключение к базе данных
    // (возможно, вам придется настроить имя хоста, имя пользователя и пароль)
    $dbh = new mysqli("localhost", "root", "", "phpblog");
 
    if(mysqli_connect_errno())
    {
        exit("Ошибка подключения к базе данных MySQL: Сервер база данных не доступен!<br>
        Проверте параметры подключения к базе данных.");
    }
 
    $data = addslashes(fread(fopen($_FILES['file']['tmp_name'], "r"), 
    filesize($_FILES['file']['tmp_name'])));
 
    $_POST['form_description'] = trim($_POST['form_description']);
    $size = filesize ($_FILES['file']['tmp_name']);
 
    $result=$dbh->prepare("INSERT INTO binary_data (description,bin_data,filename,filesize,filetype) 
  "."VALUES ('".$_POST['form_description']."',
  '".$data."',
  '".$_FILES["file"]["name"]."',
  '".$size."',
  '".$_FILES["file"]["type"]."')");
 
  if(!$result) exit("Ошибка выполнения SQL запроса!");
 
  $result->execute(); 
  $id = $dbh->prepare();
 
  echo "<p>Этот файл имеет следующий идентификатор (ID) в базе данных: <b>".$id."</b>";
 
} else {
 
  // отображаем форму для оправки новых данных:
?>
 
<form method="post" action="<?php echo $_SERVER['PHP_SELF']; ?>" enctype="multipart/form-data">
Описание файла: <input type="text" name="form_description" size="40">
<input type="hidden" name="MAX_FILE_SIZE" value="1000000">
Файл для загрузки/хранения в базе данных: <input type="file" name="file" size="40">
<p><input type="submit" name="submit" value="Отправить">
</form>
<?php
 
}
 
?> 
</body>
</html>
getdata.php
PHP
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
<?php
if(!preg_match("|^[\d]*$|",$_GET['id'])) exit();
// подключение к базе данных
$database    = 'phpblog'; // название базы
$mysql_user    = 'root'; // пользователь
$mysql_password    = ''; //пароль
$mysql_host    = 'localhost'; //сервер
$dbh = mysql_pconnect ($mysql_host, $mysql_user, $mysql_password);
if(mysqli_connect_errno())
{
  exit("Ошибка подключения к базе данных MySQL: Сервер база данных не доступен!<br>
  Проверте параметры подключения к базе данных.");
}
$query = "SELECT bin_data,filetype from binary_data WHERE id=".$_GET['id'];
$result = $dbh->query($query);
if(!$result) exit("Ошибка выполнения SQL запроса!");
$row = $result->fetch_array();
Header( "Content-type: ".$row['filetype']."");
echo $row['bin_data'];
?>
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
13.10.2016, 09:32
Ответы с готовыми решениями:

Занесение в базу данных phpMyAdmin
Доброго времени суток. Для обучения работы с selenium мне понадобилась форма регистрации, заносящая данные в БД. Для этих целей был ...

Занесение авторов в базу данных
Есть входной файл в таком виде: Царица добродетель Державин Царь огнь Херасков Тютчев Царь зерцало Тредиаковский Державин ...

Занесение имен файлов в базу
Несколько файлов через одно поле в форме загружаются. В таблице под них разные поля. Как занести в эти поля имена файлов?

9
Эксперт PHP
3899 / 3237 / 1353
Регистрация: 01.08.2012
Сообщений: 10,904
13.10.2016, 09:58
Цитата Сообщение от suname Посмотреть сообщение
Warning: mysqli:repare() expects exactly 1 parameter, 0 given
Ожидается 1 параметр, передано 0. Какой информации вам не хватает?
1
0 / 0 / 0
Регистрация: 08.10.2015
Сообщений: 27
13.10.2016, 11:30  [ТС]
я не пойму почему ошибка выходит
0
Эксперт PHP
3899 / 3237 / 1353
Регистрация: 01.08.2012
Сообщений: 10,904
13.10.2016, 11:42
Цитата Сообщение от suname Посмотреть сообщение
я не пойму почему ошибка выходит
Потому что вы запускаете prepare без аргументов, очевидно же.

На 29 строке вы передаёте sql-запрос, а на 39 не передаёте.
1
0 / 0 / 0
Регистрация: 08.10.2015
Сообщений: 27
13.10.2016, 11:52  [ТС]
А как сделать что бы это заработало?
0
Эксперт PHP
3899 / 3237 / 1353
Регистрация: 01.08.2012
Сообщений: 10,904
13.10.2016, 11:56
suname, судя по коду, 39 строку заменить на:
PHP
1
$id = $dbh->lastInsertId();
1
0 / 0 / 0
Регистрация: 08.10.2015
Сообщений: 27
13.10.2016, 12:42  [ТС]
все равно выходит ошибка
Fatal error: Call to undefined method mysqli::lastInsertId() in Z:\home\1demo.kz\www\store.php on line 39
0
471 / 399 / 169
Регистрация: 04.01.2013
Сообщений: 1,675
13.10.2016, 12:47
Лучший ответ Сообщение было отмечено suname как решение

Решение

Для mysqli OOP используйте
PHP
1
$id = $dbh->insert_id;
2
0 / 0 / 0
Регистрация: 08.10.2015
Сообщений: 27
13.10.2016, 12:50  [ТС]
Спасибо за помощь
Все работает .
0
13.10.2016, 16:43

Не по теме:

Упс, точно, вижу mysqli, думаю про PDO.

0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
13.10.2016, 16:43
Помогаю со студенческими работами здесь

Определение ip и занесение его в базу данных
Допустим существует страница регистрации, пользователь регистрируется, и его ip заносится в базу данных рядом с его данными в таблице, как...

Получение методом пост и занесение его в базу mysql
Здравствуйте! Есть форма с добавлением полей на js то есть: есть 1 ряд с ячейками (id и name в input, формата id=&quot;cell-0&quot; ...

Занесение в базу многострочного текста
Как можно внести в базу текст из многострочного TextBox с сохранением разрыва строк.

Подсчет и занесение в базу данных
всем привет) $sql = mysql_query(&quot;SELECT `msg` FROM `comments-recipes` WHERE `id_recipes`=&quot;.$_GET); $comments =...

Занесение xml в базу данных
Здравствуйте Создаю xml файл таким образом,но не знаю как теперь его поместить в базу данных. Пробывал $result =...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
10
Ответ Создать тему
Новые блоги и статьи
Учёным и волонтёрам проекта «Einstein@home» удалось обнаружить четыре гамма-лучевых пульсара в джете Млечного Пути
Programma_Boinc 01.01.2026
Учёным и волонтёрам проекта «Einstein@home» удалось обнаружить четыре гамма-лучевых пульсара в джете Млечного Пути Сочетание глобально распределённой вычислительной мощности и инновационных. . .
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru