Не удалось запустить Code-First Migration - RenameColumn - с MySql

У меня есть проблема, на которую я не смог найти ответ в Интернете.

Я использую миграцию CodeFirst EF 4.3.1 с MySQL.

Мой провайдер MySQL — Devart.

После запуска Add-Migration для существующей базы данных я получил следующий код:

public partial class ChangeSet_1231 : DbMigration
{
    public override void Up()
    {
        RenameColumn(table: "RW_TTaskInstanceProperties", name: "TaskInstance_TaskInstanceId", newName: "TaskInstanceId");
    }

    public override void Down()
    {
        RenameColumn(table: "RW_TTaskInstanceProperties", name: "TaskInstanceId", newName: "TaskInstance_TaskInstanceId");
    }
}

Запуск Update-Database приводит к следующей ошибке:

PM> Update-Database -verbose –startupprojectname "RTDataAccess"
Using NuGet project 'RTDataAccess'.
Target database is: 'rsruntime' (DataSource: localhost, Provider: Devart.Data.MySql, Origin: Explicit).
Applying explicit migrations: [201205311312361_ChangeSet_1231].
Applying explicit migration: 201205311312361_ChangeSet_1231.
ALTER TABLE RW_TTaskInstanceProperties RENAME COLUMN TaskInstance_TaskInstanceId TO TaskInstanceId

You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'COLUMN TaskInstance_TaskInstanceId TO TaskInstanceId' at line 2

Глядя на детали ошибки, я вижу, что RenameColumn переводится в команду MsSql, а не в команду MySql, поэтому неудивительно, что она сообщает о синтаксической ошибке.

Любые идеи, как это решить?

Я знаю, что могу использовать Update-Database -script, затем отредактировать скрипт, чтобы он соответствовал MySql, и запустить его, но я предпочитаю, чтобы команда Update-Database работала...

Спасибо.

В ответ на вопрос Ладислава:

Да, я зарегистрировал генератор SQL от Devart для миграции MySQL. Мой класс конфигурации выглядит так:

using Devart.Data.MySql.Entity.Configuration;
using Devart.Data.MySql.Entity.Migrations;

internal sealed class Configuration : DbMigrationsConfiguration<RTDataAccess.RTContext>
{
    public Configuration()
    {
        AutomaticMigrationsEnabled = false;

        MySqlEntityProviderConfig.Instance.Workarounds.IgnoreSchemaName = true;
        var connectionInfo = MySqlConnectionInfo.CreateConnection("Server=xxxx;Port=yyyy;Database=rsruntime;Uid=zzzz;Pwd=wwww;charset=utf8;");
        this.TargetDatabase = connectionInfo;
        this.SetSqlGenerator(connectionInfo.GetInvariantName(), new MySqlEntityMigrationSqlGenerator());
    }

    protected override void Seed(RTDataAccess.RTContext context)
    {
    }
}

comment
Вы зарегистрировали генератор SQL Devart для миграции MySQL в своем классе конфигурации миграции?   -  person Ladislav Mrnka    schedule 03.06.2012
comment
да. Я редактирую свой вопрос, чтобы включить соответствующий код конфигурации.   -  person mayash    schedule 04.06.2012
comment
Это кажется правильным. В таком случае вам следует обратиться в службу поддержки Devart.   -  person Ladislav Mrnka    schedule 04.06.2012


Ответы (1)


Проблема была исправлена ​​Devart.

Подробности по следующим ссылкам:

http://forums.devart.com/viewtopic.php?f=2&t=24250

http://www.devart.com/dotconnect/mysql/download.html

person mayash    schedule 10.06.2012