-
Notifications
You must be signed in to change notification settings - Fork 106
Home
Last update: Oct 17, 2021
This guide assumes that you have already familiar with MySQL Dot Net Connector with the minimum knowledge of performing SELECT, INSERT, UPDATE, DELETE by using MySql.Data.DLL.
Add this using statement
before coding
using MySql.Data.MySqlClient;
string constring = "server=localhost;user=root;pwd=qwerty;database=test;";
string file = "C:\\backup.sql";
using (MySqlConnection conn = new MySqlConnection(constring))
{
using (MySqlCommand cmd = new MySqlCommand())
{
using (MySqlBackup mb = new MySqlBackup(cmd))
{
cmd.Connection = conn;
conn.Open();
mb.ExportToFile(file);
conn.Close();
}
}
}
string constring = "server=localhost;user=root;pwd=qwerty;database=test;";
string file = "C:\\backup.sql";
using (MySqlConnection conn = new MySqlConnection(constring))
{
using (MySqlCommand cmd = new MySqlCommand())
{
using (MySqlBackup mb = new MySqlBackup(cmd))
{
cmd.Connection = conn;
conn.Open();
mb.ImportFromFile(file);
conn.Close();
}
}
}
Above examples will export and import a MySQL database with default options.
There are some options that can be modified the export and import behavior. These options are defined in
MySqlBackup.ExportInfo
MySqlBackup.ImportInfo
Example of customized export behavior: You want to:
- Only export table's structures
- Don't export rows of data
Sample Codes:
string constring = "server=localhost;user=root;pwd=1234;database=test1;";
string file = "Y:\\backup.sql";
using (MySqlConnection conn = new MySqlConnection(constring))
{
using (MySqlCommand cmd = new MySqlCommand())
{
using (MySqlBackup mb = new MySqlBackup(cmd))
{
cmd.Connection = conn;
conn.Open();
mb.ExportInfo.ExportTableStructure = true;
mb.ExportInfo.ExportRows = false;
mb.ExportToFile(file);
}
}
}
ExportInfo.GetDocumentHeaders(cmd)
return: List<string>
default value: Demonstrated in test app.
Gets the list of document headers.
ExportInfo.SetDocumentHeaders(List<string>)
Sets the document headers.
ExportInfo.GetDocumentFooters()
return: List<string>
default value: demonstrated in test app.
Gets the document footers.
ExportInfo.SetDocumentFooters(List<string>)
Sets the document headers.
ExportInfo.ExcludeTables - List<string>
default value: empty list
Gets or Sets the tables (black list) that will be excluded for export. The rows of the these tables will not be exported too.
ExportInfo.TablesToBeExportedList - List<string>
default value: empty list
Gets or Sets the list of tables that will be exported. If none, all tables will be exported.
ExportInfo.TablesToBeExportedDic - Dictionary<string, string>
default value: empty dictionary
Gets or Sets the tables that will be exported with custom SELECT defined.
If none or empty, all tables and rows will be exported.
Key = Table's Name. Value = Custom SELECT Statement.
Example 1: SELECT * FROM product
WHERE category
= 1;
Example 2: SELECT name
,description
FROM product
;
ExportInfo.RecordDumpTime - bool
default value: true
Gets or Sets a value indicates whether the Dump Time should recorded in dump file.
ExportInfo.AddCreateDatabase - bool
default value: false
Gets or Sets a value indicates whether the SQL statement of "CREATE DATABASE" should be added into dump file.
ExportInfo.AddDropDatabase - bool
default value: false
Gets or Sets a value indicates whether the SQL statement of "DROP DATABASE" should be added into dump file.
ExportInfo.ExportTableStructure - bool
default value: true
Gets or Sets a value indicates whether the Table Structure (CREATE TABLE) should be exported.
ExportInfo.AddDropTable - bool
default value: true
Gets or Sets a value indicates whether the SQL statement of "DROP TABLE" should be added into the dump file.
ExportInfo.ResetAutoIncrement - bool
default value: false
Gets or Sets a value indicates whether the value of auto-increment of each table should be reset to 1.
ExportInfo.ExportRows - bool
default value: true
Gets or Sets a value indicates whether the Rows should be exported.
ExportInfo.MaxSqlLength - int
default value: 5 * 1024 * 1024 (5mb)
Gets or Sets the maximum length for combining multiple INSERTs into single sql.
Default value is 5MB.
Only applies if RowsExportMode = "INSERT" or "INSERTIGNORE" or "REPLACE".
This value will be ignored if RowsExportMode = ONDUPLICATEKEYUPDATE or UPDATE.
ExportInfo.ExportProcedures - bool
default value: true
Gets or Sets a value indicates whether the Stored Procedures should be exported.
ExportInfo.ExportFunctions - bool
default value: true
Gets or Sets a value indicates whether the Stored Functions should be exported.
ExportInfo.ExportTriggers - bool
default value: true
Gets or Sets a value indicates whether the Stored Triggers should be exported.
ExportInfo.ExportViews - bool
default value: true
Gets or Sets a value indicates whether the Stored Views should be exported.
ExportInfo.ExportEvents - bool
default value: true
Gets or Sets a value indicates whether the Stored Events should be exported.
ExportInfo.IntervalForProgressReport - int
default value: 100
Gets or Sets a value indicates the interval of time (in miliseconds) to raise the event of ExportProgressChanged.
ExportInfo.ScriptsDelimiter - string
default value: |
Gets or Sets the delimiter used for exporting Procedures, Functions, Events and Triggers.
ExportInfo.ExportRoutinesWithoutDefiner - bool
default value: true
Gets or Sets a value indicates whether the exported Scripts (Procedure, Functions, Events, Triggers, Events) should exclude DEFINER.
ExportInfo.RowsExportMode - enum RowsDataExportMode
default value: Insert
Gets or Sets a enum value indicates how the rows of each table should be exported.
INSERT = The default option. Recommended if exporting to a new database. If the primary key existed, the process will halt;
INSERT IGNORE = If the primary key existed, skip it;
REPLACE = If the primary key existed, delete the row and insert new data;
OnDuplicateKeyUpdate = If the primary key existed, update the row. If all fields are primary keys, it will change to INSERT IGNORE;
UPDATE = If the primary key is not existed, skip it and if all the fields are primary key, no rows will be exported.
ExportInfo.WrapWithinTransaction - bool
default value: false
Gets or Sets a value indicates whether the rows dump should be wrapped with transaction.
Recommended to set this value to FALSE if using RowsExportMode = "INSERT" or "INSERTIGNORE" or "REPLACE", else TRUE.
ExportInfo.TextEncoding - System.Text.Encoding
default value: UTF8Encoding(false)
Gets or Sets a value indicates the encoding to be used for exporting the dump. Default = UTF8Coding(false)
ExportInfo.BlobExportMode - enum BlobDataExportMode
default value: BlobDataExportMode.HexString
Gets or Sets a enum value indicates how the BLOB should be exported.
HexString = Hexa Decimal String (default);
BinaryChar = char format.
Note: Export BLOB into Binary Char is not intended for real deploy usage at the moment. Exporting into BinaryChar will raise an exception which attempt to alarm the developers that this function is meant for development and debugging purposes.
ExportInfo.BlobExportModeForBinaryStringAllow - bool
default value: false
If you wish to help to debug, fix or develop the function of exporting BLOB into binary char format (BlobExportMode=BinaryChar
), set this value to true
.
ExportInfo.GetTotalRowsMode - enum BlobDataExportMode
default value: InformationSchema
Gets or Sets a value indicates the method of how the total rows value is being obtained.
This function is useful if you are developing a progress bar
.
InformationSchema = Fast, but approximate value;
SelectCount = Slow but accurate;
Skip = Skip obtaining total rows. Use this option if you are not doing any progress report.
ExportInfo.EnableComment - Boolean
default value: True
Gets or Sets a value indicates whether the comments should be included in the dump content.
ExportInfo.InsertLineBreakBetweenInserts - Boolean
default value: false
Gets or Sets a value indicates whether the comments should be included in the dump content.
ImportInfo.IntervalForProgressReport - int
default value: 100
Gets or Sets a value indicates whether line breaks should be added in between multiple INSERTs.
ImportInfo.IgnoreSqlError - bool
default value: false
Gets or Sets a value indicates whether SQL errors occurs in import process should be ignored.
ImportInfo.ErrorLogFile - string
default value: string.empty Gets or Sets the file path used to log error messages.