首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >LLBLGen -如何使用CatalogNameOverwriteHashtable

LLBLGen -如何使用CatalogNameOverwriteHashtable
EN

Stack Overflow用户
提问于 2013-10-16 13:13:14
回答 1查看 157关注 0票数 2

我试图连接两个不同目录中的两个表,但我无法工作。

我知道我必须对CatalogNameOVerwriteHashtable做点什么,但显然我做错了什么。

文档链接(adapter.htm)没有提供足够的信息来解决我的挑战。

我有以下情况:

  • 我有两个目录: CatalogA和CatalogB
  • CatalogA中有商品表,CatalogB中有库存表

我创造了一种人工关系。到目前一切尚好。

我的猜测是,我有以下行为:

  • 创建一个新的CatalogNameOverwriteHashtable实例: var foo =();
  • Foo.Add(StockCount,CatalogA);
  • Foo.Add(“条款”、"CatalogB");
  • 将其分配给适配器: adapter.CatalogNameOverwrites = foo;

这将导致以下查询:

代码语言:javascript
复制
SELECT 
[dbo].[StockCount].[ArticleId], 
[dbo].[Article].[Description], 
[dbo].[StockCount].[ShopId], 
[dbo].[StockCount].[LastMutationDateTime]
FROM ( [dbo].[StockCount] INNER JOIN 
[dbo].[Article] ON [dbo].[StockCount].[ArticleId]=[dbo].[Article].[ArticleId])

显然,我做错了什么,因为查询中缺少目录名称。问题是,什么?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2013-10-18 08:07:59

最后,该解决方案非常简单,并证明了为什么LLBLGen如此强大和易于使用。

首先。生成实体时,目录名称存储在FieldInfoProviders中。这可以通过以下指令检索:

代码语言:javascript
复制
var catalogName = ORMapper.Utils.DatabasePersistenceInfo.GetFieldPersistenceInfo(ArticleFields.PKey).SourceCatalogName;

此目录名称是用于生成针对的实体的目录。这可能是您的开发数据库。

接下来要做的就是用产品目录名称映射开发目录名称。就像这样:

代码语言:javascript
复制
adapter = new DataAccessAdapter("Your connection string");
adapter.CatalogNameOverwrites =new CatalogNameOverwriteHashtable();
adapter.CatalogNameOverwrites.Add(catalogName, "ProductionCatalogName");
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/19404430

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档