using System; using System.Data.SqlClient; using System.Globalization; using OpenDBDiff.Schema.Misc; using OpenDBDiff.Schema.SQLServer.Generates.Generates.SQLCommands; using OpenDBDiff.Schema.SQLServer.Generates.Model; using OpenDBDiff.Schema.SQLServer.Generates.Options; #if DEBUG using System.Runtime.InteropServices; #endif namespace OpenDBDiff.Schema.SQLServer.Generates.Generates { public class GenerateDatabase { private string connectioString; private SqlOption objectFilter; public bool UseDefaultVersionOnVersionParseError { get; private set; } /// /// Constructor de la clase. /// /// Connection string de la base public GenerateDatabase(string connectioString, SqlOption filter) { this.connectioString = connectioString; this.objectFilter = filter; } public DatabaseInfo Get(Database database) { DatabaseInfo item = new DatabaseInfo(); using (SqlConnection conn = new SqlConnection(connectioString)) { using (SqlCommand command = new SqlCommand(DatabaseSQLCommand.GetVersion(database), conn)) { conn.Open(); item.Server = conn.DataSource; item.Database = conn.Database; using (SqlDataReader reader = command.ExecuteReader()) { if (reader.Read()) { string versionValue = reader["Version"] as string; try { // used to use the decimal as well when Azure was 10.25 var version = new Version(versionValue); item.VersionNumber = float.Parse(String.Format("{0}.{1}", version.Major, version.Minor), CultureInfo.InvariantCulture); if (reader.FieldCount > 1 && !reader.IsDBNull(1)) { int edition; if (int.TryParse(reader[1].ToString(), out edition) && Enum.IsDefined(typeof(DatabaseInfo.SQLServerEdition), edition)) { item.SetEdition((DatabaseInfo.SQLServerEdition)edition); } } } catch (Exception notAGoodIdeaToCatchAllErrors) { var exception = new SchemaException( String.Format("Error parsing ProductVersion. ({0})", versionValue ?? "[null]") , notAGoodIdeaToCatchAllErrors); if (!UseDefaultVersionOnVersionParseError) { throw exception; } } } } } using (SqlCommand command = new SqlCommand(DatabaseSQLCommand.Get(item.Version, item.Edition, database), conn)) { using (SqlDataReader reader = command.ExecuteReader()) { if (reader.Read()) { item.Collation = reader["Collation"].ToString(); item.HasFullTextEnabled = ((int)reader["IsFulltextEnabled"]) == 1; } } } } return item; } } }