'Declaration Public Class MySqlScript Inherits Devart.Common.DbScript Implements System.ComponentModel.IComponent, System.IDisposable
public class MySqlScript : Devart.Common.DbScript, System.ComponentModel.IComponent, System.IDisposable
'Declaration Public Class MySqlScript Inherits Devart.Common.DbScript Implements System.ComponentModel.IComponent, System.IDisposable
public class MySqlScript : Devart.Common.DbScript, System.ComponentModel.IComponent, System.IDisposable
Often it is necessary to execute several SQL statements one by one. It can be performed by using a lot of components such as MySqlCommand. Usually it isn't a good solution. With only one MySqlScript component you can execute several SQL statements as one. This sequence of statements is named script. To separate individual statements use semicolon (;) symbol.
When MySqlScript encounters a BEGIN keyword in the script, it looks for a slash symbol "/" in the first position of some consecutive line. Everything between the BEGIN and the slash is considered single block. Usually the slash is placed after the line containing END keyword. You do not have to place slash after nested BEGIN...END block.
[STAThread] static void Main(string[] args) { string script = "DROP TABLE IF EXISTS DEPT;"+ "CREATE TABLE DEPT ("+ " DEPTNO INT PRIMARY KEY,"+ " DNAME VARCHAR(14),"+ " LOC VARCHAR(13)"+ ") TYPE = InnoDB;"+ "INSERT INTO DEPT VALUES (10,'ACCOUNTING','NEW YORK');"+ "INSERT INTO DEPT VALUES (20,'RESEARCH','DALLAS');"+ "INSERT INTO DEPT VALUES (30,'SALES','CHICAGO');"+ "INSERT INTO DEPT VALUES (40,'OPERATIONS','BOSTON');"+ "SELECT * FROM DEPT"; MySqlConnection myConn = new MySqlConnection( "User Id=root;Host=localhost;Database=Test;"); MySqlScript myScript = new MySqlScript(script,myConn); myScript.Progress += new Devart.Common.ScriptProgressEventHandler(OnProgress); myScript.Error += new Devart.Common.ScriptErrorEventHandler(OnError); myConn.Open(); myScript.Execute(); myConn.Close(); } static void OnProgress(object sender, Devart.Common.ScriptProgressEventArgs e) { Console.WriteLine(e.Text); Console.WriteLine(" Successfully executed."); } static void OnError(object sender, Devart.Common.ScriptErrorEventArgs e) { e.Ignore = true; Console.WriteLine(e.Text); Console.WriteLine(" Failed."); }
Module Module1 Friend WithEvents myScript As Devart.Data.MySql.MySqlScript Sub Main() Dim script As String = _ "DROP TABLE IF EXISTS DEPT;" + _ "CREATE TABLE DEPT (" + _ " DEPTNO INT PRIMARY KEY," + _ " DNAME VARCHAR(14)," + _ " LOC VARCHAR(13)" + _ ") TYPE = InnoDB;" + _ "INSERT INTO DEPT VALUES (10,'ACCOUNTING','NEW YORK');" + _ "INSERT INTO DEPT VALUES (20,'RESEARCH','DALLAS');" + _ "INSERT INTO DEPT VALUES (30,'SALES','CHICAGO');" + _ "INSERT INTO DEPT VALUES (40,'OPERATIONS','BOSTON');" + _ "SELECT * FROM DEPT" Dim myConn As MySqlConnection = New MySqlConnection( _ "User Id=root;Host=localhost;Database=Test;") myScript = New MySqlScript(script, myConn) myConn.Open() myScript.Execute() myConn.Close() Console.ReadLine() End Sub Sub OnProgress(ByVal sender As Object, ByVal e As Devart.Common.ScriptProgressEventArgs) Handles myScript.Progress Console.WriteLine(e.Text) Console.WriteLine(" Successfully executed.") End Sub Sub OnError(ByVal sender As Object, ByVal e As Devart.Common.ScriptErrorEventArgs) Handles myScript.Error e.Ignore = True Console.WriteLine(e.Text) Console.WriteLine(" Failed.") End Sub End Module
System.Object
System.MarshalByRefObject
System.ComponentModel.Component
Devart.Common.DbScript
Devart.Data.MySql.MySqlScript
Target Platforms: Windows 7, Windows Vista SP1 or later, Windows XP SP3, Windows Server 2008 (Server Core not supported), Windows Server 2008 R2 (Server Core supported with SP1 or later), Windows Server 2003 SP2