С Новым годом! Форум программистов, компьютерный форум, киберфорум
PHP: базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.63/8: Рейтинг темы: голосов - 8, средняя оценка - 4.63
 Аватар для Darwin
2 / 2 / 0
Регистрация: 16.08.2013
Сообщений: 88

Создание дампа базы данных (скрипт) - найти ошибку

04.10.2015, 11:17. Показов 1613. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте!
Раскопал скрипт для создания дампа базы MySQL. На локальном сервере работает как надо, у хостера (Beget) вылазит ошибка:
You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near '`' at line 1
Скрипт состоит из 3 файлов:

index.php
PHP
1
2
3
4
5
6
7
8
<?php
header("Content-Type:text/html;charset=UTF-8");
include "config.php";
include "functions.php";
$db = connect_db();
$tables = get_tables($db);
get_dump($db,$tables);
?>
config.php
PHP
1
2
3
4
5
6
7
8
<?php
define("HOST",'localhost');
define("USER",'user');
define("PASSWORD",'12345');
define("DB",'baza');
define("DIR_SQL",'sql/');
define("FOR_WRITE",10);
?>
functions.php
PHP
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
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
<?php
function connect_db() {
    $db = mysqli_connect(HOST,USER,PASSWORD,DB);    
    if(mysqli_connect_error($db)) {
        exit("Нет соединения с БД");
    }   
    return $db;
}
function get_tables($db) {
    
    $sql = "SHOW TABLES";
    $result = mysqli_query($db,$sql);
    
    if(!$result) {
        exit(mysqli_error($db));
    }
    
    $tables = array();
    for($i = 0; $i < mysqli_num_rows($result); $i++) {
        $row = mysqli_fetch_row($result);
        $tables[] = $row[0];
    }
    
    return $tables;
    
}
function get_dump($db,$tables) {
    
    if(is_array($tables)) {
        $fp = fopen(DIR_SQL.time()."_dump.sql","w");
        
        $text = "-- SQL Dump
-- my_ version: 1.234
--
-- База дынных: `".DB."`
--
-- ---------------------------------------------------
-- ---------------------------------------------------
";
        fwrite($fp,$text);
        
        foreach($tables as $item) {
            
                $text = "
-- 
-- Структура таблицы - ".$item."
--
";
        fwrite($fp,$text);
            
            
            $text = "";
            $text .= "DROP TABLE IF EXISTS `".$item."`;";
            
            $sql = "SHOW CREATE TABLE ".$item;
            $result = mysqli_query($db, $sql);
            if(!$result) {
                exit(mysqli_error($db));
            }
            $row = mysqli_fetch_row($result);
            
            $text .= "\n".$row[1].";";
            fwrite($fp,$text);
            
            $text = "";
            $text .=
            "
--          
-- Dump BD - tables :".$item."
--
            ";
// INSERT INTO `category` VALUES ("1", "Opel"),(id,opel),           
            $text .= "\nINSERT INTO `".$item."` VALUES";
            fwrite($fp,$text);
            
            $sql2 = "SELECT * FROM ".$item."`";
            $result2 = mysqli_query($db,$sql2);
            if(!$result2) {
                exit(mysqli_error($db));
            }
            $text = "";
            
            for($i = 0; $i < mysqli_num_rows($result2); $i++) {
                $row = mysqli_fetch_row($result2);
                
                if($i == 0) $text .= "(";
                    else  $text .= ",(";
                
                foreach($row as $v) {
                    $text .= "\"".mysqli_real_escape_string($db,$v)."\",";
                }
                $text = rtrim($text,",");   
                $text .= ")";
                
                if($i > FOR_WRITE) {
                    fwrite($fp,$text);
                    $text = "";
                }
                
            }
            $text .= ";\n";
            fwrite($fp,$text);
            
            
        }
    }
    fclose($fp);
}
?>
Подскажите, плиз, где ошибка.
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
04.10.2015, 11:17
Ответы с готовыми решениями:

Создание набора данных .xsd на основе сохраненного дампа базы данных MS SQL
Привет всем! У меня есть текстовый файл - дамп (если правильно выражаюсь) базы данных с расширением .sql такого вида: USE GO ...

Создание базы данных, открытие из под одной базы данных MS Access
Здравствуйте. В общем, C# начал заниматься только вот и сразу была поставлена задача создать базу данных. Идея есть, при открытие программы...

Создать обработчик кнопки "Найти" для базы данных в borland (выдаёт ошибку)
должен производиться поиск страны и стоимости по фамилии клиента, программа запускается, но при вводе фамилии вылезает окно (в прикрепе,...

3
Эксперт PHP
3899 / 3237 / 1353
Регистрация: 01.08.2012
Сообщений: 10,904
04.10.2015, 16:06
Лучший ответ Сообщение было отмечено Darwin как решение

Решение

Ошибку выводит mysqli_error, их в файле с функциями три. Ищите.

Предположу, что ошибка на строке 76, нет открывающего апострофа (символ `).
1
 Аватар для Darwin
2 / 2 / 0
Регистрация: 16.08.2013
Сообщений: 88
04.10.2015, 18:54  [ТС]
Цитата Сообщение от Jodah Посмотреть сообщение
Ошибку выводит mysqli_error, их в файле с функциями три. Ищите.
Предположу, что ошибка на строке 76, нет открывающего апострофа (символ `).
Исправил. Не знаю какие еще 2 ошибки, но уже работает.
PHP
1
$sql2 = "SELECT * FROM `".$item."`";
0
Эксперт PHP
3899 / 3237 / 1353
Регистрация: 01.08.2012
Сообщений: 10,904
04.10.2015, 20:37
Darwin, ошибка одна, функций три. Всё хорошо.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
04.10.2015, 20:37
Помогаю со студенческими работами здесь

Создание connection и скрипт для создания базы
Как при создании connection к БД сделать, чтобы выполнялся скрипт, который лежит в resourses ? connection =...

Данные из дампа базы
Есть дамп ms sql-ной базы 1с 8х. Допустим, если его отресторить на каком-нибудь сервере, то можно из него дернуть справочники запросами или...

Развернуть базы из дампа
Необходимо восстановить бд из дампа. я новичок, вообще не знаю с чего начать! ПОДСКАЖИТЕ пожалуйста! установила Oracle Database 11g....

Восстановление базы из дампа
Добрый день ув. форумчане . С ДБ знаком только недели 3 и то самоучка ). Мне прислали дамп базы (без данных , только процедуры ,...

Восстановление сайта без дампа базы
Здравствуйте!есть резервная копия сайта(папка сайта) нет дампа базы.Возможно ли восстановить сайт?и если возможно дайте ссылку на...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Модель микоризы: классовый агентный подход
anaschu 02.01.2026
Раньше это было два гриба и бактерия. Теперь три гриба, растение. И на уровне агентов добавится между грибами или бактериями взаимодействий. До того я пробовал подход через многомерные массивы,. . .
Учёным и волонтёрам проекта «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-динозавры, а новое поколение лёгких потоков. Откат?. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru