Setup a Spring boot application with MVC and JPA
Introduction#
A Spring Boot application integrates several Spring projects, simplifying the development of Java applications. Here's a brief introduction to its main components:
- Spring Boot Web MVC:
- Spring Boot Web MVC simplifies web development by providing an out-of-the-box setup for creating web applications. It follows the Model-View-Controller (MVC) pattern to separate concerns:
- Model handles data (e.g., entities or domain objects).
- View manages the UI (e.g., Thymeleaf, JSP).
- Controller processes requests and returns views or data.
- Spring Boot automatically configures essential components like embedded web servers (e.g., Tomcat) and provides easy handling of RESTful endpoints.
- Spring Boot Web MVC simplifies web development by providing an out-of-the-box setup for creating web applications. It follows the Model-View-Controller (MVC) pattern to separate concerns:
- Spring Boot Data JPA:
- Spring Boot Data JPA simplifies data access and interaction with relational databases by integrating JPA (Java Persistence API). It provides easy CRUD operations, pagination, and query methods.
- JpaRepository offers built-in methods for interacting with the database, while custom query methods can be created with query derivation or JPQL.
Build A Spring Boot Application#
- Go to https://start.spring.io/, configure the necessary project settings as shown in the image, add the required dependencies, and generate the application as a ZIP file.
data:image/s3,"s3://crabby-images/3b9a6/3b9a6c6e30cf0b02819dcf793e9a1fdcd164bea0" alt="Select a Maven Java project with Spring Boot (latest version). Add the group, artifact, name, description, and set packaging as JAR. Also, select the Java version and add the following dependencies: Lombok, Spring Data JPA, Spring Web, and a database driver like MySQL."
- After that, go to File Explorer > Downloads, and extract the ZIP file.
- After that, open the project in your preferred IDE. Here, we are using IntelliJ IDEA.
- After opening the project, the first thing we need to do is reload Maven.
data:image/s3,"s3://crabby-images/7e001/7e0012293beba16b12c69c31781bfd69ab0e1f5c" alt="Open the project in IntelliJ IDEA, and you will see the Maven reload symbol. Click on it to reload the project."
- Now, let's add some packages. To do this, navigate to src > main > java > <group package> . After that, right-click on <group package>, select New > Package or Java Class, and create the necessary packages and classes.
data:image/s3,"s3://crabby-images/bb22f/bb22f625157b0481d61659196f2411f45412f18d" alt="Right-click src/main/java to create a package, then right-click the package to create a Java class."
- In the same way, you can create different classes, interfaces, enums, and packages within your specific package.
data:image/s3,"s3://crabby-images/7a3f5/7a3f5093f39047f7532c1f2c2f4aa1874b104849" alt="Open the Project tool window and expand the folders to view the structure."
Dto Class
Here, we are using @AllArgsConstructor
and @NoArgsConstructor
. These constructors are required by Jackson to convert JSON into DTO classes.
Entity Class
Here, we are using @AllArgsConstructor
and @NoArgsConstructor
because Hibernate requires these constructors to create entities and map database tables to entity objects.
Repository Interface
This repository interface extends JpaRepository<ProductEntity, Long>
, where ProductEntity
is the entity type and Long
is the type of the entity's ID.
Controller Class
Service Class
Here, we need to create the necessary constructor, or we can use @RequiredArgsConstructor
from Lombok, which automatically generates the required constructors for us.
Here, we use the DTO class for business logic, and we need to convert it to an Entity class. To do this, you should add the ModelMapper dependency and configure it as a bean.
Here, we need to handle all exceptions by creating custom exception classes.
Add dependency
Go to https://mvnrepository.com/artifact/org.modelmapper/modelmapper and copy the dependency for the latest version.
data:image/s3,"s3://crabby-images/f8f44/f8f4408bb12d9ec9cb4fa97d45e52ce74f134503" alt="Visit the ModelMapper page on Maven Repository, copy the latest Maven dependency."
Add it in dependencies section of your Pom.xml file and after adding it, reload your maven.
Configuration Class
Custom Exception Class
Dependencies and Plugins
Database Setup#
To store our data, we need to connect to a real database (e.g., MySQL, PostgreSQL). We can familiarize ourselves with industry-standard practices using applications like DBeaver. While there are several other applications available for connecting to multiple databases and running queries, DBeaver is popular among developers due to its versatility. Let’s explore how to use it after installing the software.
Installing MySql
Visit Setting up MySQL db with Spring Data JPA page and for further guides you can check https://www.dataquest.io/blog/install-mysql-windows/
Installing DBeaver
- Visit https://dbeaver.io/download/ download page and download the latest version for your preferred operating system. You can check this documentation for further guides https://dbeaver.com/docs/dbeaver/ .
How to Connect to a Database in DBeaver:#
- Open DBeaver application
data:image/s3,"s3://crabby-images/4f942/4f942bc4fc3a10bb7dbb7c520e9f3eafb844918a" alt="The view of DBeaver"
- Go to New Database Connection and select the database you want to connect to
data:image/s3,"s3://crabby-images/00274/0027490dffc36963aaad6f371219240b52a82441" alt="Click New Database Connection and select your database."
- Here, we have created a new database connection (MySQL) and clicked the Next button.
data:image/s3,"s3://crabby-images/b994f/b994fff3ae1207982f8a860526034cfdc7d6e436" alt="Created a new MySQL connection and clicked Next."
- Here, you enter the password.
data:image/s3,"s3://crabby-images/89544/89544e34dc332fe2f3ae628797a355a9439f2697" alt="Enter the password in the provided field."
- Click ‘Test Connection’. After testing, you will see a pop-up like the image. Press ‘OK.’
data:image/s3,"s3://crabby-images/d31e0/d31e05e2e2e9c681645bc28498bd248035e1a97e" alt="Click Test Connection, then click OK in the pop-up."
- After that, check ‘Database Navigator’; you should see the localhost:3306 (MySQL) connection.
data:image/s3,"s3://crabby-images/7bcef/7bcefcdd9e7e5f455fe15fb06aa5047ec52738a7" alt="Check Database Navigator for the localhost:3306 (MySQL) connection."
- You need to check every time whether the connection is established. Essentially, ‘the green tick’ indicates that you are connected.
data:image/s3,"s3://crabby-images/440db/440dbac67d1e8207b37a81fb934118a7457020e3" alt="Check for a green tick to confirm the connection is successful."
- If you see nothing, that means you are disconnected, and you will need to reconnect. To do this, right-click on it, and you will see the ‘Connect’ option.
data:image/s3,"s3://crabby-images/dcfeb/dcfebecf2f5d451a44c67febe585d59f0099fa6d" alt="Right-click and select Connect if disconnected."
- If you see a ‘red cross,’ that means you need to log in to MySQL again using the MySQL command line. After that, you can reconnect.
data:image/s3,"s3://crabby-images/59b5a/59b5abc13bf1f7c9a15c264399368df8f587399e" alt="A red cross indicates a need to log in to MySQL and reconnect."
How to Create a Database in DBeaver:#
- After connecting to MySQL, you can go to localhost:3306 > Databases. Right-click on Databases to create new databases.
data:image/s3,"s3://crabby-images/882ce/882ce67213b2efd54461ed13b069f2537ffabdfb" alt="Right-click Databases and select Create New Database."
- Go to ‘Create New Database,’ and enter the name of the database you want to create, then press ‘OK.’
data:image/s3,"s3://crabby-images/b2d7f/b2d7f3b4ecea5dd8ef067f6d9bd1000f1583b18d" alt="Enter the database name in Create New Database and click OK."
Application Configure Database Connection#
This configuration is crucial for connecting a Spring application to a MySQL database, defining how Hibernate interacts with that database, and providing useful logging for development. Adjustments should be made for production environments, especially concerning security and schema management. If you have specific areas you want to delve deeper into, let me know!
Go to resources > application.properties
or resources > application.yml
data:image/s3,"s3://crabby-images/088ab/088ab83a3a05d130eb160cd90dcf00f15dffe757" alt="Navigate to resources > application.properties or application.yml."
Application Properties
data:image/s3,"s3://crabby-images/23d93/23d933bae29c190e3251fc7166ac7807d7073a61" alt="Configure the database in the application.properties file."
spring.application.name=product_ready_features
Purpose: Sets the name of the Spring application. This name can be useful for logging, monitoring, and managing different services in a microservices architecture.
Database Configuration
- spring.datasource.url
spring.datasource.url=jdbc:mysql://localhost:3306/<Your Database Name>?useSSL=false
Purpose: Specifies the URL for the database connection. In this case:
jdbc:mysql://
indicates that the application will use the MySQL JDBC driver.localhost:3306
refers to the database server running on the local machine at port 3306 (the default port for MySQL)./<Your Database Name>
is the name of the database to connect to.?useSSL=false
disables SSL for the connection, which can be useful in a development environment where SSL is not set up.
- spring.datasource.username
spring.datasource.username=root
Purpose: Specifies the username to connect to the database. In this case, it is set to root
, which is the default administrative user for MySQL.
- spring.datasource.password
spring.datasource.password=<your mysql login password>
Purpose: Sets the password for the specified username to connect to the database. Ensure that sensitive information like passwords is handled securely (e.g., using environment variables or a secrets management tool).
- JPA Configuration
- spring.jpa.hibernate.ddl-auto
spring.jpa.hibernate.ddl-auto=create
Purpose
: Configures the behavior of the Hibernate framework regarding the database schema:
create
: Drops the existing schema and creates a new one on application startup. This is useful during development but should be changed toupdate
ornone
in production to avoid data loss.
spring.jpa.show-sql
spring.jpa.show-sql=true
Purpose: Enables the logging of SQL statements generated by Hibernate. This is useful for debugging and understanding what queries are being executed against the database.
spring.jpa.properties.hibernate.format_sql
spring.jpa.properties.hibernate.format_sql=true
Purpose: Formats the SQL output for better readability in the logs. When set to true
, it indents the SQL statements, making it easier to read in the log files.
Run Application#
Go to main application file and go to run button to run it.
Output#
- Output of IDE Console:
data:image/s3,"s3://crabby-images/13cbb/13cbbe2cdb5d277300a7dfe7ad7cff717ce046c5" alt="The view of IDE console logs"
- Output of Postman Console:
- For creating a new product, getting all products, getting product by product id, we are basically sending the request through Postman.
- Create New Product
- For creating a new product, getting all products, getting product by product id, we are basically sending the request through Postman.
data:image/s3,"s3://crabby-images/b3a00/b3a007f83fd3b76ec0e2b2076da531ce733676a6" alt="The view of postman ( after create a new product)"
- Get All Products
data:image/s3,"s3://crabby-images/24eea/24eea039647ecc61c6fa75fe48be8275cc97fbd3" alt="The view of postman ( get list of all created product)"
- Get Product By Id
- If the ID is present, the product is displayed.
data:image/s3,"s3://crabby-images/0400c/0400c4a642d3bb2524138bbc9bdbf841679f9667" alt="The view of postman ( get the created product by product id)"
- If the ID is not present, an internal server error is returned.
data:image/s3,"s3://crabby-images/3f3c5/3f3c56fcd9db0fd4b7ef7d17530ef4cdff65cfca" alt="Internal server error in Postman for non-existent product ID."
- To handle this server-related exception, we need to create a custom exception handler class (GlobalExceptionHandler).
- ApiError Class
- GlobalExceptionHandler
- In this class, we will specifically handle the 404 Not Found error.
- After running the application, if you send an invalid request, it will display a 404 Not Found error.
data:image/s3,"s3://crabby-images/0dbcd/0dbcd8421a873f5b4f63c5f40f605c70926d4b02" alt="Postman shows 'Not Found' for a non-existent product ID after exception handling."
- Output of Database:
- After running applications
data:image/s3,"s3://crabby-images/075e2/075e214f2109becae417f6489cf63720914cbd00" alt="DBeaver view after creating all tables."
After creating new product. Let’s see our database.
data:image/s3,"s3://crabby-images/541e4/541e481c6693f3236d50e500dde06bca6d22de05" alt="DBeaver view after adding new products in table format."
Conclusion#
This article explains how to build a Spring Boot application with MVC and JPA, covering entities, services, controllers, and exception handling. It also highlights using ModelMapper for DTO conversions and best practices for maintainability. Spring Boot's simplicity and scalability make it ideal for modern Java development.