Как использовать Entity Framework 6.x в Asp.Net 5 (MVC 6)

NullPointerException s - исключения, возникающие при попытке использовать ссылку, которая указывает на отсутствие местоположения в памяти (null), как если бы она ссылалась на объект. Вызов метода по нулевой ссылке или попытка получить доступ к полю нулевой ссылки вызовет функцию NullPointerException. Они наиболее распространены, но другие способы перечислены на странице NullPointerException javadoc.

Вероятно, самый быстрый пример кода, который я мог бы придумать для иллюстрации NullPointerException, be:

public class Example {

    public static void main(String[] args) {
        Object obj = null;
        obj.hashCode();
    }

}

В первой строке внутри main я явно устанавливаю ссылку Object obj равной null. Это означает, что у меня есть ссылка, но она не указывает на какой-либо объект. После этого я пытаюсь обработать ссылку так, как если бы она указывала на объект, вызывая метод на нем. Это приводит к NullPointerException, потому что нет кода для выполнения в местоположении, на которое указывает ссылка.

(Это техничность, но я думаю, что она упоминает: ссылка, которая указывает на null, равна 't то же, что и указатель C, указывающий на недопустимую ячейку памяти. Нулевой указатель буквально не указывает на в любом месте , который отличается от указаний на местоположение, которое оказывается недопустимым.)

25
задан John Saunders 10 April 2015 в 23:36
поделиться

1 ответ

В зависимости от используемой базы данных это может быть не так просто, как ответ. Если вы используете MsSql, тогда никакая конфигурация не требуется, и принятый ответ вполне подходит. Но для использования LocalDB может потребоваться некоторая настройка.

Например, MySql необходимо зарегистрировать провайдера

[DbConfigurationType(typeof(CodeConfig))] // point to the class that inherit from DbConfiguration
public class ApplicationDbContext : DbContext
{
    [...]
}

public class CodeConfig : DbConfiguration
{
    public CodeConfig()
    {
        SetDefaultConnectionFactory(new MySql.Data.Entity.MySqlConnectionFactory());
        SetProviderServices("MySql.Data.MySqlClient",
                    new MySql.Data.MySqlClient.MySqlProviderServices());
    }
}

PostgreSql необходимо зарегистрировать провайдера в разделе entityFramework AND system.data. Это может быть сделано с помощью события System.Data.Entity.DbConfiguration.Loaded. То же самое относится и к Oracle.

Посмотрите этот пост в блоге, который подробно объясняет его: http://bleedingnedge.com/2015/11/01/entity-framework-6-with-asp-net-5/

6
ответ дан pg0xC 10 April 2015 в 23:36
поделиться
Другие вопросы по тегам:

Похожие вопросы: