/*- * See the file LICENSE for redistribution information. * * Copyright (c) 2002-2003 * Sleepycat Software. All rights reserved. * * $Id: Shipment.java,v 1.2 2004/03/30 01:23:24 jtownsen Exp $ */ package com.sleepycat.examples.bdb.shipment.sentity; import java.io.Serializable; /** * A Shipment represents the combined key/value pair for a shipment entity. * *

In this sample, Shipment is created from the stored key/value data using * TupleSerialEntityBinding. See {@link SampleViews.PartBinding} for details. *

* *

The binding is "tricky" in that it uses this class for both the stored * data value and the combined entity object. To do this, the key field(s) are * transient and are set by the binding after the data object has been * deserialized. This avoids the use of a ShipmentValue class completely.

* *

Since this class is used directly for data storage, it must be * Serializable.

* * @author Mark Hayes */ public class Shipment implements Serializable { private transient String partNumber; private transient String supplierNumber; private int quantity; public Shipment(String partNumber, String supplierNumber, int quantity) { this.partNumber = partNumber; this.supplierNumber = supplierNumber; this.quantity = quantity; } /** * Set the transient key fields after deserializing. This method is only * called by data bindings. */ void setKey(String partNumber, String supplierNumber) { this.partNumber = partNumber; this.supplierNumber = supplierNumber; } public final String getPartNumber() { return partNumber; } public final String getSupplierNumber() { return supplierNumber; } public final int getQuantity() { return quantity; } public String toString() { return "[Shipment: part=" + partNumber + " supplier=" + supplierNumber + " quantity=" + quantity + ']'; } }