Έχοντας ξεμπερδέψει με τη θεωρία, σήμερα θα δούμε ένα πρακτικό επεισόδιο.
Θα φτιάξουμε μια μικρή εφαρμογή Todo list, δεν θα επικεντρωθούμε στην ωραιοποίηση της σελίδας αλλά στην εξερεύνηση μιας προηγμένης χρήσης του Spring Boot, τη χρήση των drivers για σύνδεση στη βάση δεδομένων.
Η βάση που θα χρησιμοποιήσω κατά τη διάρκεια του βίντεο είναι η MySQL, είναι μια πολύ γνωστή βάση και χρησιμοποιείτε από πάρα πολλές εταιρίες και ιδιώτες που αναπτύσσουν διαφόρων ειδών εφαρμογές.
Για εργαλείο σχεδιασμού και διαχείρισης της βάσης θα χρησιμοποιήσω το MySQL Workbench.
Όπως θα παρακολουθήσετε και στο βίντεο θα φτιάξουμε με τη χρήση του εργαλείου MySQLWorkbench μια νέα βάση και θα προσθέσουμε ένα χρήστη.
Στη συνέχεια θα χρησιμοποιήσουμε το eclipse για να φτιάξουμε ένα νέο έργο Spring Boot τα βήματα είναι αναλυτικά στο βίντεο.
Για να μπορεί να φτιάξει τους πίνακες στη βάση δεδομένων θα ορίσουμε μια κλάση (class) όπου θα ορίσουμε όλα τα πεδία που χρειαζόμαστε.

Θα προσθέσουμε στο POM αρχείο μας το dependency JPA (Java Persistence API).
Θα συνεχίσουμε με την προσθήκη των ρυθμίσεων του application.properties. Όπως μπορείτε να δείτε πιο κάτω το Spring Boot με πολύ απλές ρυθμίσεις αναλαμβάνει τις πιο σύνθετες λειτουργίες και μας διευκολύνει, πχ δεν χρειάζεται να φτιάξουμε connection strings.

Στην πιο πάνω εικόνα μπορούμε να δούμε και ορισμένες επιπρόσθετες ρυθμίσεις, όπως την εντολή για την εκτέλεση DDL (Data Definition Language) εντολών από το ORM (Object Relation Mapper) πακέτο.

Στο βίντεο συζητάμε και τις διάφορες επιλογές που μπορούμε να εκτελέσουμε.

Επίσης θα συζητήσουμε και τη χρήση του πιο πάνω, που δίνει εντολή στο JPA, να ακολουθεί την ονομασία που εμείς καθορίζουμε.
Γιατί όμως πρέπει να καθορίζουμε εμείς το όνομα του πίνακα και το όνομα των πεδίων;
Παρότι παρέχεται η δυνατότητα αυτόματης δημιουργίας ονομάτων πινάκων και πεδίων, η πρακτική αυτή αποθαρρύνεται λόγω των ενδεχόμενων προβλημάτων συμβατότητας μεταξύ διαφορετικών βάσεων δεδομένων, της δυσκολίας συντήρησης του κώδικα και της απώλειας ελέγχου στην δομή της βάσης δεδομένων.
Αναλυτικά στο βίντεο φτιάξαμε
- Διάφορες οθόνες με τη χρήση html αρχείων
- Διαδικασία που εισάγει δεδομένα κατά την εκκίνηση της εφαρμογής με τη χρήση του command line runner, με χαρακτηριστικό annotation @Component
- Χρήση του repository, διαμεσολαβητή εφαρμογής και βάσης δεδομένων με τη χρήση JPA
- Κλάση με χαρακτηριστικό annotation @Entity
- Ορισμός και χρήση μεταβλητής repository με χαρακτηριστικό annotation @Autowired
- Ορισμός και χρήση του Controller με το αντίστοιχο annotation
- Πάντρεμα http requests με τις αντίστοιχες οθόνες.
- @GetMapping
- @PostMapping
- Ορισμός και χρήση
- Map<T>, για ανάκτηση των request parameters
- Optional<T>, για ανάκτηση δεδομένων από το repository όπου υπάρχει ασάφεια εάν υπάρχουν δεδομένα ή όχι (null)
- Χρήση του repository για:
- Ανάκτηση εγγραφών
- Δημιουργία καινούργιας εγγραφής
- Επεξεργασία εγγραφής
- Διαγραφή εγγραφής
- Χρήση του Model And View για μεταφορά δεδομένων από τον controller στα html αρχεία
- Χρήση του @PathVariable στις μεθόδους που καθορίσαμε
- Χρήση του thymeleaf για παρουσίαση δεδομένων στην οθόνη, με τεχνικές όπως τα th:each, το th:text, th:value και th:href
- Χρήση του thymeleaf χαρακτηριστικού @ που συνδυάζει το URL του server μας μαζί με ένα endpoint που ορίζουμε

