gpt4 book ai didi

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

转载 作者:太空狗 更新时间:2023-10-29 21:44:22 27 4
gpt4 key购买 nike

我创建了两个应用程序,第一个是使用 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/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com