eclipse-spring-jdbc-tutorial-en

icon

20

pages

icon

Slovak

icon

Documents

Écrit par

Publié par

Le téléchargement nécessite un accès à la bibliothèque YouScribe Tout savoir sur nos offres

icon

20

pages

icon

Slovak

icon

Documents

Le téléchargement nécessite un accès à la bibliothèque YouScribe Tout savoir sur nos offres

Spring DAO with JBDCThis tutorial explains how to implement the design pattern Data Access Objects (DAO) to access a Database with JDBC. In addition the tutorial shows how to use Inversion of controll to improve your code quality. We will use the Spring framework.Do you need expert help or consulting? Get it at http://www.laliluna.de In- depth, detailed and easy- to- follow Tutorials for JSP, JavaServer Faces, Struts, Spring, Hibernate and EJBSeminars and Education at reasonable prices on a wide range of Java Technologies, Design Patterns, and Enterprise Best Practices Improve your development qualityAn hour of support can save you a lot of time - Code and Design Reviews to insure that the best practices are being followed! Reduce solving and testing timeConsulting on Java technologies Get to know best suitable libraries and technologiesGeneralAuthor: Sebastian HennebruederDate: December, 09 2005Used software and frameworksEclipse 3.1Spring 1.2.4 http://www.springframework.orgRecommendedMyEclipse 4 http://www.myeclipseide.comSource code: http://www.laliluna.de/download/eclipse- spring- jdbc- tutorial.zipPDF version of the tutorial: http://www.laliluna.de/download/eclipse- spring- jdbc-tutorial- en.pdfTable of ContentSpring DAO with JBDC.....................................................................................................................1General..................................................................................... ...
Voir icon arrow

Publié par

Langue

Slovak

Spring DAO with JBDC This tutorial explains how to implement the design pattern Data Access Objects (DAO) to access a Database with JDBC. In addition the tutorial shows how to use Inversion of controll to improve your code quality. We will use the Spring framework.
Do you need expert help or consulting? Get it at http:/ / w w w.laliluna.de In - depth, detailed and easy - to - follow Tutorials for JSP, JavaServer Faces, Struts, Spring, Hibernate and EJB Seminars and Education at reasonable prices on a wide range of Java Technologies, Design Patterns, and Enterprise Best Practices Improve your development quality An hour of support can save you a lot of time - Code and Design Reviews to insure that the best practices are being followed! Reduce solving and testing time Consulting on Java technologies  Get to know best suitable libraries and technologies
General Author: Sebastian Hennebrueder Date : December, 09 2005 Used software and frameworks Eclipse 3.1 Spring 1.2.4 http: / / w w w.springframework.org Recommended MyEclipse 4 http: / / w w w.myeclipseide.com
Source code: http: / / w w w.laliluna.de / download /eclipse - spring - jdbc - tutorial.zip
PDF version of the tutorial: http: / / w w w.laliluna.de / d ownload /eclipse - spring - jdbc -tutorial - en.pdf
Table of Content Spring DAO with JBDC.....................................................................................................................1 General..............................................................................................................................................1 What is the Spring framework?......................................................................................................2 Application and business logic .................................................................................................2 Transaction Management ......................................................................................................2 Integration of resource files .................................................................................................2 Integration of messaging ......................................................................................................2 JMX (Java Management Extension) .......................................................................................3 Integration of JDBC, Hibernate, JDO, EJB to access databases.......................................3 Web application development ...................................................................................................3 Aspect Oriented Programming and Inversion of Control ......................................................3 Springs advantages....................................................................................................................4 Little invasive..........................................................................................................................4
Good Design...........................................................................................................................5 Introduction to our example ..........................................................................................................5 Prepare the project.....................................................................................................................5 JDBC Libraries.........................................................................................................................9 Configure logging ..................................................................................................................9 Create the database and tables..............................................................................................10 The structure.............................................................................................................................10 Why interfaces are useful?..................................................................................................11 Creating the basic classes.......................................................................................................12 Class book............................................................................................................................12 Interface and Implementation ............................................................................................13 Adding inversion of control ....................................................................................................16 Configuration in Java classes.............................................................................................16 Configuration with Spring config files ..............................................................................18 Test your application...............................................................................................................19 Outlook...........................................................................................................................................20 Replacing the datasource with a connection pool ..........................................................20 Object Relational Mapping .................................................................................................20 Alternative implementation ................................................................................................20 Adding transactions to our application ............................................................................20 Copyright and disclaimer .............................................................................................................20
What is the Spring framework? Spring is a lot of things at the same time and I will try to give you a short understandable overview. A full overview to all functions can be found in the documentation which is included in the download of the Spring framework. Application and business logic Spring provides functionality to implement a well designed business layer for your application. It helps you implementing standard design patterns like DAO or designing to interfaces and provides features you need in all standard application and which allow you to integrate different services. If you are familiar with EJB you may find a lot of features you know from EJB. I speak about the advantages of Spring later in this tutorial: Transaction Management You can use a wide choice of transaction management solutions including Hibernate, database transactions or the Transaction Management from your Websphere or JBoss application server (JTA). The selection of a transaction management solution is not very invasive, i.e. you can easily change the transaction management without changing much of your code. Integration of resource files A complete library to read your resource and configuration files. Integration of messaging A complete library to create Emails or messages using a Java Messaging System. JMS is included in most J2EE application servers like JBoss, Websphere etc. A JMS allows you for example to send messages including objects (classes) between applications. For example
your Internet shop applications sends a message including the order class. The message is read later by your enterprise resource planning application. JMX (Java Management Extension) JMX allows you to remote access other application from within your application. Imagine a local Java application calling a remote server to start jobs, getting information or do what ever you like. JMX allows you to connect your application between multiple servers across the Internet or a LAN. Integration of JDBC, Hibernate, JDO, EJB to access databases Spring allows to integrate any of this solutions to access your database. The interface is well designed and lets you easily replace a JDBC database access with a Hibernate based database access. Hibernate, JDO and EJBare solutions to map database data to classes, e.g. Reading a line of the table book and writing it to a object of class type book. This allows you to use classes instead of result sets in your application and is considered as good design, because your application keeps being object oriented. If you use JDBC access, Spring provides an abstract exception layer. If you change your database from PostgreSQL to Oracle you do not have to change the exception handling from OracleDataAcception to PostgresDataException. Spring catches the application server specific Exception and throws a Spring dataexception. Web application development Spring provides his own web framework but also allows to use Struts, Velocity, FreeMarker, Struts Tiles or Libraries to create XML, Excel, PDF documents or reports. You can even develop an adapter for your own web framework to use Spring for your business logic. Aspect Oriented Programming and Inversion of Control AOP is all about adding aspects to your code. So what are aspects? The same as Cross Cutting Concerns? What are ...? I do not want to tease you but give you frequently used terms in the world of AOP. Cross Cutting Concerns are functions you need throughout your application. This can be for example transactions, logging or functions you need only for a limited time like measuring of process time to benchmark your application. Very often you implement this code in each method of your business logic. You will probably have already seen code like this or even written code like this. public void doMyBusiness(){ long startTime = 0; _ if (DO MEASURING) startTime = System.currentTimeMillis();
_ { if (DO LOGGING) Logger log = Logger.getLogger(this.getClass()); log.debug("I am in my DoBusiness method"); }
/* faked code if (! Transactionmanager.transactionOpen())  MyTransaction tx = TransActionmanager.beginTransaction(); ## Businesslogicmanager bl = Businesslogicmanager.getCurrentManager();
## bool success = bl.doMyWork(); if (success)  TransActionmanager.commitTransaction(); else  TransActionmanager.rollBack(); */ long endTime; if (DO_MEASURING){ endTime = System.currentTimeMillis(); System.out.println("Needed time for "+this.getClass()+" "+((endTime-startTime)/1000)); This example has two lines of code, I marked them with # which are doing something that has to do with the logic. The rest is needed but hhmm.. do I need the rest here? It makes the code difficult to read and even more difficult to test. This is where Aspect Oriented Programming comes on the scene. It allows code like the following:
public void doMyBusiness(){ /* faked code Businesslogicmanager bl = (Businesslogicmanager) beanFactory. getBean ("Businesslogicmanager");  Businesslogicmanager.doMyWork(); // and throw exceptions if you did not do it */  } To have the transaction, measurement and logging you add your aspects in a configuration file. ....snip ........ <property name="interceptorNames"> <list> <value>logAdvice</value> <value>measureAdvice</value> </list> </property> .... snip ....... <property name="transactionAttributes" > <props> _ <prop key="borrowBooks">PROPAGATION REQUIRED</prop> </props> </property> ...... I thing that this is impressive, isn't it? Your code is by far better readable. Springs advantages Little invasive Spring is little invasive compared to other solutions. Using EJB version 2.1 will force you to extend EJBObject classes and other when you want to create your business logic or your entity objects. Your code is closely coupled to to the technology you choose. This is
improved in EJB3 but EJB3 is at the time (December 2005) still not not integrated in all J2EE application servers. Spring allows you to use so- called POJO (Plain Old Java Objects) for your domain classes (domain class = e.g. a class Book representing a entity book) or your business logic. This will keep your code clean and easily to understand. Good Design Spring is very well designed even if I question the usefulness of the runtime exception for example, the usefulness of all the adapters to EJBaccess, transaction management etc. are enormous. They allow to replace technology A with technology B when your application growths and needs a more powerful solution or if you change the environment or because of other reasons. Runtime Exception in Spring Spring does throw runtime exceptions instead of checked exceptions. Runtime exceptions must not be catched and if they happen and if they are not catched your application will stop running with a standard java stack trace. Checked exceptions must be catched. If you do not catch a checked exception in your code, it can not be compiled. As it is a tedious task to catch all the exceptions for example when using EJBtechnology and there are bad developers catching exceptions without giving any feedback to the user, the Spring developers decided to throw runtime exceptions, so that if you do not catch an exceptions your application will break and the user gets the application exception. Their second reasoning is that most exceptions are unrecoverable so your application logic can not deal with them anyway. This is true to some extend but in my opinion at least the user should not see a Java stack trace from an exception when using the application. Even if they are right and most exceptions are unrecoverable, I must catch them at least in the highest level (dialogues) of my application, if I do not want a user to see a Java Exception stack trace. The problem is that all IDEs recognizes checked exceptions and tell me that I must still for example catch a DataBaseNotAvailable exception and a doubleEntryForPrimaryKey exception. But in this case I can decide that the user application will stop for the first exception and will continue to the edit dialogue for the second exception to allow the user to input a different value for the primary key. Eclipse even creates the try catch method for me. Using RuntimeExceptions I must know which exception can happen and write my code manually. I do not know if I catched all the important runtime exceptions where I could allow the application to continue running. And this is what I really dislike about this strategy. But anyway, I came across a lot of very nice design patterns in Spring and it will help even mediocre developers as me ;- ) to write nice code.
Introduction to our example We are responsible to create a library application. Your job is to develop the business logic and to test it with a Java application as client. We will create all access method do deal with a book. Prepare the project I want to continue this project as web application, so I chose this kind of project. When you do not have MyEclipse installed you may use a Java project or have a look at the tutorial at http: / / w w w.laliluna.de /webprojects - eclipse - jbosside - tutorial - en.html to create a web project. Press Ctrl +n (Strg+n) and choose new webproject.
Ca
l
l
 
y
o
u
r
 
p
r
o
j
e
c
t
 
Spr
i
n
gJd
b
c
.
In the next step we need to add the missing libraries. MyEclipse provides a wizard to do this. For other user see below how to add libraries.
Using MyEclipse right click on your project - > MyEclipse -will need the DAO/ORM libraries and the core.
>
Add Spring capabilities. We
In the next step you can create a Spring configuration file.
If you do not use MyEclipse download Spring from the website http: / / w w w.springframework.org We used version 1.2.6 Unpack all the spring libraries from the zip or tgz file in a directory. Libraries have names like spring.jar. Open the libraries dialog in the project properties (Alt +Enter) - > Java Build Path - > Libraries Add external jar - > Below you can see the libraries added by MyEclipse. This is by far to much. You will not need spring - hibernate, dbcp, ibatis and toplink libraries.
JDBC Libraries You will need a jdbc driver for your database. I used PostgreSQL. You can get the driver from http: / / j d bc.postgresql.org / . You can use the JDBC 3 driver if you are running a current j2sdk like 1.4 and 1.5 / 5.0. For MySQL you can use the MySQL connector which can be found at http: / / w w w. mysql.com / p r oducts / connector / j /
Configure logging Spring depends on log4j. If you use MyEclipse this is already provided with the spring libraries. If not you can find the libraries here http: / / l o g g ing.apache.org / l og4j / d ocs / i n dex.ht ml Create a log4j.properties file in the src directory and add the following code to have a debugging output to the console.
### direct log messages to stdout ### log4j.appender.stdout= org.apache.log4j.ConsoleAppender log4j.appender.stdout.Target= System.out log4j.appender.stdout.layout= org.apache.log4j.PatternLayout log4j.appender.stdout.layout.ConversionPattern= %d{ABSOLUTE}  %5p  %c {1} : %L  - %m%n
### direct messages to file hibernate.log ### #log4j.appender.file=org.apache.log4j.FileAppender
#log4j.appender.file.File=hibernate.log #log4j.appender.file.layout=org.apache.log4j.PatternLayout #log4j.appender.file.layout.ConversionPattern=%d{ABSOLUTE} %5p %c{1}:%L - %m%n ### set log levels - for more verbose logging change 'info' to 'debug' ### log4j.rootLogger= debug,  stdout Create the database and tables I use PostgreSQL in the tutorial text but you can find MySQL specific source code in the source code, I provided. Create a database named library and use the following script to create the tables. PostgreSQL CREATE  TABLE book (  id serial,  title text,  author text,  borrowsBy int4,   primary  key (id) ) ;
MySQL CREATE  TABLE `book` ( _ `id` INT  NOT  NULL AUTO INCREMENT , `title` VARCHAR ( 255 ) NOT  NULL , `author` VARCHAR ( 255 ) NOT  NULL , `borrowedby` INT , PRIMARY  KEY ( `id` ) ) TYPE = INNODB ;
Why do I use PostreSQL? I like PostgreSQL very much. It provides features like Triggers, Stored Procedures, Views for quite a long time compared to MySql, it has a better licence model, a wide choice of languages to create stored procedures including pg /psql, c and others. I have heard ;- ) that it is better scalable when you are not having a simple web application reading data but a large scale application using transactions, triggers, stored procedures and a lot of complex queries.
The structure The solution should be portable between different database server, so we need to encapsulate the access to the database. A good way to make your application not aware of a special implementation, is to use an interface.
Why interfaces are useful? I will give you some reasons in favour of using interfaces. Imagine you wrote a class dealing with your MySql database. public class MyLibrary { public void doSomething(){ // I will call a MySQL database now } public void doSomethingElse(){ // I will call a MySQL database now } } When you create a different class dealing with a PostgreSQL database you will have to replace the MyLibrary class with the MyLibraryPostgreSQL class everywhere.
When you create an interface for example: public interface MyLibrary { public abstract void doSomething(); public abstract void doSomethingElse(); } and write implementations like the following: public class MyLibraryMySQLImp implements MyLibrary { public void doSomething(){ // I will call a MySQL database now } public void doSomethingElse(){ // I will call a MySQL database now } } you can pass the interface as parameter to your business method. Void businessMethod(MyLibrary myLib){ myLib.doSomething(); } Your code no longer knows which implementation it got and will work on any implementations.
Voir icon more
Alternate Text