我创建了两个应用程序,第一个是使用 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 实现非常差,但有一些方法可以使其正常工作。
简单但烦人 - 使用 NULL 或自己的数据库初始化程序实现:
Database.SetInitializer<DatabaseContext>(null);
或
class DatabaseInitializer : IDatabaseInitializer<DatabaseContext>
{
public void InitializeDatabase(DatabaseContext context)
{
// your implementation
}
}
Database.SetInitializer(new DatabaseInitializer());
在首次访问数据库之前设置初始化。
- 如果您想使用迁移创建您的 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/