Crud App with Spring Boot
Objective
In this tutorial, I will show you how to build a crud app using Spring Boot .
Environment
Java
Spring boot
Mysql
Spring Boot
- Java version
java -version
data:image/s3,"s3://crabby-images/a2af8/a2af88d13bb6c7175ddc0fdece44e9ef616aa7fb" alt="java version"
- Create a Java app with Spring Initializr
data:image/s3,"s3://crabby-images/07172/07172b60abb9bfb88f124b5943e85fe09acb3db2" alt="java spring Initializr crud app"
- Generate Java Spring App
data:image/s3,"s3://crabby-images/e73e2/e73e2240404e29f33ed4f3bfa557b9908ada866d" alt="generate java spring crud app with spring Initializr"
- Open Java Spring App with IntelliJ IDEA
data:image/s3,"s3://crabby-images/8bae9/8bae923c6dd9ed2e89c0bb0053e1d5a7aff3bf14" alt="open java spring app with intelliJ IDEA"
- Add model repository controller exception packages
data:image/s3,"s3://crabby-images/73225/7322560a5d48df6308b992d3db561b24d8231155" alt="Add model controller repository exception packages"
- Add User class
data:image/s3,"s3://crabby-images/b7c80/b7c80beecf94ab127e657f44141e7d4b70cde6a2" alt="New model User Class"
data:image/s3,"s3://crabby-images/dd13b/dd13bdd0e5ece466338c02fe2534f204d39910c4" alt="user class java"
- Add UserRepository
data:image/s3,"s3://crabby-images/fd808/fd808c7517c4cc68910121e7d510d06fd56ef4d0" alt="Add interface UserRepository"
data:image/s3,"s3://crabby-images/ca7b7/ca7b79489b8e3ec5e8099610f67628678f95c707" alt="UserRepository interface"
- Mysql workbench
create database data;
- configure database connection with JDBC driver application.properties
data:image/s3,"s3://crabby-images/9cd07/9cd070584e5d885166f0565d1d769ec1cc507953" alt="application properties"
- Run Spring Boot
data:image/s3,"s3://crabby-images/266a7/266a7168f47680c6e3689611e3681213a867c424" alt="run spring boot app"
- Result MySQL Workbench
show databases;
data:image/s3,"s3://crabby-images/d14ac/d14ac9e5daa8aaf333b63cf944b4b43fae405d4f" alt="mysql workbench database"
use data;
desc user;
data:image/s3,"s3://crabby-images/1375f/1375f875099db38dc1fbdebc0fe45a619064a932" alt="mysql data user table see columns"
- Add UserController class to send data in the database with postMapping
data:image/s3,"s3://crabby-images/9d777/9d7773c747b8a54e1e359c41284637aa897768c7" alt="Add UserController Class to send data in database with postMapping"
data:image/s3,"s3://crabby-images/01648/01648d4f3dddfbb2363d68dc0efbffebdbf098ee" alt="UserController Class spring postMapping"
- Run java spring boot port 8080
data:image/s3,"s3://crabby-images/6286f/6286fe3d859123232213c442b34843a91aad706f" alt="run java spring app tomcat port 8080"
- Postman: create a new collection
data:image/s3,"s3://crabby-images/68f20/68f20074ab26ac6cd40e08a2e705a6ad9e4a5ee9" alt="postman create new collection"
- new request send POST user localhost port 8080
data:image/s3,"s3://crabby-images/50ab4/50ab46a9fa3cf587d55f79609ef2259d2c9a0720" alt="new request send POST user localhost port 8080"
- view data in MySQL Workbench select from user
data:image/s3,"s3://crabby-images/87d6f/87d6f53a813653cd51908a3a271b5cb0740ddc62" alt="view data in MySQL Workbench select from user"
- GetMapping for getting data from the database
data:image/s3,"s3://crabby-images/37e66/37e6648091f9e0a082ea6b6efd5740a1d7e44859" alt="spring boot GetMapping for getting data from database"
- new request Postman get users localhost port 8080
data:image/s3,"s3://crabby-images/0f28b/0f28b606bf12e5d66da46dc8a945fbdbbeb5aa3c" alt="new request send get users localhost port 8080"
- GetMapping: view user by id
data:image/s3,"s3://crabby-images/b60e4/b60e436bf77fdcfbabef0b896f996821e239d0f1" alt="getMapping find user by id"
- Exception
data:image/s3,"s3://crabby-images/22830/2283024402bbbdcaeda2210df01d3b5395a21948" alt="user not found exception java"
data:image/s3,"s3://crabby-images/3d32a/3d32a9264bd25153cf2309f45b0cfb3da3f5d790" alt="user not found advice java"
- Test view user by Postman
data:image/s3,"s3://crabby-images/a3773/a3773e653b720133e98377ffc766c850a1e9afd4" alt="view user by i postman"
data:image/s3,"s3://crabby-images/659ed/659ed06b2f2243ecf32791cbec925bc805f15974" alt="view user by id not found error msg postman"
- PutMapping spring: edit user by id
data:image/s3,"s3://crabby-images/bb0bf/bb0bfc711074bfa41118afbcadbeb382b68f79c2" alt="Put Mapping edit user by id"
data:image/s3,"s3://crabby-images/5617d/5617d500b69c4baa32e0b7bda26b27845bab7187" alt="postman update user by id"
data:image/s3,"s3://crabby-images/2b1cd/2b1cd6788ec0096a48d339c403b4ed53ff4acb63" alt="edit user by id error message user not found postman"
- Delete Mappin spring: delete a user by id
data:image/s3,"s3://crabby-images/1a651/1a651b32ab4a8ce49c2c7c771d35e673ffb2e04d" alt="DeleteMapping spring delete user by id"
- delete user by id postman
data:image/s3,"s3://crabby-images/ec07b/ec07b32d3baef7933695dc2d772b7e8227176048" alt="delete user by id postman"
data:image/s3,"s3://crabby-images/ff809/ff8097e5d42a4bdf3a77f7e48136cf892dce42d1" alt="delete user by id not found postman"
data:image/s3,"s3://crabby-images/eeea6/eeea64f5ba31af1094da5585f7370d9172a8fd73" alt="result delete user mysql Wokbench"