Get the most out of your data access layer
Want to run your data access layer at high speeds?
- 1Database Essentials
Do you know how a relational database systems works behind the scenes?
Do you know how the JDBC Driver executes statements and how you can configure it to boost application performance?
- 3JPA and Hibernate
Adding JPA and Hibernate annotations is fairly easy. But, do you know the performance implications of each JPA or Hibernate feature your application makes heavy use of?
- 4Spring project suite
The Spring project offers a great varieties of frameworks that can help you deal with many enterprise application requirements. From Spring framework to Spring Data, Spring MVC and Spring Integration, I can help you get the most out of this framework and make sure you are using it properly.
Who am I?
I'm a Java Champion, and I wrote hundreds of articles about JPA and Hibernate.
On StackOverflow, I have been answering thousands of questions about JPA and Hibernate which brought me several gold badges for the Java, JPA, Hibernate and ORM tags.
Besides writing about JPA and Hibernate, I've been talking about high-performance data access frameworks at various international software conferences like Devoxx, Voxxed Days, JAX or JavaZone, and even run workshops at some of the most appreciated software conferences in the world, like Craft Conf.
Last, but not least, I'm one of the top contributors to the Hibernate ORM project.
All in all, if you want to speed up your data access layer, I'm here to help.
Founder - Web Data Technologies LLP
We were lucky to hire Vlad's services for a day to evaluate the Hibernate data layer of our open source jBilling fork. Vlad had provided effort estimates in advance and a detailed feedback was provided by the end of scheduled day exactly as planned.
The feedback was quite to the point, thorough in terms of domain objects and relationships, prioritized along with explanations. Vlad also allowed an opportunity to seek clarifications later on, which were promptly provided and greatly accelerated the adoption process of these changes in the development pipeline.
We are very happy with the value we received from consulting with Vlad.
Founder - Orijtech, Inc
Vlad is a talented Java and overall databases/web services expert. For a couple of weeks, I was lucky to be able to hire and work with Vlad here and there on both Hibernate and Spring projects and his insights are great but also I can rely on him to deliver and get things done the right way.
He is very resourceful and a delight to collaborate with. I look forward to continuing to work with him.
Work with me
Besides on-site training, I can also help you design your data access layer or optimize it to run as fast as possible.
Prior to working as a Developer Advocate for the Hibernate project, I used to work as a software architect building systems ranging from automotive industry (e.g., Ford North America), to telecommunication companies (e.g., Nokia), logistics systems (e.g., FleetLogis), real-estate platforms (e.g., Etuovi), and data aggregation and analysis (e.g., Brückner).
I can revise your system architecture and provide tips about how you ca optimize it both for performance and cost-effectiveness.
Database design and query optimization
I can analyze your database schema and give you advice about how you can change it to better serve your application requirements.
More, I can help you analyze queries and optimize them to make sure they run as fast as possible.
JPA and Hibernate entity modeling
From basic types to relationships, mapping entities to database tables requires consideration, especially if you want to get the most out of your data access layer.
Some mappings perform better than others, and I can help you make sure you are using the right mappings based on the underlying database schema design.
Service and data layer design
Writing data access layer code is not as simple as it looks. If you want performance, you need to make sure you that:
- you are fetching just the right amount of data,
- you are writing data efficiently without more database roundtrips than necessary
- statements are properly cached
- you are using a good connection pooling solution and you monitor its usage
- the auto-generated SQL statements are as efficient as possible
- transaction boundaries are properly set up
- you are not using anti-patterns like the Open Session In View, Temporary Session or redundant merging
- you are using the right transaction isolation level and you understand the possible data anomalies that may occur
There are many more aspects you should take into consideration when writing data access code, and I can help you make sure your data access layer runs like a cheetah.
Testing is extremely important when writing software, and data access logic is no different. For testing the data access layer, using an in-memory database is a very widespread approach. However, few developers realize that you need to test against the same database engine you use in production.
I can help you make sure your tests are both effective and efficient using Docker to speed up integration testing and simplify environement configuration.
Spring is just awesome. From Spring Core to Spring Data, Spring Integration and MVC, it offers everything a great variety of libraries to help you develop an enterprise application. I've been using Spring since 2005, and I've enjoyed it ever since.
I can also analyze the application architecture and make sure you are using the right tools for the right job.
Besides consulting, I'm also offering a coaching program that's aimed to help you learn how to become a better software engineer.
By enrolling in my coaching program, you get access to all my books, video courses, online workshops, as well as to a private group channel where we discuss various software-related concepts.
Let me teach you how to run your data access layer at high speeds!
If you want to book an on-site training session, you should email me at email@example.com
and discuss it in more detail.