使用db4o和一个简单的嵌套结构遇到棘手的问题。
问题:当我使用LINQ从db4o中提取数据时,它会抽出太多数据(即“where”子句似乎没有工作)。
我有一些嵌套对象:
Root ----Symbol (SPX)
| |------Day 1: Date: 2010-10-18, string "SPX meta"
| |------Day 2: Date: 2010-10-19, string "SPX meta"
|
|
|-----Symbol (IBM)
|------Day 1: Date: 2010-10-18, string "IBM meta"
|------Day 2: Date: 2010-10-19, string "IBM meta"
我创建了两个符号:
Symbol sym1 = new Symbol("SPX");
Symbol sym2 = new Symbol("IBM");
然后我创建了一些交易日:
// SPX
TradingDay day1 = new TradingDay(new DateTime(2010, 10, 18), "SPX meta");
TradingDay day2 = new TradingDay(new DateTime(2010, 10, 19), "SPX meta");
// IBM
TradingDay day3 = new TradingDay(new DateTime(2010, 10, 18), "IBM meta");
TradingDay day4 = new TradingDay(new DateTime(2010, 10, 19), "IBM meta");
然后我为每个符号指定了几天:
sym1.AssignTradingDay(day1);
sym1.AssignTradingDay(day2);
sym2.AssignTradingDay(day3);
sym2.AssignTradingDay(day4);
然后我将它持久化到db4o对象数据库:
// Store in the database.
db4o.db.Store(sym1);
db4o.db.Store(sym2);
db4o.db.Commit();
到目前为止非常简单。
我用“db4o Object Manager Enterprise”检查数据库,果然,有两个符号,如果我点击每个符号,每个符号包含两天。
现在,我执行LINQ查询以提取数据:
var daysForSymbolS1 = from Symbol s in db4o.db
from TradingDay t in db4o.db
where (s.SymbolGlobal == "IBM"
&& t.Date == new DateTime(2010, 10, 19))
select new
{
s.SymbolGlobal,
t.Date,
t.Meta
};
foreach (var d in daysForSymbolS1)
{
Console.WriteLine("{0} - {1} - {2}", d.SymbolGlobal, d.Date.Date, d.Meta);
}
并且,发生了一些奇怪的事情:
IBM - 10/19/2010 12:00:00 AM - SPX meta // This line should not appear because we have specified "IBM" in the filter.
IBM - 10/19/2010 12:00:00 AM - IBM meta
尽管我指定它应该只返回“SPX”的数据,它也会从“IBM”返回数据。
我做了什么明显的错误吗?
答案 0 :(得分:1)
您没有发布您的类的确切定义,但您当前正在Linq查询中执行cartesian product - 您正在创建所有可能的组合,而您实际上只需要“匹配”组合(自交易日起)在您的架构中由于某种原因似乎与符号相关联)。你应该做的是一个连接,如:
from TradingDay t in db4o.db
join Symbol s in db4o.db
on s.SymbolGlobal equals t.SymbolGlobal
where (s.SymbolGlobal == "IBM"
&& t.Date == new DateTime(2010, 10, 19))
...