db4o Tutorial 中文翻译(八)
6. 继承
到现在为止,我们已经可以操作实体类了。但是如何操作子类或者接口呢?
为了方便讲解,我们将创造不同种类的sensors
Sensor
TemperatureSensorReadout
PressureSensorReadout
Car的snapshot也要跟着变化:
new car
6.1. 存储
代码只是加入了与sensor的交互而已,其他部分没有动:
// storeFirstCar
Car car1 = new Car("Ferrari");
Pilot pilot1 = new Pilot("Michael Schumacher", 100);
car1.Pilot = pilot1;
db.Set(car1);
Car car1 = new Car("Ferrari");
Pilot pilot1 = new Pilot("Michael Schumacher", 100);
car1.Pilot = pilot1;
db.Set(car1);
// storeSecondCar
Pilot pilot2 = new Pilot("Rubens Barrichello", 99);
Car car2 = new Car("BMW");
car2.Pilot = pilot2;
car2.Snapshot();
car2.Snapshot();
db.Set(car2);
Pilot pilot2 = new Pilot("Rubens Barrichello", 99);
Car car2 = new Car("BMW");
car2.Pilot = pilot2;
car2.Snapshot();
car2.Snapshot();
db.Set(car2);
6.2. 检索
db4o提供所有的给定类型的对象。在检索给定类型的对象时候,不管他们是否是子类或者其他,只要给出一个原型就可以。
// retrieveTemperatureReadoutsQBE
SensorReadout proto = new TemperatureSensorReadout(DateTime.MinValue, null, null, 0.0);
IObjectSet result = db.Get(proto);
ListResult(result);
SensorReadout proto = new TemperatureSensorReadout(DateTime.MinValue, null, null, 0.0);
IObjectSet result = db.Get(proto);
ListResult(result);
// retrieveAllSensorReadoutsQBE
SensorReadout proto = new SensorReadout(DateTime.MinValue, null, null);
IObjectSet result = db.Get(proto);
ListResult(result);
SensorReadout proto = new SensorReadout(DateTime.MinValue, null, null);
IObjectSet result = db.Get(proto);
ListResult(result);
当在如下情况时QBE就不合适了:如果给定的类是一个接口或者抽象类。有一个小诀窍:只要获取对象的类型就可以了
// retrieveAllSensorReadoutsQBEAlternative
IObjectSet result = db.Get(typeof(SensorReadout));
ListResult(result);
IObjectSet result = db.Get(typeof(SensorReadout));
ListResult(result);
当然,还有SODA API:
// retrieveAllSensorReadoutsQuery
IQuery query = db.Query();
query.Constrain(typeof(SensorReadout));
IObjectSet result = query.Execute();
ListResult(result);
IQuery query = db.Query();
query.Constrain(typeof(SensorReadout));
IObjectSet result = query.Execute();
ListResult(result);
6.3. 更新和删除
不管他们在继承树的哪里,他们都和正常的对象一样。.
就像刚刚我们的检索过程, 我们可以删除所有的对象,好进行下一章的讲解。
// deleteAll
IObjectSet result = db.Get(typeof(Object));
foreach (object item in result)
{
db.Delete(item);
}
IObjectSet result = db.Get(typeof(Object));
foreach (object item in result)
{
db.Delete(item);
}
6.4. 总结
现在我们已经知道了所有的OO特征如何在db4o里面操作。我们将在下一章完成预排工作,下一章将可以看到深层次的探险,包括循环结构。
6.5. 完整代码
锘縰sing System;
using System.IO;
using Db4objects.Db4o;
using Db4objects.Db4o.Query;
namespace Db4objects.Db4o.Tutorial.F1.Chapter4
{
public class InheritanceExample : Util
{
public static void Main(string[] args)
{
File.Delete(Util.YapFileName);
IObjectContainer db = Db4oFactory.OpenFile(Util.YapFileName);
try
{
StoreFirstCar(db);
StoreSecondCar(db);
RetrieveTemperatureReadoutsQBE(db);
RetrieveAllSensorReadoutsQBE(db);
RetrieveAllSensorReadoutsQBEAlternative(db);
RetrieveAllSensorReadoutsQuery(db);
RetrieveAllObjects(db);
}
finally
{
db.Close();
}
}
public static void StoreFirstCar(IObjectContainer db)
{
Car car1 = new Car("Ferrari");
Pilot pilot1 = new Pilot("Michael Schumacher", 100);
car1.Pilot = pilot1;
db.Set(car1);
}
public static void StoreSecondCar(IObjectContainer db)
{
Pilot pilot2 = new Pilot("Rubens Barrichello", 99);
Car car2 = new Car("BMW");
car2.Pilot = pilot2;
car2.Snapshot();
car2.Snapshot();
db.Set(car2);
}
public static void RetrieveAllSensorReadoutsQBE(IObjectContainer db)
{
SensorReadout proto = new SensorReadout(DateTime.MinValue, null, null);
IObjectSet result = db.Get(proto);
ListResult(result);
}
public static void RetrieveTemperatureReadoutsQBE(IObjectContainer db)
{
SensorReadout proto = new TemperatureSensorReadout(DateTime.MinValue, null, null, 0.0);
IObjectSet result = db.Get(proto);
ListResult(result);
}
public static void RetrieveAllSensorReadoutsQBEAlternative(IObjectContainer db)
{
IObjectSet result = db.Get(typeof(SensorReadout));
ListResult(result);
}
public static void RetrieveAllSensorReadoutsQuery(IObjectContainer db)
{
IQuery query = db.Query();
query.Constrain(typeof(SensorReadout));
IObjectSet result = query.Execute();
ListResult(result);
}
public static void RetrieveAllObjects(IObjectContainer db)
{
IObjectSet result = db.Get(new object());
ListResult(result);
}
}
}
using System.IO;
using Db4objects.Db4o;
using Db4objects.Db4o.Query;
namespace Db4objects.Db4o.Tutorial.F1.Chapter4
{
public class InheritanceExample : Util
{
public static void Main(string[] args)
{
File.Delete(Util.YapFileName);
IObjectContainer db = Db4oFactory.OpenFile(Util.YapFileName);
try
{
StoreFirstCar(db);
StoreSecondCar(db);
RetrieveTemperatureReadoutsQBE(db);
RetrieveAllSensorReadoutsQBE(db);
RetrieveAllSensorReadoutsQBEAlternative(db);
RetrieveAllSensorReadoutsQuery(db);
RetrieveAllObjects(db);
}
finally
{
db.Close();
}
}
public static void StoreFirstCar(IObjectContainer db)
{
Car car1 = new Car("Ferrari");
Pilot pilot1 = new Pilot("Michael Schumacher", 100);
car1.Pilot = pilot1;
db.Set(car1);
}
public static void StoreSecondCar(IObjectContainer db)
{
Pilot pilot2 = new Pilot("Rubens Barrichello", 99);
Car car2 = new Car("BMW");
car2.Pilot = pilot2;
car2.Snapshot();
car2.Snapshot();
db.Set(car2);
}
public static void RetrieveAllSensorReadoutsQBE(IObjectContainer db)
{
SensorReadout proto = new SensorReadout(DateTime.MinValue, null, null);
IObjectSet result = db.Get(proto);
ListResult(result);
}
public static void RetrieveTemperatureReadoutsQBE(IObjectContainer db)
{
SensorReadout proto = new TemperatureSensorReadout(DateTime.MinValue, null, null, 0.0);
IObjectSet result = db.Get(proto);
ListResult(result);
}
public static void RetrieveAllSensorReadoutsQBEAlternative(IObjectContainer db)
{
IObjectSet result = db.Get(typeof(SensorReadout));
ListResult(result);
}
public static void RetrieveAllSensorReadoutsQuery(IObjectContainer db)
{
IQuery query = db.Query();
query.Constrain(typeof(SensorReadout));
IObjectSet result = query.Execute();
ListResult(result);
}
public static void RetrieveAllObjects(IObjectContainer db)
{
IObjectSet result = db.Get(new object());
ListResult(result);
}
}
}
Surance Yin@ Surance Center
转载请注明出处
转载请注明出处