summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorJames Ahlborn <jtahlborn@yahoo.com>2012-07-26 02:46:28 +0000
committerJames Ahlborn <jtahlborn@yahoo.com>2012-07-26 02:46:28 +0000
commit64f98b1d1067fbaa4d7cf2a825e682f845c600a7 (patch)
tree8bbc8706e77bd5e2984cc4c14f843b9dde636d45 /src
parenta8aecc707332c78c335fed90c130c848184831b0 (diff)
downloadjackcess-64f98b1d1067fbaa4d7cf2a825e682f845c600a7.tar.gz
jackcess-64f98b1d1067fbaa4d7cf2a825e682f845c600a7.zip
more cookbook work
git-svn-id: https://svn.code.sf.net/p/jackcess/code/jackcess/trunk@639 f203690c-595d-4dc9-a70b-905162fa7fd2
Diffstat (limited to 'src')
-rw-r--r--src/site/xdoc/cookbook.xml64
1 files changed, 62 insertions, 2 deletions
diff --git a/src/site/xdoc/cookbook.xml b/src/site/xdoc/cookbook.xml
index e40a403..6946c3b 100644
--- a/src/site/xdoc/cookbook.xml
+++ b/src/site/xdoc/cookbook.xml
@@ -27,7 +27,13 @@
may be used in places where the actual code is not relevant to the
example.
</p>
+<macro name="toc">
+ <param name="section" value="2"/>
+ <param name="fromDepth" value="0"/>
+ <param name="toDepth" value="4"/>
+</macro>
</section>
+
<section name="The Basics">
<subsection name="Opening a Database">
<p>
@@ -68,17 +74,71 @@
Where's the data? While a <a
href="apidocs/com/healthmarketscience/jackcess/Cursor.html">Cursor</a>
is the best way to interact with the data in a Table, for the sake
- of simplicity when just getting started we will use the simplified
+ of simplicity when just getting started, we will use the simplified
iteration provided by the Table class itself. When reading row
data, it is generally provided as a <code>Map&lt;String,Object&gt;</code> where the keys are the column
names and the values are the strongly typed column values.
</p>
<source>
for(Map&lt;String,Object&gt; row : table) {
- System.out.prinln("The row data is: " + row);
+ System.out.prinln("Look ma, a row: " + row);
}
</source>
+ <p>
+ So, what's in a row? Well, let's assume your "Test" table is
+ defined in the following way in Access:
+ </p>
+ <blockquote>
+ <table>
+ <tr>
+ <th>Field Name</th><th>Data Type</th>
+ </tr>
+ <tr>
+ <td>ID</td><td>AutoNumber (Long Integer)</td>
+ </tr>
+ <tr>
+ <td>Name</td><td>Text</td>
+ </tr>
+ <tr>
+ <td>Salary</td><td>Currency</td>
+ </tr>
+ <tr>
+ <td>StartDate</td><td>Date/Time</td>
+ </tr>
+ </table>
+ </blockquote>
+ <p>
+ Then, given a row of data, we could inspect the various <a href="apidocs/com/healthmarketscience/jackcess/Column.html">Columns</a> and
+ their values like so:
+ </p>
+<source>
+ Map&lt;String,Object&gt; row = ...;
+ for(Column column : table.getColumns()) {
+ String columnName = column.getName();
+ Object value = row.get(columnName);
+ System.out.println("Column " + columnName + "(" + column.getType() + "): "
+ + value + " (" + value.getClass() + ")");
+ }
+
+ // Example Output:
+ //
+ // Column ID(LONG): 27 (java.lang.Integer)
+ // Column Name(TEXT): Bob Smith (java.lang.String)
+ // Column Name(MONEY): 50000.00 (java.math.BigDecimal)
+ // Column StartDate(SHORT_DATE_TIME): Mon Jan 05 09:00:00 EDT 2010 (java.util.Date)
+</source>
+ <p>
+ As you can see in this example (and as previously mentioned), the
+ row values are <i>strongly typed</i> Java objects. In Jackcess, the
+ column types are represented by a Java enum named <a href="apidocs/com/healthmarketscience/jackcess/DataType.html">DataType</a>.
+ The DataType javadoc details the Java types used to return row
+ values as well as the value types which are acceptable inputs for
+ new rows (more on this later). One other thing to note in this
+ example is that the column names in the row Map are <i>case
+ sensitive</i> strings.
+ </p>
</subsection>
</section>
+
</body>
</document>