ebook img

Frameworks for the Model PDF

147 Pages·2006·0.7 MB·English
by  
Save to my drive
Quick download
Download
Most books are stored in the elastic cloud where traffic is expensive. For this reason, we have a limit on daily download.

Preview Frameworks for the Model

A P P E N D I X A ■ ■ ■ Frameworks for the Model I n this appendix, I’ll provide simple examples of how to use Hibernate and Torque, and also (shameless plug) a simple, open source, “classes that persist” framework called Lisptorq, developed by the company I work for. I’ll illustrate the use of these persistence frameworks with the Registration webapp I first introduced in Chapter 5. I’ll show you how to persist different versions of the User class outlined in Listing A-1. Listing A-1. Skeleton for the Registration Webapp Model public class User{ protected String _userId = null; protected String _password = null; /* Bean-like getters and setters */ public String getUserId(){ return _userId; } public String setUserId(String userId){ _userId = userId; } public String getPassword(){ return _password; } public String setPassword(String password){ _password = password; } 359 360 APPENDIX A ■ FRAMEWORKS FOR THE MODEL /** * Checks if the userid exists. */ public static boolean exists(String userid){ //implementation omitted } /** * Saves the _userid and _password pair */ public void save() throws Exception{ //implementation omitted } } Getting the Software All three persistence frameworks discussed here are open source, and may be obtained freely from their websites: • Hibernate:www.hibernate.org • Torque:http://db.apache.org/torque/ • Lisptorq:www.thinksquared.net/dev/lisptorq/ Both Hibernate and Torque require some setup in order for you to use them in your projects. Consult their respective websites for installation instructions. Lisptorq, on the other hand, was specially designed to be easy to use and experiment with. You have to copy only two JAR files: a Java Lisp interpreter called jlisp and the Lisptorq JAR file, lisptorq.jar, which contains the LISP programs that constitute Lisptorq. Both of these are in the Source Code section of the Apress website, found at http://www. apress.com, but you should download the latest files from the URL listed earlier. Because Lisptorq is simple to understand and use, I’ll introduce it first, and give you some practice using it in Lab A. I’ll then redo the Registration webapp using Hibernate and Torque. Lisptorq Lisptorq is a code generator, and it produces Java source code given a database schema. These generated classes constitute the Model tier of your webapp. APPENDIX A ■ FRAMEWORKS FOR THE MODEL 361 As an example, Listing A-2 shows how you might define the database schema for the Registration webapp using Lisptorq. There’s just one table called user with two fields, user_id and password. Listing A-2. Defining the user Table in Lisptorq define database ( (user (user_id (REQUIRED PRIMARY (VARCHAR 32))) (password (REQUIRED (VARCHAR 32))) ) ) Listing A-2 should be self-explanatory. Both the user_id and password fields are mandatory, and the user_id field is used as a primary key. When Lisptorq is run on the schema described by Listing A-2 (I’ll show you how in the following lab), the output is four Model classes, plus four other helper classes. In general, for each table on the database schema, four Model classes are generated. The first two are called data object classes, which are really JavaBeans with properties for each column on the table. Persistence is handled by peer classes, which have methods for saving, deleting, and searching for data objects on the database. So, the generated Model classes for Listing A-2 using Lisptorq would be • BaseUser: Contains getters and setters for user_id and password. It also contains asave() method to persist the data in the class. • BaseUserPeer: Contains functions to persist a BaseUser class. It contains functions like doSave(),doDelete(), and doSelect(), which save, delete, and search for Users. • User: An empty class representing the user. You can write your own additional functions in this class. User extends BaseUser. • UserPeer: An empty subclass of BaseUserPeer. This class lets you extend the func- tionality of BaseUserPeer. Having four classes for one database entity might seem a little complicated, but there’s a method to the madness. The User class (a data object) holds data while the UserPeer classes (peer classes) are used to save, delete, or retrieve data objects from the database. The Base classes contain autogenerated functions that do the real work. The non-Base classes (User and UserPeer) are given to you to add additional functionality on top of the Base classes. Listing A-3 shows how you might save the user ID and password data using the User class. 362 APPENDIX A ■ FRAMEWORKS FOR THE MODEL Listing A-3. Saving a Lisptorq-Generated User Bean User u = new User(); u.setUserId("kolmogorov"); u.setPassword("turbulence23"); u.save(); These few lines do a lot behind the scenes: SQL is generated to save the user ID and password. Using Model classes saves you from writing a single line of SQL yourself! In addition to the four model classes (remember, four are created per table), Lisptorq always generates four helper classes: Criteria,Database,DatabaseSetup, and Scroller: • Criteria allows you to create queries without using SQL. • Database manages connections to the database. • DatabaseSetup gives you a main() function you can call to set up your database. You’d obviously need to use this class just once. • Scroller is an interface that extends java.util.Iterator. It represents an iterator that can iterate either forward (using the usual hasNext() and next()) or backward (using hasPrevious() and previous()). You may also position the “cursor” using absolute(). Listing A-4 is an implementation of the exists() function of Listing A-1 using the Criteria class as well as the User and UserPeer Model classes. Listing A-4. An Implementation of exists() using the Criteria and Model Classes public static boolean exists(String userId){ Criteria crit = new Criteria(); crit.add(User.USER_ID,userId); return UserPeer.doSelect(crit).iterator().hasNext(); } Lisptorq currently produces generated code optimized for Derby SQL. Derby is a Java embedded database, currently being “incubated” at Apache. It was donated by IBM, and was previously the proprietary Java embedded database called Cloudscape. It is one of the few open source databases available that support Atomicity, Consistency, Isolation, and Durability, or ACID (See “Useful Links”). The JAR file for Derby (derby.jar) is in the Source Code section of the Apress website at http://www.apress.com. APPENDIX A ■ FRAMEWORKS FOR THE MODEL 363 Lab A: Test Driving Lisptorq I hope the previous section has piqued your interest in using Model classes. To get your toes wet, in this lab session you’ll develop a simple application to store and retrieve data using Lisptorq-generated Model classes. In order for you to complete this lab, you must refer to the Lisptorq manual at www.thinksquared.net/dev/lisptorq/. Step 1: Preparing the Development Environment 1. Create a folder in your development environment called lisptorq. 2. Create a .\lib subfolder within this folder. 3. Extract jlisp.jar, the LISP interpreter found in jlisp_0.2.zip in the Source Code section of the Apress website at http://www.apress.com, into .\lib. 4. Save lisptorq.jar in the Source Code section of the Apress website into .\lib. 5. Save derby.jar, the Derby database driver in the Source Code section of the Apress website, into the development .\lib folder. Step 2: Writing the Database Schema In what follows, we will create a simple bookstore app, in which we’ll store books along with publisher and author information. (This app originally appeared in Apache Torque’s tutorial.) The database has three tables: • author: Has four columns: author_id,first_name,last_name, and full_name. Make author_id an autogenerated field. It should also be a primary key for this table. • publisher: Has just two columns: publisher_id and name. Make publisher_id an autogenerated field. It should also be a primary key for this table. • book: Has four columns: title and ISBN to hold data; author_id, which is a foreign key to the author_id column in the author table; and publisher_id, which is a foreign key to the publisher table. It should be fairly transparent what the three tables represent. Apart from the three ID columns, which should be INTEGERs, the other columns should be (VARCHAR 255). You need to complete the following: 364 APPENDIX A ■ FRAMEWORKS FOR THE MODEL 1. Create a new text file called main.lisp in the Lisptorq development folder. 2. Open this up with Notepad (or your favorite IDE), and write the Lisptorq database schema for this database. You will certainly need help—please refer to the Lisptorq manual at www.thinksquared.net/dev/lisptorq/. Step 3: Specifying the Database Settings Derby is an embedded database, so you have to give it a folder to store the database files, and you have to specify a system property called derby-home. These tasks are done for you by Lisptorq’s generated helper classes, but you have to supply the information. Here are the configuration parameters you must specify: • database-type should be set to derby. • database-name should be set to bookstore. • derby-home should be set to ./bookstore. • package should be set to net.bookstore. Again, refer to the online manual for help on how to set these configuration parameters. database-type is set to derby because we’re using the Derby database for this lab. database-name specifies how the generated classes will internally refer to the database. The derby-home setting is required by Derby, and is a path that points to the folder that contains the database files. You do not have to create this folder yourself; it will be done for you by the DatabaseSetup program. Finally, the package setting is the package in which you would like to place the generated classes. Step 4: Generate the Java Files First, enter (lisptorq:generate database) at the end of main.lisp. This command is a request to generate the Model classes. Next, run main.lisp in order to generate all the Model tier source code files: java -classpath .\lib\jlisp.jar;.\lib\lisptorq.jar net.thinksquared.jlisp.Loader main.lisp If all goes well, you should see 16 files (four for each table plus four helper classes) in the development folder. The next step is to write a test program to write and retrieve records. APPENDIX A ■ FRAMEWORKS FOR THE MODEL 365 Step 5: Writing the Test Program Write a simple test program in the file Test.java to store the following information: • Authors: Lewis Carroll, Harold Edwards, Arthur Conan Doyle • Publishers: Dover Books, MacmillanPublishers • Books: •Alice in Wonderland, by Lewis Carroll, Dover Books •Riemann’s Zeta Function, by Harold Edwards, Dover Books •The Sherlock Holmes Casebook, by A. C. Doyle, MacmillanPublishers •Through the Looking Glass, by Lewis Carroll, MacmillanPublishers Enter this information into the relevant data objects, and then save them. Remember that Books require foreign keys. How will you specify these? Once the data is saved, run the following queries: • List all books and their authors from Dover Books. • List all the publishers that carry books by Lewis Carroll. Again, you should refer to the online manual for help. Step 6: Initializing the Database Compile your work (javac *.java) and then run DatabaseSetup to create the database: java -classpath ./lib/derby.jar org.bookstore.DatabaseSetup You should see the database files created in the .\bookstore folder. Step 7: Running the Test Program Finally, run your Test program with the command java -classpath ./lib/derby.jar org.bookstore.Test Play with this simple application, until you are thoroughly familiar with the Model classes. Try to extend the functionality beyond that described here. Examine the database schema for LILLDEP (described in a later section in this appendix). Next, let’s see how to use Torque for the Registration webapp. 366 APPENDIX A ■ FRAMEWORKS FOR THE MODEL Using Torque for the Registration Webapp Like Lisptorq, Torque also autogenerates Java source code for you. In fact, the data object and peer classes and the functions on them are very similar to those generated by Lisptorq (that is, in fact, where the torq in Lisptorq comes from). I won’t discuss the installation and setup of Torque here—you should refer to the Torque website (see “Useful Links”) for details. However, I will illustrate its use with the Registration webapp. Unlike Lisptorq, Torque uses XML to specify the database schema. The user table is described in Torque’s XML schema in Listing A-5. Listing A-5. Torque’s XML Description of the user Table <?xml version="1.0" encoding="ISO-8859-1" standalone="no"?> <!DOCTYPE database SYSTEM "http://db.apache.org/torque/dtd/database_3_1.dtd"> <database name="registration"> <table name="user" description="Table of registered users"> <column name="user_id" required="true" primaryKey="true" type="VARCHAR" size="32"/> <column name="password" required="true" type="VARCHAR" size="32"/> </table> </database> The XML is quite self-explanatory. Torque’s output from this XML consists of the usual four classes (data object and peer classes), as it did for Lisptorq. So if you know how to use Lisptorq, you know how to use Torque. For example, the exists() function (see Listing A-4) using Torque is provided in Listing A-6. As you can see, compared with Listing A-4 there is very little difference. APPENDIX A ■ FRAMEWORKS FOR THE MODEL 367 Listing A-6. An Implementation of exists() Using Torque public static boolean exists(String userId){ Criteria crit = new Criteria(); crit.add(UserPeer.USER_ID,userId); return UserPeer.doSelect(crit).iterator().hasNext(); } The central idea behind both these frameworks is that you have special Model classes, custom built by the framework for your webapp. Hibernate takes a different tack, allowing you to persist any JavaBean. Unfortunately, with flexibility comes more complexity, but Hibernate does an admirable job of keeping this to a minimum. We’ll see how Hibernate works for the Registration webapp next. Using Hibernate for the Registration Webapp Hibernate can persist any Java object or collection of objects, as long as they follow the JavaBeans convention: each property of the Java class must have associated getXXX and setXXX methods. As with Torque, some setup is required in order for you to use Hibernate. Consult the Hibernate website (see “Useful Links”) for details. In this section, I’ll focus on showing how you might use Hibernate as the Model tier for the Registration webapp. The User class (reproduced in Listing A-7) does follow this convention, since both the _userId and _password variables have associated getters and setters. Listing A-7. The User Bean package net.thinksquared.registration.data; public class User{ protected String _userId = null; protected String _password = null; public String getUserId(){ return _userId; } public String setUserId(String userId){ _userId = userId; } 368 APPENDIX A ■ FRAMEWORKS FOR THE MODEL public String getPassword(){ return _password; } public String setPassword(String password){ _password = password; } } For each bean you want to persist using Hibernate, you have to create an XML description of it, which essentially maps the bean’s properties to tables and columns in your database. The XML mapping for User appears in Listing A-8. Listing A-8. Hibernate XML Description of the User Bean <?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD//EN" "http://hibernate.sourceforge.net/hibernate-mapping-2.0.dtd"> <hibernate-mapping> <class name="net.thinksquared.registration.data.User" table="user"> <id name="userId" type="string" unsaved-value="null"> <column name="user-id" sql-type="char(32)" not-null="true"/> <generator class="assigned"/> </id> <property name="password"> <column name="password" sql-type="char(32)" not-null="true"/> </property> </class> </hibernate-mapping>

Description:
Save lisptorq.jar in the Source Code section of the Apress website into .\lib. 5. Form tags: These tags transfer data from View to Controller. The tags All of these tags, except the ones that involve flow control, have JSTL equivalents, so you Expert website, 6, 91 . Spring framework website, 6.
See more

The list of books you might like

Most books are stored in the elastic cloud where traffic is expensive. For this reason, we have a limit on daily download.