ASP.NET MVC - Entity Framework - Oracle - ORA-00942: table or view does not exist

首先感谢Fabio Statti。这篇英文解决方法post的作者。


我遇到的问题:

网站开发:asp.net mvc4+EF5+Oracle

开发中无问题,开发时使用Oracle数据库用户A

部署时使用Oracle数据库用户B,用户A和B下的权限和对象完全一致,只是用户名不同。

部署时,在部署的机器上死活报错ORA-00942: table or view does not exist


问题解决过程:

1.确认mvc网站Web.config中的Entites连接字符串无误。(使用此连接字符串和用户在PLSQLDeveloper和Toad中尝试均能成功连接)

2.检查连接字符串中用户B的权限,权限是DBA,最大的权限了

但尝试未能解决问题,此时都想把EF层干掉并直接写传统的Model和DAL了。

3.终于等到你,还好我没放弃…………

4.百度google一把,百度真是渣,百度结果乱七八糟。google还是很给力的,google出结果了。

原来是在添加edmx文件时,vs自动将开发机器上使用的A用户写入了edmx中的Schema

如下图

<EntitySet Name="AUTH_MENU" EntityType="Model.Store.AUTH_MENU" store:Type="Tables" Schema="A" />

,难怪部署时连接字符串中oracle用户B一直报ora-00942.


解决办法:

  • Open the .edmx file with a text editor
  • Delete every occurrence of the following string: Schema="YOUR_SCHEMA_DEVELOPMENT_MACHINE"
  • Save the file
  • Recompile the Project

按我的场景就是将我的edmx文件用记事本打开,将Schema="A" 全部删除,保存edmx,重新编译。


ok,整个世界清静了,生活如此美好!


英文原文:http://library.logicsistemi.it/en/net/general-topics/50-asp-net-mvc-entity-framework-oracle-ora-00942-table-or-view-does-not-exist

转载于:https://www.cnblogs.com/wangdh/p/6431814.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值