LLBLGen - 如何使用CatalogNameOverwriteHashtable

时间:2013-10-16 13:13:15

标签: c# llblgenpro llblgen

我正在尝试从两个不同的目录中加入两个表,但我无法开始工作。

我知道我必须对CatalogNameOVerwriteHashtable做一些事情,但显然我做错了。

文档链接(http://www.llblgen.com/documentation/2.6/using%20the%20generated%20code/Adapter/gencode_dataaccessadapter_adapter.htm)没有提供足够的信息来解决我的挑战。

我有以下情况:

  • 我有两个目录:CatalogA和CatalogB
  • CatalogA中有Article-table,CatalogB中有StockCount-table

我创建了一个手动关系。到目前为止一切都很好。

我的猜测是我有以下行动:

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

导致以下查询:

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])

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

1 个答案:

答案 0 :(得分:1)

最后解决方案非常简单,证明了为什么LLBLGen功能强大且易于使用。

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

var catalogName = ORMapper.Utils.DatabasePersistenceInfo.GetFieldPersistenceInfo(ArticleFields.PKey).SourceCatalogName;

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

您接下来要做的是将开发目录名称与生产目录名称映射。像这样:

adapter = new DataAccessAdapter("Your connection string");
adapter.CatalogNameOverwrites =new CatalogNameOverwriteHashtable();
adapter.CatalogNameOverwrites.Add(catalogName, "ProductionCatalogName");