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

сохранение/восстановление каталога бд mysql из c#

12.05.2013, 00:42. Показов 1456. Ответов 5
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Для сохранения/восстановления каталга бд, использую утилиты mysqldump.exe и mysql.exe (скопировал их в папку с исходником).
Есть функция сохранения бд, она работает (нашел ее в статье, но обратой функции там не было(().
C#
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
 // функция резервного сохранения БД
        public bool RunBackup(string fileSave, string server, string port, string db, string login, string pass)
        {
            StreamWriter file = new StreamWriter(fileSave, false, Encoding.GetEncoding(1251));
            string output;
            ProcessStartInfo psi = new ProcessStartInfo();
            psi.FileName = "mysqldump.exe";
            psi.RedirectStandardInput = false;
            psi.RedirectStandardOutput = true;
            psi.UseShellExecute = false;
            
            psi.Arguments = string.Format(@"-l -u{0} {1} -h{2} -P {3} --default-character-set= --skip-set-charset {4}", login, string.IsNullOrEmpty(pass) ? "" : "-p" + pass, server, port, db);
 
            Process pr = Process.Start(psi);
            try
            {
                output = pr.StandardOutput.ReadToEnd();
                file.WriteLine(output);
                pr.WaitForExit();
            }
            catch (Exception e)
            {
                MessageBox.Show(e.Message);
                return false;
            }
            finally
            {
                file.Close();
                pr.Close();
            }
            return true;
        }
Не получается написать обратную функцию восстановления каталога бд из файла *.sql. Не понимаю, нужно ли работать с файлом, как в первой функции или можно просто передать параметры. Пытался экспериментировать с параметрами, но ничего не выходит (наверно я написал полный бред).

C#
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
// функция восстановления БД
        public bool RunRestore(string fileSave, string server, string port, string db, string login, string pass)
        {
            ProcessStartInfo psi = new ProcessStartInfo();
            psi.FileName = "mysql.exe";
            //psi.RedirectStandardInput = true;
            psi.RedirectStandardInput = false;
            psi.RedirectStandardOutput = true;
            psi.UseShellExecute = false;
            //psi.Arguments = string.Format(@"-u{0} {1} -h{2} -P {3} {4}", login, string.IsNullOrEmpty(pass) ? "" : "-p" + pass, server, port, db);
            //psi.Arguments = string.Format(@"-u{0} {1} -h{2} -P {3} {4} < {5}", login, string.IsNullOrEmpty(pass) ? "" : "-p" + pass, server, port, db, fileSave);
            //psi.Arguments = string.Format(@"-u{0} {1} -h{2} -P {3} {4}", login, string.IsNullOrEmpty(pass) ? "" : "-p" + pass, server, port, db); //"restore.sql"
            //psi.Arguments = "-uroot -p555 -hlocalhost test < t.sql";
            //psi.Arguments = "-uroot -pp555 test < t.sql";
            psi.Arguments = "-uroot -p555 -hlocalhost test ";
            
            Process pr = Process.Start(psi);
            //pr.BeginOutputReadLine();
            pr.StandardInput.WriteLine("mysql -uroot -p555 -hlocalhost test < t.sql");
            try
            {
                //output = pr.StandardOutput.ReadToEnd();
                //file.ReadLine(output);
 
                //Здесь все приготовили, задали параметры
                string line = "";
                while (!pr.StandardOutput.EndOfStream)
                {
                    line = pr.StandardOutput.ReadLine();
                }
 
                pr.WaitForExit();
            }
            catch (Exception e)
            {
                MessageBox.Show(e.Message);
                return false;
            }
            finally
            {
                //file.Close();
                pr.Close();
            }
            return true;
        }
Помогите пожалуйста! Очень, очень нужна эта функция.
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
12.05.2013, 00:42
Ответы с готовыми решениями:

ListView в БД сохранение/восстановление
Есть ListView c CheckBoxами, пользователь отмечает некоторые элементы списка, как лучше сохранить его выбор в базу данных? Записывать в...

Сохранение/восстановление дерева
Здравствуйте! В программе имеется TreeView, структура в которого подгружается из ini файла. Как реализовать сохранение последнего...

Открытие файлов из каталога и сохранение их в каталог определенного размера
Есть сама программа обработки ОДИНОЧНОГО файла, выполненная на куде. Хотелось бы поставить на непрерывную обработку. Подскажите пожалуйста...

5
0 / 0 / 0
Регистрация: 11.05.2013
Сообщений: 8
12.05.2013, 11:32  [ТС]
если ввожу просто в командной строке строчку: "mysql.exe -uroot -p555 test < c4.sql", то все работают, в базе появляются таблицы.
Если делаю в программе так:
C#
1
Process pr = Process.Start("mysql.exe", "mysql -uroot -p555 test < c4.sql");
то появляется командная строка, в ней быстро отображается что-то типо справки. в бд таблцы не создаются(

что не так делаю??
Миниатюры
сохранение/восстановление каталога бд mysql из c#  
0
0 / 0 / 0
Регистрация: 11.05.2013
Сообщений: 8
15.05.2013, 09:32  [ТС]
есть у кого какие-нибудь идеи??
0
 Аватар для kodv
1449 / 1121 / 347
Регистрация: 11.04.2011
Сообщений: 2,621
15.05.2013, 10:48
Цитата Сообщение от pippo Посмотреть сообщение
есть у кого какие-нибудь идеи??
Конечно, есть. Описание используемого вами метода на MSDN:
Цитата Сообщение от MSDN
public static Process Start(
string fileName,
string arguments
)
Думаю, описание параметров нету смысла писать. Ваша команда не знает аргумента mysql, и поэтому выводит вам в консоле описание того, как пользоваться файлом mysql.exe. Уберите mysql из списка аргументов.
0
0 / 0 / 0
Регистрация: 11.05.2013
Сообщений: 8
15.05.2013, 11:16  [ТС]
я пробовал делать и так
C#
1
Process pr = Process.Start("mysql.exe", "-uroot -p555 test < c4.sql");
но все-равно выводит справку(
0
0 / 0 / 0
Регистрация: 11.05.2013
Сообщений: 8
17.05.2013, 12:56  [ТС]
Проблема решена, если кому интересно:
C#
1
Process.Start("cmd.exe", "/C mysql.exe -uroot -p555 -hlocalhost test < restore.sql").WaitForExit();
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
17.05.2013, 12:56
Помогаю со студенческими работами здесь

Восстановление системы. Сохранение данных
Всем доброго времени суток! Прошу помощи у знающих! После обновления драйверов на моём ноуте HP dv6-2110-er он перезапускается. И при...

Сохранение и последующее восстановление процесса
Требуется написать программу, которая бдет по расписанию сохранять некоторый процесс, полный дамп. и уметь его восстанавливать из...

Code First сохранение и восстановление данных
Совсем недавно начал изучать создание сайтов с использованием MVC, Entity Framework Code First и столкнулся с распространённой проблемой:...

Сохранение классов на диск и их восстановление
Вот тут есть такая ситуэйшн: нужно сохранить класс, как я и делаю, но вот этот класс содержит в себе ОЧЕНЬ много членов, те в свою очердь...

Сохранение и восстановление настроек браузеров
Как известно, средствами самих браузеров можно сохранить и восстановить лишь закладки и куки. Однако существуют специальные утилиты,...


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

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
Ритм жизни
kumehtar 27.02.2026
Иногда приходится жить в ритме, где дел становится всё больше, а вовлечения в происходящее — всё меньше. Плотный график не даёт вниманию закрепиться ни на одном событии. Утро начинается с быстрых,. . .
[В процессе разработки] SDL3 для Web (WebAssembly): Сборка библиотек SDL3 и Box2D из исходников с помощью CMake и Emscripten
8Observer8 27.02.2026
Недавно вышла версия SDL 3. 4. 2 библиотеки SDL3. На странице официальной релиза доступны исходники, готовые DLL (для x86, x64, arm64), а также библиотеки для разработки под Android, MinGW и Visual. . .
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru