c# - LLBLGen - 如何使用 CatalogNameOverwriteHashtable

标签 c# llblgenpro llblgen

我正在尝试连接来自两个不同目录的两个表,但无法开始工作。

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

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

我有以下情况:

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

我已经创建了一个手动关系。到目前为止一切顺利。

我的猜测是我有以下操作:

  • 创建一个新的 CatalogNameOverwriteHashtable 实例: var foo = new CatalogNameOverwriteHashtable();
  • foo.Add("StockCount", "CatalogA");
  • 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");

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

相关文章:

llblgenpro - 如何使用 LLBLGen Pro 过滤掉不在多对多关系中的实体?

c# - llblgen 2.6 中相关字段的排序

c# - 使用 SQL Command 对象,您如何检查结果集是否为空?

c# - 有人能更好地解释 nHibernate 中的 'Projections' 是什么吗?

c# - C# Request.Files[n].FileName 的哪个文件表单字段

sql - 什么是 "Scalar"查询?

c# - 如何使用ORM + LINQ 组合键查询?

c# - 在 TFS 中多次 checkin 后获取特定变更集

c# - 应该扩展还是封装 ORM 对象?

sql - LLBLGen 查看生成的 SQL 语句