我创建了两个应用程序,第一个使用 ODP.Net,另一个没有实体 - 效果很好。
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 是一个视图。
第二个程序是使用 ODP.Net 和 EntityFramework 并手动创建 DbSet 类(该类在 Npgsql.EntityFramework 上进行了测试,效果很好,是 Oracle 视图的完美副本)。应用程序返回错误:ORA-00955。
我注意到,当将“模式”的名称更改为没有视图“订单”的名称时,程序会创建具有相同名称的表。
这是我的 DbSet 的开始:
[Table("ORDERS", Schema = "TEST")]
也有可能是错误的。但我不知道如何构建可以访问此视图的实体。用户仅具有 SELECT 权限。我想做只读操作。
实体框架提供程序的 Oracle 实现非常差,但有一些方法可以使其发挥作用。
-
简单但烦人 - 使用 NULL 或自己的数据库初始值设定项实现:
Database.SetInitializer<DatabaseContext>(null);
or
class DatabaseInitializer : IDatabaseInitializer<DatabaseContext>
{
public void InitializeDatabase(DatabaseContext context)
{
// your implementation
}
}
Database.SetInitializer(new DatabaseInitializer());
设置在首次访问数据库之前进行初始化。
- 如果您想使用迁移,请创建视图,然后添加迁移并忽略更改,例如使用包控制台
add-migration initial -ignorechanges
。这将使 EF 忽略数据库架构和模型之间的不一致(因为它只检查来自ALL_TABLES
,而不是视图),因此它不会尝试创建表。 Oracle EF 实现中存在一个错误,即如果初始迁移为空,它会删除并重新创建迁移__MigrationHistory
因此,在添加视图迁移之前,您的初始迁移必须至少包含一个表,或者您需要在之后添加一个表。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)