C# LLBLGen-如何使用CatalogNameOverwriteHashtable

C# LLBLGen-如何使用CatalogNameOverwriteHashtable,c#,llblgenpro,llblgen,C#,Llblgenpro,Llblgen,我正试图连接两个不同目录中的两个表,但我无法开始工作 我知道我必须对CatalogNameOverwritehHashtable做些什么,但显然我做错了什么 文档链接()没有提供足够的信息来解决我的问题 我有以下情况: 我有两个目录:目录A和目录B CatalogA中有一个Article表,CatalogB中有一个StockCount表 我创建了一个手动关系。到目前为止还不错 我猜我有以下行为: 创建新的CatalogNameOverwriteHashtable实例: var foo=ne

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

我知道我必须对CatalogNameOverwritehHashtable做些什么,但显然我做错了什么

文档链接()没有提供足够的信息来解决我的问题

我有以下情况:

  • 我有两个目录:目录A和目录B
  • CatalogA中有一个Article表,CatalogB中有一个StockCount表
我创建了一个手动关系。到目前为止还不错

我猜我有以下行为:

  • 创建新的CatalogNameOverwriteHashtable实例: var foo=new catalogname overwritehashtable()
  • foo.Add(“库存盘点”、“目录A”)
  • foo.Add(“第条”、“目录B”)
  • 将其分配给适配器: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");

我刚刚解决了我的问题。使用CatalogNameOverwriteHashtable类并指定给CatalogNameOverwrites属性。在此哈希表中,将生产目录名称指定给开发目录名称。