c# - 带有 Entity Framework 6 的 Oracle ODP.Net - 从 TableView 中选择时出现 ORA-00955

标签 c# oracle entity-framework

我创建了两个应用程序,第一个是使用 ODP.Net 的,一个是没有 Entity 的 - 效果很好。

static void Main(string[] args)
{
    OracleConnection con = new OracleConnection();

    //using connection string attributes to connect to Oracle Database
    con.ConnectionString = "user id=****;password=****;data source=" +
        "(DESCRIPTION=(ADDRESS=(PROTOCOL=TCP)(HOST=server.org.net)(PORT=1521))(CONNECT_DATA=(SERVER=dedicated)(SERVICE_NAME=ora1)))";
    con.Open();
    Console.WriteLine("Connected to Oracle" + con.ServerVersion);

    OracleCommand command = con.CreateCommand();
    command.CommandText = "SELECT ITEM FROM TEST.ORDERS";

    OracleDataReader reader = command.ExecuteReader();

    while (reader.Read())
    {
        Console.WriteLine("\t{0}",
            reader[0]);
    }
    reader.Close();

    // Close and Dispose OracleConnection object
    con.Close();
    con.Dispose();
    Console.WriteLine("Disconnected");
    Console.ReadKey();
}

TEST.ORDERS 是一个 View 。

第二个程序使用 ODP.Net 和 EntityFramework 并手动创建了 DbSet 类(在 Npgsql.EntityFramework 上进行了测试,效果很好,是 Oracle View 的完美副本)。应用程序返回错误:ORA-00955。 我注意到,当将“Schema”的名称更改为没有 View “ORDER”的名称时,程序会创建我的同名表。 这是我的 DbSet 的开始:

[Table("ORDERS", Schema = "TEST")]

有可能是错的。但我不知道如何构建可以访问此 View 的实体。用户只有 SELECT 的权限。我想做只读操作。

最佳答案

Entity Framework 提供程序的 Oracle 实现非常差,但有一些方法可以使其正常工作。

  1. 简单但烦人 - 使用 NULL 或自己的数据库初始化程序实现:

    Database.SetInitializer<DatabaseContext>(null);
    

class DatabaseInitializer : IDatabaseInitializer<DatabaseContext>
{
    public void InitializeDatabase(DatabaseContext context)
    {
        // your implementation
    }
}

Database.SetInitializer(new DatabaseInitializer());

在首次访问数据库之前设置初始化。

  1. 如果您想使用迁移创建您的 View ,然后添加忽略更改的迁移,例如使用包控制台 add-migration initial -ignorechanges。这将使 EF 忽略数据库架构和模型之间的不一致(因为它只检查 ALL_TABLES 中的表,而不是 View ),因此它不会尝试创建表。 Oracle EF 实现中存在一个错误,如果初始迁移为空,它会删除并重新创建 __MigrationHistory 表,因此在添加 View 迁移之前您的初始迁移必须至少包含一个表,或者您需要之后添加表格。

关于c# - 带有 Entity Framework 6 的 Oracle ODP.Net - 从 TableView 中选择时出现 ORA-00955,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28819307/

相关文章:

c# - 如何管理在运行时创建的 WinForms 按钮的委托(delegate)?

c# - 我可以通过实体拆分延迟加载 Entity Framework 6 中实体的一部分吗?

oracle - 如何禁用 oracle 窗体中的 F8

mysql - SQL如何处理值为0的空表?

database - Spring JDBC BeanPropertyRowMapper 是 否 ('Y' ,'N' ) 到 boolean bean 属性

c# - 每个不为 null 的 Parameter 对象属性,要作为条件添加到表达式谓词中

c# - Mvc 在隐藏字段中覆盖我的 ID

c# - Web 响应状态码

entity-framework - 在循环中构建 LINQ 查询

c# - 如果已经打开,请关闭 Telerik Radgrid Editform