我试图连接两个不同目录中的两个表,但我无法工作。
我知道我必须对CatalogNameOVerwriteHashtable做点什么,但显然我做错了什么。
文档链接(adapter.htm)没有提供足够的信息来解决我的挑战。
我有以下情况:
我创造了一种人工关系。到目前一切尚好。
我的猜测是,我有以下行为:
这将导致以下查询:
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])显然,我做错了什么,因为查询中缺少目录名称。问题是,什么?
发布于 2013-10-18 08:07:59
最后,该解决方案非常简单,并证明了为什么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");https://stackoverflow.com/questions/19404430
复制相似问题