如何在 ASP.net MVC3 中获取 Advantage Database 数据?
Posted
技术标签:
【中文标题】如何在 ASP.net MVC3 中获取 Advantage Database 数据?【英文标题】:How to get the Advantage Database data in ASP.net MVC3? 【发布时间】:2012-04-03 19:07:51 【问题描述】:我在 Asp.net MVC3 环境中,我使用 Advantage Database 9.1。
我想在 Asp.net 中获取 Advantage Database 数据(+Repository 模式)
我的 Advantage 数据库有 WebOrderHd 表,我想获取该表的 PK 字段并对其进行计数。
(表名:WebOrderHd 字段名:PK(字符(36))
我想我连接到数据库服务器成功,但我无法获取数据。
这是我的代码,
Web.config
<add name="EFAdsContext" connectionString="Data Source=\\XXX.XX.XX.XX:6262\DB_BACK\SD.ADD;ServerType=REMOTE;User ID=AdsSys;Password=xxxxx"
providerName="Advantage.Data.Provider" />
/Concrete/EFAdsContext.cs
public class EFAdsContext : DbContext
public DbSet<WebOrderHd> weborderhd get; set;
/Concrete/EFWebOrderHdRepository.cs
public class EFWebOrderHdRepository : IWebOrderHdRepository
private EFAdsContext context = new EFAdsContext();
public IQueryable<WebOrderHd> WebOrderHd
get return context.weborderhd;
/Abstract/IWebOrderHdRepository.cs
public interface IXcartOrdersRepository
IQueryable<XcartOrder> XcartOrders get;
/Entities/WebOrderHd.cs
public class WebOrderHd
[Key]
public string PK get; set;
//public string ORDERNO get; set;
在我的控制器中,
IWebOrderHdRepository WebOrderHdRepository = new EFWebOrderHdRepository();
int adsOrderCnt = WebOrderHdRepository.WebOrderHd.Count();
上面的代码运行时出现错误:
给定的键不在字典中。
说明:在执行当前 Web 请求期间发生未处理的异常。请查看堆栈跟踪以获取有关错误及其源自代码的位置的更多信息。
异常详情: System.Collections.Generic.KeyNotFoundException:字典中不存在给定的键。
我猜错误信息说 Asp.net 在 WebOrderHd 表中找不到 PK 字段, 但我确定有PK场。
有人知道我做错了什么吗?
谢谢!
堆栈跟踪:
[KeyNotFoundException: The given key was not present in the dictionary.]
System.Collections.Generic.Dictionary`2.get_Item(TKey key) +9619597
Advantage.Data.Provider.AdsProviderManifest.GetStoreType(TypeUsage edmType) +2930
System.Data.Entity.ModelConfiguration.Edm.Services.StructuralTypeMappingGenerator.MapTableColumn(EdmProperty property, DbTableColumnMetadata tableColumnMetadata, Boolean isInstancePropertyOnDerivedType, Boolean isKeyProperty) +60
System.Data.Entity.ModelConfiguration.Edm.Services.PropertyMappingGenerator.Generate(EdmEntityType entityType, IEnumerable`1 properties, DbEntitySetMapping entitySetMapping, DbEntityTypeMappingFragment entityTypeMappingFragment, IList`1 propertyPath, Boolean createNewColumn) +1293
System.Data.Entity.ModelConfiguration.Edm.Services.EntityTypeMappingGenerator.Generate(EdmEntityType entityType, DbDatabaseMapping databaseMapping) +496
System.Data.Entity.ModelConfiguration.Edm.Services.DatabaseMappingGenerator.GenerateEntityTypes(EdmModel model, DbDatabaseMapping databaseMapping) +122
System.Data.Entity.ModelConfiguration.Edm.Services.DatabaseMappingGenerator.Generate(EdmModel model) +30
System.Data.Entity.DbModelBuilder.Build(DbProviderManifest providerManifest, DbProviderInfo providerInfo) +189
System.Data.Entity.DbModelBuilder.Build(DbConnection providerConnection) +59
System.Data.Entity.Internal.LazyInternalContext.CreateModel(LazyInternalContext internalContext) +62
System.Data.Entity.Internal.RetryLazy`2.GetValue(TInput input) +117
System.Data.Entity.Internal.LazyInternalContext.InitializeContext() +453
System.Data.Entity.Internal.InternalContext.GetEntitySetAndBaseTypeForType(Type entityType) +18
System.Data.Entity.Internal.Linq.InternalSet`1.Initialize() +57
System.Data.Entity.Internal.Linq.InternalSet`1.get_InternalContext() +15
System.Data.Entity.Infrastructure.DbQuery`1.System.Linq.IQueryable.get_Provider() +37
System.Linq.Queryable.Count(IQueryable`1 source) +50
SportsStore.WebUI.Controllers.ProductController.List(String category, Int32 page) in C:\Users\mark\documents\visual studio 2010\Projects\SportsStore\SportsStore.WebUI\Controllers\ProductController.cs:37
lambda_method(Closure , ControllerBase , Object[] ) +151
System.Web.Mvc.ActionMethodDispatcher.Execute(ControllerBase controller, Object[] parameters) +17
System.Web.Mvc.ReflectedActionDescriptor.Execute(ControllerContext controllerContext, IDictionary`2 parameters) +208
System.Web.Mvc.ControllerActionInvoker.InvokeActionMethod(ControllerContext controllerContext, ActionDescriptor actionDescriptor, IDictionary`2 parameters) +27
System.Web.Mvc.<>c__DisplayClass15.<InvokeActionMethodWithFilters>b__12() +55
System.Web.Mvc.ControllerActionInvoker.InvokeActionMethodFilter(IActionFilter filter, ActionExecutingContext preContext, Func`1 continuation) +263
System.Web.Mvc.<>c__DisplayClass17.<InvokeActionMethodWithFilters>b__14() +19
System.Web.Mvc.ControllerActionInvoker.InvokeActionMethodWithFilters(ControllerContext controllerContext, IList`1 filters, ActionDescriptor actionDescriptor, IDictionary`2 parameters) +191
System.Web.Mvc.ControllerActionInvoker.InvokeAction(ControllerContext controllerContext, String actionName) +343
System.Web.Mvc.Controller.ExecuteCore() +116
System.Web.Mvc.ControllerBase.Execute(RequestContext requestContext) +97
System.Web.Mvc.ControllerBase.System.Web.Mvc.IController.Execute(RequestContext requestContext) +10
System.Web.Mvc.<>c__DisplayClassb.<BeginProcessRequest>b__5() +37
System.Web.Mvc.Async.<>c__DisplayClass1.<MakeVoidDelegate>b__0() +21
System.Web.Mvc.Async.<>c__DisplayClass8`1.<BeginSynchronous>b__7(IAsyncResult _) +12
System.Web.Mvc.Async.WrappedAsyncResult`1.End() +62
System.Web.Mvc.<>c__DisplayClasse.<EndProcessRequest>b__d() +50
System.Web.Mvc.SecurityUtil.<GetCallInAppTrustThunk>b__0(Action f) +7
System.Web.Mvc.SecurityUtil.ProcessInApplicationTrust(Action action) +22
System.Web.Mvc.MvcHandler.EndProcessRequest(IAsyncResult asyncResult) +60
System.Web.Mvc.MvcHandler.System.Web.IHttpAsyncHandler.EndProcessRequest(IAsyncResult result) +9
System.Web.CallHandlerExecutionStep.System.Web.HttpApplication.IExecutionStep.Execute() +8969117
System.Web.HttpApplication.ExecuteStep(IExecutionStep step, Boolean& completedSynchronously) +184
表结构
CREATE TABLE WEBORDERHD (
PICKNO Char( 9 ),
STATION Char( 10 ),
CUSTNO Char( 32 ),
COMPANY Char( 35 ),
BNAME Char( 255 ),
ADDRESS1 Char( 30 ),
ADDRESS2 Char( 30 ),
CITY Char( 64 ),
STATE Char( 2 ),
ZIP Char( 10 ),
SCOMPANY Char( 35 ),
SNAME Char( 255 ),
SADDRESS1 Char( 30 ),
SADDRESS2 Char( 30 ),
SCITY Char( 64 ),
SSTATE Char( 2 ),
SZIP Char( 10 ),
SALESPN Char( 10 ),
TAXRATE Numeric( 6 ,3 ),
CERTIFICA Char( 10 ),
TOTAL Numeric( 11 ,2 ),
CONTACT Char( 15 ),
TITLE Char( 10 ),
PHONE Char( 17 ),
FAX Char( 17 ),
BEEPER Char( 17 ),
FREIGHT Numeric( 11 ,2 ),
FINVNO Char( 6 ),
CUSTNOTE Memo,
MEMO Memo,
MODDATE Date,
PRNDATE Date,
SHIPVIA Char( 15 ),
SHIPDATE Date,
DATE Date,
STATUS Char( 30 ),
EMAIL Char( 128 ),
TAX Numeric( 11 ,2 ),
PAYTYPE Char( 20 ),
PAYREF Char( 20 ),
CCREF Char( 50 ),
PK Char( 36 ),
ORDTIME Char( 8 ),
SHIPMETHOD Char( 30 ),
PROCSTATUS Char( 20 ),
CUSTOMERPONO Char( 50 ),
CUSTOMERJOBNO Char( 50 ),
CUSTOMERPOCONTACT Char( 50 ),
CUSTOMERPOCOMMENT Memo,
S_COUNTRY Char( 10 ),
B_COUNTRY Char( 10 ),
SHIPBRANCH Char( 3 )) IN DATABASE;
【问题讨论】:
Stacktrace 会有所帮助:) 您的 WebOrderHd 数据库表的结构是什么?如果右键单击 Data Architect 中的表并单击 Generate SQL Script,您能否将得到的 SQL 添加到您的问题中? (至少是它的相关部分。) 我也添加了结构。请帮帮我~ 从 CREATE TABLE 语句中不清楚主键确实存在。它应该是“PK Char(36) Primary Key”。但主键也可以稍后添加。在任何情况下,您都可能想验证它是否存在。 是的,主键是PK字段,表类型是ADT,索引字段是PK和PICKNO字段。 【参考方案1】:我绝不是 EF 的专家,但是...您是否尝试过将 PK 属性虚拟化?我的理解是 EF 需要使用您的模型创建一个代理,因此它们必须是虚拟的,以便它可以按照它需要的方式实现它。
[Key]
public virtual string PK get; set;
另外,我建议您先尝试在没有高级模式的情况下访问数据,这样您就可以验证基础工作。我总是添加一个单独的控制台项目并在其中进行测试,因为您不必为了查看结果而创建整个页面。
【讨论】:
谢谢,我尝试了“public virtual string PK get; set; ”,但仍然显示相同的错误消息。这是我第一次使用 ASP.NET,所以我不知道如何简单地进行 DB 连接测试。现在我在谷歌上搜索那个;p 啊,问题就出在这里:P 另外.. ASP.NET 和 MVC 是不同的。确保当您在 Google 上查找“MVC 3”和 C# 时,这将有助于缩小您的搜索范围。这是一个可以帮助您开始使用此功能的链接。asp.net/mvc/tutorials/mvc-music-store/mvc-music-store-part-1 您可以使用控制台应用程序来初始化您的数据库并获取数据,就像在教程中一样接受您不要在网页中加载它:) 我在控制台应用中试过,AdsConnection conn = new AdsConnection("Data Source=\\\\XXX.XX.XX.XX:6262\\DB_BACK\\SD.ADD;ServerType=REMOTE; User ID=AdsSys;Password=xxxxx") ...而且效果很好....但我仍然不知道如何使它在实体框架数据模型中工作... =3以上是关于如何在 ASP.net MVC3 中获取 Advantage Database 数据?的主要内容,如果未能解决你的问题,请参考以下文章
如何在 ASP.NET MVC3 中使用“FormCollection”接收关联数组数据
如何在 ASP.NET MVC3 中通过 HTTPS 提供静态文件(在 ~/Content 中)
如何使用代码优先实体框架在 ASP.Net MVC3 中重新加载多对多导航属性