aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--src/main/java/com/healthmarketscience/jackcess/RelationshipBuilder.java14
-rw-r--r--src/site/xdoc/cookbook.xml38
-rw-r--r--src/test/java/com/healthmarketscience/jackcess/TableUpdaterTest.java10
3 files changed, 38 insertions, 24 deletions
diff --git a/src/main/java/com/healthmarketscience/jackcess/RelationshipBuilder.java b/src/main/java/com/healthmarketscience/jackcess/RelationshipBuilder.java
index 8ba9bb1..e52ea80 100644
--- a/src/main/java/com/healthmarketscience/jackcess/RelationshipBuilder.java
+++ b/src/main/java/com/healthmarketscience/jackcess/RelationshipBuilder.java
@@ -59,8 +59,11 @@ public class RelationshipBuilder
private List<String> _fromCols = new ArrayList<String>();
private List<String> _toCols = new ArrayList<String>();
- public RelationshipBuilder(String fromTable, String toTable)
- {
+ public RelationshipBuilder(Table fromTable, Table toTable) {
+ this(fromTable.getName(), toTable.getName());
+ }
+
+ public RelationshipBuilder(String fromTable, String toTable) {
_fromTable = fromTable;
_toTable = toTable;
}
@@ -75,6 +78,13 @@ public class RelationshipBuilder
}
/**
+ * Adds a pair of columns to the relationship.
+ */
+ public RelationshipBuilder addColumns(Column fromCol, Column toCol) {
+ return addColumns(fromCol.getName(), toCol.getName());
+ }
+
+ /**
* Enables referential integrity enforcement for this relationship.
*
* Note, this requires the "from" table to have an existing unique index on
diff --git a/src/site/xdoc/cookbook.xml b/src/site/xdoc/cookbook.xml
index 4ad5649..fca2519 100644
--- a/src/site/xdoc/cookbook.xml
+++ b/src/site/xdoc/cookbook.xml
@@ -243,13 +243,12 @@
.addColumn(new ColumnBuilder("StartDate", DataType.SHORT_DATE_TIME))
.toTable(db);
</source>
- </subsection>
- <p>
- That is a very simple Table. In the real world, we often need Indexes
- to speed up lookups and enforce uniqueness constraints. Adding the
- following to the previous example will make the "ID" column a primary
- key and enable speedier lookups on the "Name" column.
- </p>
+ <p>
+ That is a very simple Table. In the real world, we often need Indexes
+ to speed up lookups and enforce uniqueness constraints. Adding the
+ following to the previous example will make the "ID" column a primary
+ key and enable speedier lookups on the "Name" column.
+ </p>
<source>
// ... new TableBuilder( ...
.addIndex(new IndexBuilder(IndexBuilder.PRIMARY_KEY_NAME)
@@ -258,11 +257,12 @@
.addColumns("Name"))
// ... .toTable( ...
</source>
- <p>
- Don't forget to close the Database when you are finished building it
- and now you have a fresh, new Database on which to test some more
- recipes.
- </p>
+ <p>
+ Don't forget to close the Database when you are finished building it
+ and now you have a fresh, new Database on which to test some more
+ recipes.
+ </p>
+ </subsection>
</section>
<section name="Finding Stuff">
@@ -363,17 +363,13 @@
}
</source>
</subsection>
-
- <p>
- FIXME, writeme
- </p>
</section>
- <section name="Miscellaneous Examples">
- <p>
- FIXME, writeme
- </p>
- </section>
+ <!-- <section name="Miscellaneous Examples"> -->
+ <!-- <p> -->
+ <!-- FIXME, writeme -->
+ <!-- </p> -->
+ <!-- </section> -->
</body>
</document>
diff --git a/src/test/java/com/healthmarketscience/jackcess/TableUpdaterTest.java b/src/test/java/com/healthmarketscience/jackcess/TableUpdaterTest.java
index 2f3a1a8..564c334 100644
--- a/src/test/java/com/healthmarketscience/jackcess/TableUpdaterTest.java
+++ b/src/test/java/com/healthmarketscience/jackcess/TableUpdaterTest.java
@@ -195,11 +195,19 @@ public class TableUpdaterTest extends TestCase
// success
}
- new TableBuilder("TestTable2")
+ Table t2 = new TableBuilder("TestTable2")
.addColumn(new ColumnBuilder("id2", DataType.LONG))
.toTable(db);
try {
+ new RelationshipBuilder(t1, t2)
+ .toRelationship(db);
+ fail("created rel with no columns?");
+ } catch(IllegalArgumentException e) {
+ // success
+ }
+
+ try {
new RelationshipBuilder("TestTable", "TestTable2")
.addColumns("id", "id")
.toRelationship(db);