1
0
mirror of https://github.com/Sonarr/Sonarr.git synced 2024-10-31 07:52:37 +01:00
Sonarr/NzbDrone.Core/Datastore/MigrationsHelper.cs

73 lines
2.1 KiB
C#
Raw Normal View History

2011-05-24 01:29:14 +02:00
using System;
using System.Collections.Generic;
2011-06-23 08:56:17 +02:00
using System.Data.SqlServerCe;
using System.IO;
2011-05-24 01:29:14 +02:00
using System.Reflection;
using NLog;
namespace NzbDrone.Core.Datastore
{
2011-06-15 04:31:41 +02:00
public class MigrationsHelper
2011-05-24 01:29:14 +02:00
{
private static readonly Logger Logger = LogManager.GetCurrentClassLogger();
public static readonly Dictionary<String, String> _migrated = new Dictionary<string, string>();
2011-06-05 08:02:31 +02:00
public static void Run(string connetionString, bool trace)
2011-05-24 01:29:14 +02:00
{
if (_migrated.ContainsKey(connetionString)) return;
_migrated.Add(connetionString, string.Empty);
2011-06-23 08:56:17 +02:00
EnsureDatabase(connetionString);
Logger.Trace("Preparing to run database migration");
2011-05-24 01:29:14 +02:00
try
{
2011-06-05 08:02:31 +02:00
Migrator.Migrator migrator;
if (trace)
{
2011-06-23 08:56:17 +02:00
migrator = new Migrator.Migrator("sqlserverce", connetionString, Assembly.GetAssembly(typeof(MigrationsHelper)), true, new MigrationLogger());
2011-06-05 08:02:31 +02:00
}
else
{
2011-06-23 08:56:17 +02:00
migrator = new Migrator.Migrator("sqlserverce", connetionString, Assembly.GetAssembly(typeof(MigrationsHelper)));
2011-06-05 08:02:31 +02:00
}
2011-05-24 01:29:14 +02:00
2011-06-04 20:19:22 +02:00
migrator.MigrateToLastVersion();
2011-05-24 01:29:14 +02:00
//ForceSubSonicMigration(Connection.CreateSimpleRepository(connetionString));
2011-06-05 08:35:03 +02:00
2011-05-24 01:29:14 +02:00
Logger.Info("Database migration completed");
2011-06-05 08:35:03 +02:00
2011-05-24 01:29:14 +02:00
}
catch (Exception e)
{
Logger.FatalException("An error has occurred while migrating database", e);
2011-05-24 01:29:14 +02:00
}
}
2011-06-23 08:56:17 +02:00
private static void EnsureDatabase(string constr)
{
var connection = new SqlCeConnection(constr);
2011-06-23 08:56:17 +02:00
if (!File.Exists(connection.Database))
{
var engine = new SqlCeEngine(constr);
engine.CreateDatabase();
}
}
2011-06-24 04:04:07 +02:00
public static string GetIndexName(string tableName, params string[] columns)
{
return String.Format("IX_{0}_{1}", tableName, String.Join("_", columns));
}
2011-05-24 01:29:14 +02:00
}
2011-06-23 08:56:17 +02:00
2011-05-24 01:29:14 +02:00
}