CatalogNameOverwriteHashtable

CatalogNameOverwriteHashtable

我试图将来自两个不同目录的两个表联接起来,但是我无法上班。

我知道我必须对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])


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

最佳答案

最后,该解决方案非常简单,并证明了为什么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");

关于c# - LLBLGen-如何使用CatalogNameOverwriteHashtable,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/19404430/

10-16 12:38