Crash Introduction to Modern Java Data Access: Understanding JPA, Hibernate, Mybatis, and Purequery

Total Page:16

File Type:pdf, Size:1020Kb

Crash Introduction to Modern Java Data Access: Understanding JPA, Hibernate, Mybatis, and Purequery Crash Introduction to Modern Java Data Access: Understanding JPA, Hibernate, MyBatis, and pureQuery Dr. Vladimir Bacvanski Session Code: E13 May 6, 2011 * 8:00 – 9:00am | Platform: Cross Platform Outline • Database/Programming Languages Chasm • Persistence Options • JDBC • Object Relational Mapping • JPA & Hibernate • MyBatis • pureQuery • Conclusions 2 Database/Programming Languages Chasm • Relational Database • Java Customer c1: Customer id name phone email name="Joe" 1 Joe 123-… joe@... phone=123- 456-7890 email="[email protected]" Address custId street city a1: Address 1 1 Nice … street="1 Nice Way" San… city="San Francisco" • The world consists of • The world consists of tables objects, which are instances of classes 3 Accessing Databases: Many Choices! pureQuery JDBC SQLJ MyBatis (iBatis) Hibernat e JPA EJB There are more choices, but we'll discuss just the more popular ones 4 JDBC • JDBC (Java Database Connectivity) provides an API allowing for explicit creation of SQL queries from Java • The API allows for issuing of SQL commands • Prepared queries • Ad-hoc queries • Callable statements • The result comes back as a cursored table 5 Code Example: JDBC java.sql.PreparedStatement ps = Table Column Type con.prepareStatement( EMP NAME CHAR(64) "SELECT NAME, ADDRESS, EMP ADDRESS CHAR(128) PHONE_NUM FROM EMP EMP PHONE_NUM CHAR(10) WHERE NAME=?"); ps.setString(1, name); java.sql.ResultSet rs = ps.executeQuery(); rs.next(); Employee myEmp = new Employee(); myEmp.setName(rs.getString(1)); class Employee { myEmp.setHomeAddress(rs.getString(2)); public String name; myEmp.setHomePhone(rs.getString(3)); public String homeAddress; public String homePhone; rs.close(); … } 6 Issues with Plain JDBC • Benefits • Performance • It is possible to write optimized queries for a particular task • It is possible to take advantage of underlying DB capabilities • Ease of debugging • The connection between the DB and application code is clear • Drawbacks • Cumbersome programming • The mapping from the application world (Java objects) to the DB world may be cumbersome and complex • Much code may have to be written and debugged • It is easy to introduce mechanical bugs • E.g., closing of connections • JDBC API lags behind modern database features 7 Object-Relational Mapping • Issues with JDBC led to development of O/R mapping, most notably Hibernate as the leading implementation • One popular approach to connect applications to the database is the use of an object-relational mapping tool (ORM) • Many ORM technologies and implementations available: • JPA: The dominant specification • Hibernate, OpenJPA, EclipseLink: JPA implementations 8 Mapping Between the Worlds O/R Mapping The Object-Oriented View <<enumeration>> BikeType RACING MOUNTAIN STREET UNICYCLE Vehicle vehiclePark owner Person name: String name: String Mapping: * 1 Annotations or XML MotorizedVehicleType * * name: String availableCars legalUsers description: String 1 type * instances MotorizedVehicle Bike Address * fuelCapacity: Integer bikeType: BikeType street: String map city: String state: String country: String map The Relational Database View MOTORIZED_VEHICLE_TYPE VEHICLE_2_PERSON_MAP PERSON_TBL PK id char(10) PK,FK2 legal_driver_id char(10) PK id char(10) PK,FK1 available_car_id char(10) map name varchar(50) name varchar(50) description varchar(255) map VEHICLE_TBL PK id char(10) FK1 owner_id char(10) name varchar(50) map type smallint ADDRESS_TBL PK id varchar(16) MOTORIZED_VEHICLE_TBL BIKE_TBL FK1 occupant_id char(10) PK,FK1,FK2 id char(10) PK,FK1 id char(10) street varchar(250) city varchar(50) fuel_consumption real bike_type smallint state varchar(50) type_id char(10) country varchar(40) 9 JPA Example: Annotations @Entity public class Employee { @Id private Long id; @ManyToOne private Department department; ... } @Entity public class Department { @OneToMany(mappedBy="department")‏ private Collection<Employee> employees = new HashSet(); 10 JPA Inheritance Example @Entity @Inheritance @DiscriminatorColumn( name="DISC", discriminatorType=STRING,length=20)‏ @DiscriminatorValue(“PERSON")‏ public class Person { ... } @Entity @DiscriminatorValue("CUSTOMER")‏ public class Customer extends Person { ... } 11 Hibernate: More than JPA • JPA was heavily inspired by Hibernate • Today, Hibernate implements the JPA standard • Provides more features in areas: • Primary key generators • Control over cascade behaviors • Criteria for query building • Query language HQL • Caching • … 12 Issues with ORM Tools • Benefits • Ease of use for the application programmer • The programmer writes code assuming an object model • The tool maps the object model to SQL • Continuity • The domain model (from analysis) is preserved in implementation • Drawbacks • Performance • It is hard for the general purpose mapping tool to take advantage of the underlying database capabilities • Complex to debug • The mapping can make finding errors very hard 13 MyBatis (iBatis) • MyBatis was earlier known as iBatis • SQL is fully exposed: MyBatis is not a full ORM! • Persistence access is explicit through SQL • Reduced Java boilerplate code in comparison with JDBC Mapping XML or Annotations Input Output Hashtable Hashtable Mapped POJO Statement POJO Primitive Primitive 14 SQL Mapping and Call in MyBatis Mapping: <?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> <mapper namespace="com.scispike.CustomerMapper"> <select id="selectCustomer" parameterType="int" resultType="Customer"> select * from Customer where id = #{id} </select> </mapper> Call: Customer cust = (Customer) session.selectOne( "com.scispike.CustomerMapper.selectCustomer", 1001); 15 Issues with MyBatis • Benefits • Full control over SQL and improved productivity in comparison with JDBC • Suitable for dealing with legacy databases • Troubleshooting easier in comparison with JPA • Drawbacks • Tooling support is lacking • Productivity initially reduced in comparison with JPA, but catches up later through easier troubleshooting 16 pureQuery • A high-performance, data access platform to simplify developing, managing, securing, and optimizing data access pureQuery Components: • Simple and intuitive API • Enables SQL access to databases or in-memory Java objects • Facilitates best practices • Optim Development Studio (integrates with RAD/RSA) • Integrated development environment with Java and SQL support • Improve problem isolation and impact analysis • Optimize existing code: JDBC/JPA/Hibernate/MyBatis • Optim pureQuery Runtime • Flexible static SQL deployment for DB2 17 Code Example: pureQuery • "Inline" query: Employee myEmp = db.queryFirst( "SELECT NAME, ADDRESS, PHONE_NUM FROM EMP WHERE NAME=?", Employee.class, name); • Even simpler, if we have a method getEmployee with a Java annotation or XML file with SQL for the query: Employee myEmp = db.getEmployee(name); 18 Optim Development Studio: pureQuery IDE Visualize application SQL Replace SQL Visualize without changing execution metrics the application Position in Database Explorer Execute, tune, share, trace, 19 explore SQL SQL Integration with Java • SQL content assist • SQL validation 20 Data Access Objects – pureQuery support Quickly create JEE Data Access Objects • An interface with only your methods • Methods for each database access • Each method has only your parameters • SQL can be in XML file or annotations • Implementation automatically generated with best practice database access and optimizations. • Template-based generation with template customization • Mix hand-written and generated code. • Can modify generated code and safely regenerate. 21 pureQuery: Optimal Productivity and Control Full SQL Control Object-Relational Mapping Managed Objects Code all your SQL JDBC / SQLJ MyBatis Add basic OR mapping and annotated-method style pureQuery Complex O/R mapping and persistence management, but loss of control JPA/Hibernate Adds container management option EJB 3 22 Conclusion • Each approach has its strengths and weaknesses • JDBC alone • To low level for most applications • JPA and Hibernate • Good choice when you own the database, performance not critical • MyBatis • Full control over SQL, reduced boilerplate • pureQuery • Full control over SQL , mixing productivity, static SQL, and integrated tooling 23 Getting in Touch • Email: [email protected] • Blog: http://www.OnBuildingSoftware.com/ • Twitter: http://twitter.com/OnSoftware • LinkedIn: http://www.linkedin.com/in/VladimirBacvanski 24.
Recommended publications
  • Hibernate ORM Query Simplication Using Hibernate
    2016 3rd National Foundation for Science and Technology Development Conference on Information and Computer Science Hibernate ORM Query Simplication Using Hibernate Criteria Extension (HCE) Kisman Sani M. Isa Master of Information Technology Master in Computer Science Bina Nusantara University Bina Nusantara University Jl. Kebon Jeruk Raya No. 27, Jakarta Barat, DKI Jl. Kebon Jeruk Raya No. 27, Jakarta Barat, DKI Jakarta, Indonesia 11530 Jakarta, Indonesia 11530 [email protected] [email protected] Abstract— Software development time is a critical issue interfaced by a query. The software engineer will make in software development process, hibernate has been the query specified to database used. Each database widely used to increase development speed. It is used in vendor has their Structured Query Language (SQL). As database manipulation layer. This research develops a the development of software technology and most of library to simplify hibernate criteria. The library that is programming languages are object oriented, some called as Hibernate Criteria Extension (HCE) provides API functions to simplify code and easily to be used. Query engineer or software institutions try to simplify the associations can be defined by using dot. The library will query process. They try to bind object in application to automatically detect the join association(s) based on database. This approach is called as Object Relational mapping in entity class. It can also be used in restriction Mapping (ORM). ORM is a translation mechanism from and order. HCE is a hibernate wrapper library. The object to relational data, vice versa. ORM has “dialect” configuration is based on hibernate configuration.
    [Show full text]
  • JPA Avancé » Licence
    Formation « JPA Avancé » Licence Cette formation vous est fournie sous licence Creative Commons AttributionNonCommercial- NoDerivatives 4.0 International (CC BY-NC-ND 4.0) Vous êtes libres de : ● Copier, distribuer et communiquer le matériel par tous moyens et sous tous formats Selon les conditions suivantes : ● Attribution : Vous devez créditer l'Oeuvre, intégrer un lien vers la licence et indiquer si des modifications ont été effectuées à l'Oeuvre. Vous devez indiquer ces informations par tous les moyens possibles mais vous ne pouvez pas suggérer que l'Offrant vous soutient ou soutient la façon dont vous avez utilisé son Oeuvre. ● Pas d’Utilisation Commerciale: Vous n'êtes pas autoriser à faire un usage commercial de cette Oeuvre, tout ou partie du matériel la composant. ● Pas de modifications: Dans le cas où vous effectuez un remix, que vous transformez, ou créez à partir du matériel composant l'Oeuvre originale, vous n'êtes pas autorisé à distribuer ou mettre à disposition l'Oeuvre modifiée. http://creativecommons.org/licenses/by-nc-nd/4.0/deed.fr Ippon Technologies © 2014 Ippon Formation en bref Pourquoi Ippon Technologies publie ses supports de formation ? Car Ippon participe à la communauté Java et Web et soutien le modèle open-source Le support théorique représente 40% du temps de formation, l'intérêt est dans les Travaux Pratiques et l'expert Ippon qui assure le cours. Nos TP sont dispensés lors des sessions de formations que nous proposons. Ippon Technologies © 2014 Pour nous contacter Pour nous contacter et participer à nos formations : - Technique : [email protected] - Commercial : [email protected] Toutes les informations et les dates de formations sont sur notre site internet et notre blog : - http://www.ippon.fr/formation - http://blog.ippon.fr Ippon Technologies © 2014 Bienvenue ● Présentation ● Organisation ● Détails pratiques Ippon Technologies © 2014 Prérequis ● Pour suivre le cours ○ Avoir de bonnes bases en Java : les JavaBeans, les Collections, JDBC..
    [Show full text]
  • Thesis Artificial Intelligence Method Call Argument Completion Using
    Method Call Argument Completion using Deep Neural Regression Terry van Walen [email protected] August 24, 2018, 40 pages Academic supervisors: dr. C.U. Grelck & dr. M.W. van Someren Host organisation: Info Support B.V., http://infosupport.com Host supervisor: W. Meints Universiteit van Amsterdam Faculteit der Natuurwetenschappen, Wiskunde en Informatica Master Software Engineering http://www.software-engineering-amsterdam.nl Abstract Code completion is extensively used in IDE's. While there has been extensive research into the field of code completion, we identify an unexplored gap. In this thesis we investigate the automatic rec- ommendation of a basic variable to an argument of a method call. We define the set of candidates to recommend as all visible type-compatible variables. To determine which candidate should be recom- mended, we first investigate how code prior to a method call argument can influence a completion. We then identify 45 code features and train a deep neural network to determine how these code features influence the candidate`s likelihood of being the correct argument. After sorting the candidates based on this likelihood value, we recommend the most likely candidate. We compare our approach to the state-of-the-art, a rule-based algorithm implemented in the Parc tool created by Asaduzzaman et al. [ARMS15]. The comparison shows that we outperform Parc, in the percentage of correct recommendations, in 88.7% of tested open source projects. On average our approach recommends 84.9% of arguments correctly while Parc recommends 81.3% correctly. i ii Contents Abstract i 1 Introduction 1 1.1 Previous work........................................
    [Show full text]
  • A Decision Support Model for Using an Object-Relational Mapping Tool in the Data Management Component of a Software Platform
    UNIVERSITY OF UTRECHT DEPARTMENT OF INFORMATION AND COMPUTING SCIENCES A Decision Support Model for using an Object-Relational Mapping Tool in the Data Management Component of a Software Platform Rares George Sfirlogea Supervisors: dr. R.L. Jansen dr. ir. J.M.E.M. van der Werf Friday 6th February, 2015 Academic year 2014/2015 Abstract The usage of an ecosystem-based application framework gives software com- panies a competitive advantage in delivering stable, feature rich products while keeping the completion time to a minimum. It is seldom the case that a platform is selected by looking at its software architecture although it can reveal a lot of details about its limitations and functionality. The Object- Relational Mapping (ORM) tool in the data management component imposes extendability restrictions on the software platform. The software architect or developer that is responsible of making this decision is often unaware of the platform traits leading to breaking the general conventions or even consider- ing a costly rewrite of the entire application in the future. The aim of this research thesis is to create a decision support model regarding the inclusion of an ORM tool in the platform architecture and the consequences it imposes on the software platform's quality attributes. With this artefact, any individ- ual in charge with the product architecture can make a more knowledgeable decision, by aligning the platform capabilities with his data requirements. Acknowledgements I would like to express my sincere appreciation for all the people who helped this research reach its final state. With a special mention going to my thesis coordinators, the experts who agreed to be interviewed and of course my girlfriend, family and friends who put up with me during this long period of time.
    [Show full text]
  • Spring Datasource Properties Mysql
    Spring Datasource Properties Mysql Braden coddle revivingly? Bad-tempered Arne tasselling unfaithfully, he weeps his heat very impishly. Ed minimized vindictively. Run the testcase, we got a green bar. So, we need to configure the timeout parameter. Need access to an account? Secrets, on the other hand, are meant for storing sensitive information and offer better security. Now we are ready to test the application. Wordpress is Super Easy and lots of themes to choose. If it is on the classpath Spring Boot, pick it up. RESTful API, so you can get everything setup right from the command line. Can you please help. This means application fails to start when scripts causes exception. Java config and properties config. Spring reads the properties defined in this file to configure your application. Reason: Failed to determine a suitable driver class. It is a Hibernate feature that control the behavior in more fine grained way. Spring Boot Profiling provide a way to segregate parts of your application. Detect your application can download our prod and it in the best way spring datasource properties mysql database dependency similar expect for my requirements. If a connection is due for validation, but has been validated previously within this interval, it will not be validated again. In the response added Employee data is sent back. Thanks for pointing that out. You also need to update your application build file to include the Spring Framework Milestone repository. Configure your application with database is the basic need of every project. Here the Postgresql database url must be loaded if everything is correct.
    [Show full text]
  • An Experimental Study of the Performance, Energy, and Programming Effort Trade-Offs of Android Persistence Frameworks
    An Experimental Study of the Performance, Energy, and Programming Effort Trade-offs of Android Persistence Frameworks Jing Pu Thesis submitted to the Faculty of the Virginia Polytechnic Institute and State University in partial fulfillment of the requirements for the degree of Master of Science in Computer Science and Applications Eli Tilevich, Chair Barbara G. Ryder Francisco Servant July 1, 2016 Blacksburg, Virginia Keywords: Energy Efficiency; Performance; Programming Effort; Orthogonal Persistence; Android; Copyright 2016, Jing Pu An Experimental Study of the Performance, Energy, and Programming Effort Trade-offs of Android Persistence Frameworks Jing Pu (ABSTRACT) One of the fundamental building blocks of a mobile application is the ability to persist program data between different invocations. Referred to as persistence, this functionality is commonly implemented by means of persistence frameworks. When choosing a particular framework, Android|the most popular mobile platform—offers a wide variety of options to developers. Unfortunately, the energy, performance, and programming effort trade-offs of these frameworks are poorly understood, leaving the Android developer in the dark trying to select the most appropriate option for their applications. To address this problem, this thesis reports on the results of the first systematic study of six Android persistence frameworks (i.e., ActiveAndroid, greenDAO, Orm- Lite, Sugar ORM, Android SQLite, and Realm Java) in their application to and performance with popular benchmarks, such as DaCapo. Having measured and ana- lyzed the energy, performance, and programming effort trade-offs for each framework, we present a set of practical guidelines for the developer to choose between Android persistence frameworks. Our findings can also help the framework developers to optimize their products to meet the desired design objectives.
    [Show full text]
  • What's in Oracle Database 21C for Java Developers?
    Business / Technical Brief What’s in Oracle Database 21c for Java Developers? New enhancements to JDBC, UCP and OJVM for Designing and Deploying Mission Critical and Cloud Native Java Applications. Updated: August 2021 Copyright © 2021, Oracle and/or its affiliates Public 1 What’s in Oracle Database 21c for Java Developers? Copyright © 2021, Oracle and/or its affiliates. Disclaimer This document in any form, software or printed matter, contains proprietary information that is the exclusive property of Oracle. Your access to and use of this confidential material is subject to the terms and conditions of your Oracle software license and service agreement, which has been executed and with which you agree to comply. This document and information contained herein may not be disclosed, copied, reproduced or distributed to anyone outside Oracle without prior written consent of Oracle. This document is not part of your license agreement nor can it be incorporated into any contractual agreement with Oracle or its subsidiaries or affiliates. This document is for informational purposes only and is intended solely to assist you in planning for the implementation and upgrade of the product features described. It is not a commitment to deliver any material, code, or functionality, and should not be relied upon in making purchasing decisions. The development, release, and timing of any features or functionality described in this document remains at the sole discretion of Oracle. Due to the nature of the product architecture, it may not be possible to safely include all features described in this document without risking significant destabilization of the code.
    [Show full text]
  • Jianfeng Zhao *[email protected] ((831)295-7707 EDUCATION University of California, Santa Cruz (UCSC) Sep 2017 - June 2018 M.S
    Jianfeng Zhao *[email protected] ((831)295-7707 EDUCATION University of California, Santa Cruz (UCSC) Sep 2017 - June 2018 M.S. Computer Science Beijing University of Posts and Telecommunications (BUPT), Beijing, China Sep 2011 - July 2015 B.E. Communication engineering WORKING EXPERIENCE Co-Founder & CTO, Chengdu Cuantianhou Technology Co., Ltd, Chengdu, China Nov 2016 - Sep 2017 § Responsible for product design and project management, led the development of 3 products. § Served 7000+ users and sold10 thousands of dishes Research and development engineer, China Internet Plus(Meituan), Beijing July 2015 - July 2016 1. Real-time monitor system § Implemented this system with the functionality of collecting real time data, monitoring and alarming. § Collected data through Kafka and aggregated these data by Storm then saved into OpenTSDB for analyzing and alarming § Built a real-time data monitor platform, which used by the whole business group of Meituan. 2. Data quality detection system § Developed the whole system which contains data-detection module, parameter-fitting module and configuration module § Detected outliers intelligently based on the configuration through machine learning algorithms, which parameter will be refitted each calculation. § Improved significantly productivity and the data reliability of our department Software engineer intern, Baidu, Beijing July 2014 - Oct 2014 § Developed and Improved Baidu’s automatic test script in IOS platform based on JavaScript. Software engineer intern, BYR-team, Beijing Oct 2012 – May 2014
    [Show full text]
  • Spring Boot Starter Cache Example
    Spring Boot Starter Cache Example Gail remains sensible after Morrie chumps whereby or unmuffled any coho. Adrick govern operosely. Gregorio tomahawks her Janet indigestibly, she induces it indecently. Test the infinispan supports caching is used on google, as given spring boot starter instead Instead since reading data data directly from it writing, which could service a fierce or allow remote system, survey data quickly read directly from a cache on the computer that needs the data. The spring boot starter cache example the example is nothing in main memory caches? Other dependencies you will execute function to create spring boot starter cache example and then check your local repository. Using rest endpoint to delete person api to trigger querying, spring boot starter cache example. Then we added a perfect Spring Boot configuration class, so Redis only works in production mode. Cache example using. Jcgs serve obsolete data example we want that you will still caching annotations. CACHE2K SPRING BOOT Spring boot database cache. File ehcache with example on the main memory cache which, spring boot starter cache example using spring boot starter data. Add the cache implementation class to use hazelcast. Spring-boot-cache-examplepomxml and master GitHub. SPRINGBOOT CACHING LinkedIn. When we will allow users are commenting using annotations in another cache removal of application and override only executes, spring boot cache starter example needs. Cacheable annotation to customize the caching functionality. Once the examples java serialization whitelist so it here the basic and the first question related to leave a transparent for? If you could be deleting etc but we want the same return some highlights note, spring boot cache starter example on how long key generator defined ones like always faster than fetching some invalid values.
    [Show full text]
  • On the Distribution of Test Smells in Open Source Android Applications: an Exploratory Study
    On the Distribution of Test Smells in Open Source Android Applications: An Exploratory Study Anthony Peruma1, Khalid Almalki1, Christian D. Newman1, Mohamed Wiem Mkaouer1, Ali Ouni2, Fabio Palomba3 1Rochester Institute of Technology, Rochester, NY, USA 2ETS Montreal, University of Quebec, Montreal, QC, Canada 3University of Zurich, Zurich, Switzerland [email protected],[email protected],[email protected],[email protected],[email protected],[email protected] ABSTRACT benefit from such a study; users will see an increase in their usage The impact of bad programming practices, such as code smells, in experience and developers will have an easier time maintaining production code has been the focus of numerous studies in soft- apps in the long term. To this end, we have extended the set of ware engineering. Like production code, unit tests are also affected existing smells to cover violations of xUnit testing guidelines [19]. by bad programming practices which can have a negative impact To analyze the lifecycle and impact of these smells, we conducted on the quality and maintenance of a software system. While sev- a large-scale, empirical study on test suites utilizing JUnit [20] eral studies addressed code and test smells in desktop applications, for 656 open-source Android apps. Further, we defined a series of there is little knowledge of test smells in the context of mobile research questions to support and constrain our investigation to applications. In this study, we extend the existing catalog of test better understand the existence and distribution of test smells, and smells by identifying and defining new smells and survey over 40 more precisely to investigate whether the existence of test smells developers who confirm that our proposed smells are bad program- is an indicator of poor testing quality.
    [Show full text]
  • Chapter 14: Using Relational Databases to Provide Object Persistence
    C h a p t e r 1 4 Using Relational Databases to Provide Object Persistence Learning Objectives after studying this chapter, you should be able to: ■ Concisely define each of the following terms: persistence, serialization, object- relational mapping (OrM), object-relational impedance mismatch, object identity, accessor method, call-level application programming interface, transparent persis- tence, separation of concerns, pooling of database connections, entity class, fetching strategy, n+1 selects problem, declarative mapping schema, and value type. ■ Understand the fundamental mismatch between the object-oriented paradigm and the relational model and the consequences of this mismatch for the use of relational databases with object-oriented development environments. ■ Understand the similarities and differences between the approaches that are used to address the object-relational impedance mismatch. ■ Create a mapping between core object-oriented structures and relational structures using Hibernate. ■ Identify the primary contexts for using each of the approaches to addressing the object-relational impedance mismatch. ■ Understand possible effects of the use of the object-relational mapping approaches on database performance, concurrency control, and security. ■ Use HQL to formulate various types of queries. IntroductIon In Chapter 13, you learned about the object-oriented approach to data modeling, leading to a conceptual domain model represented with the UML class diagram notation. As briefly discussed in Chapter 13, the object-oriented approach is not limited to data modeling but it is frequently used for systems analysis, design, and implementation. It is useful to understand the broader context of object-oriented thinking before we discuss the core topic of this chapter: the integration between object-oriented application development models and relational databases.
    [Show full text]
  • Apache Camel
    Apache Camel USER GUIDE Version 2.9.7 Copyright 2007-2013, Apache Software Foundation 1 Table of Contents Table of Contents......................................................................... ii Chapter 1 Introduction ...................................................................................1 Chapter 1 Quickstart.......................................................................................1 Chapter 1 Getting Started..............................................................................7 Chapter 1 Architecture................................................................................ 17 Chapter 1 Enterprise Integration Patterns.............................................. 37 Chapter 1 Cook Book ................................................................................... 42 Chapter 1 Tutorials..................................................................................... 122 Chapter 1 Language Appendix.................................................................. 221 Chapter 1 DataFormat Appendix............................................................. 297 Chapter 1 Pattern Appendix..................................................................... 383 Chapter 1 Component Appendix ............................................................. 532 Index ................................................................................................0 ii APACHE CAMEL CHAPTER 1 °°°° Introduction Apache Camel ª is a versatile open-source integration framework based on known Enterprise
    [Show full text]