PedroGeoGISdev wiki
  • Home
  • Linux OS
    • Linux: concepts
    • Linux: basic concepts
    • Linux: Bash
    • Linux: su and sudo
    • Linux: pipes
    • Linux: File System
    • Linux: Virtual Machines

    • Linux: distros
    • Linux Distros: Ubuntu
    • Linux Distros: Mint
    • Linux Distros: Debian
    • Linux Distros: openSuse
    • Linux Distros: Manjaro
    • Linux Distros: Red Hat Enterprise

    • Linux: laboratories
    • Linux Lab#LI01-1: Choose Linux
    • Linux Lab#LI01-2: Install at least three distributions
    • Linux Lab#LI01-3: Adjust user permissions
    • Linux Lab#LI02-1: Export env user with grep and pipe
    • Linux Lab#LI03-1: Manage users and groups
    • Linux Lab#LI03-2: Manage files
    • Linux Lab#LI03-3: Manage software
    • Linux Lab#LI03-4: Manage hardware
    • Linux Lab#LI04-1: Bash scripting, qtool
    • Linux Lab#LI04-2: Bash scripts as terminal tool
    • Linux Lab#LI04-3: Distribute the terminal app

    • Linux readings
    • Linux Resources
  • DevOps
    • What is DevOps
    • DevOps: Introduction
    • DevOps: Agile and Microservices
    • Infrastructure as code (IaC)
    • Immutable Infrastructure
    • Software Lifecycle

    • Documentation
    • How to document: Quarto and Obsidian

    • Network protocols
    • Network: Basics
    • Network: Client-server
    • Network Protocols
    • Network: DNS
    • Network: API Rest
    • Network: gRPC
    • Network: Websocket
    • Network: SMTP
    • Network: Ping
    • Network: UDP
    • Network: webhook
    • Network: SOAP
    • Network: graphQL

    • Version Control
    • Git
    • GitHub
    • Idea and GitHub 2023
    • Git and GitHub 2023 CLI

    • IDEs
    • IDE: Visual Code
    • IDE: IntellJIdea

    • DevOps tools
    • Amazon Web Services AWS
    • Docker
    • Jenkins pipelines
    • Kubernetes k8s
    • Digital Ocean
    • Nagios
    • Ansible

    • DevOps Laboratories
    • Lab 1: chat App
    • Lab 2: Spring Boot AWS AEB manually
    • Lab 3: Spring Boot and AWS S3 publisher
    • Lab 4: Spring Boot Docker/Jenkins
    • Lab 5: k8s on Digital Ocean
    • Lab 6: Spring Boot AWS codecommit

    • DevOps readings
    • DevOps Resources
  • MarkUp
    • MarkUp Languages
    • Introduction Markup
    • HTML Markup
    • Markdown Markup
    • Markdown and HTML working together, good idea?

    • Quarto Markdown
    • Quarto Markdown: basics
    • Quarto Markdown: creating
    • Quarto Markdown: publishing
    • Quarto Markdown: code & data
    • Quarto Markdown: api rest call
    • Quarto Markdown: OJS Cells
    • Quarto Markdown: cheat-sheet

    • Styling: CSS
    • Cascade Style Sheet
    • Cascade Style Sheet: Box Model and Containers
    • CSS: W3.css

    • MarkUp Languages Laboratories
    • Lab#MD01-1: Create and publish by Quarto

    • MarkUp Languages readings
    • MarkUp Languages Resources
  • Java SE
    • What is Java SE
    • Java Standard Edition: Basics
    • Java Standard Edition: Principles
    • Java MOOC Helsinki
    • Java MOOC Helsinki Syllabus

    • Java Create Project
    • Java SE: Maven
    • Java SE: Create Maven Project
    • Java SE: Project push GitHub
    • Java SE: JUnit and TDD

    • Java Concepts
    • Java SE: Class and Objects
    • Java SE: Scope
    • Java SE: static modifier
    • Java SE: Coupling and DDD
    • Java SE: Packages
    • Java SE: Abstract/Interface
    • Java SE: Java 8

    • Java Principles
    • Java SE: Encapsulation
    • Java SE: Abstraction
    • Java SE: Inherence
    • Java SE: Polymorphism

    • Java Design Patterns
    • Java Patterns: UML
    • Java Patterns: Types
    • Singleton
    • Factory
    • Abstract Factory
    • Builder
    • Facade
    • Bridge
    • Decorator
    • Composite
    • Observer
    • Strategy
    • State
    • Commander

    • Java SE Laboratories
    • Lab#SE00-1: Maven Person
    • Lab#SE00-2: Maven Clinic
    • Lab#SE00-3: Library Model
    • Lab#SE00-4: Abstract/Interface Human
    • Lab#SE01-1: Maven/Gradle Person and Account
    • Lab#SE01-2: Maven/Gradle Person and Account stored in JSON
    • Lab#SE02-1: Movie/Review, Model
    • Lab#SE02-2: Movie/Review, CRUD Operations
    • Lab#SE02-3: Movie/Review, factory
    • Lab#SE02-4: Movie/Review, interactivity and coupling
    • Lab#SE02-5: Movie/Review, simulate interactivity by console
    • Lab#SE03-1: Library/Book, Core-Model
    • Lab#SE03-2: Library/Book, Sprint Zero
    • Lab#SE03-3: Library/Book, Expand Model
    • Lab#SE04-1: healthyFood Restaurant, Core Model

    • Java SE readings
    • Java SE Resources
  • Python
    • Python Basics
    • Python: Basic Concepts
    • Python: Tips
  • JavaScript
    • JavaScript Basics
    • JavaScript: Basic Concepts
    • JavaScript: Tips
  • Spring
    • Spring Legacy
    • Spring Framework
    • Spring MVC
    • Springs Servlets

    • Spring Boot Basics
    • Spring Boot: fundamentals
    • Spring Boot: create a Project
    • Spring Boot: H2 DB and Thymeleaf
    • Spring Boot: cycle

    • Spring Boot Concepts
    • Spring Boot: Dependency Injection
    • Spring Boot: Annotations
    • Spring Boot: Controller
    • Spring Boot: View
    • Spring Boot: Thymeleaf
    • Spring Boot: Vaadin Flow
    • Spring Boot: Vaadin Hilla
    • Spring Boot: Model
    • Spring Boot: Rest
    • Spring Boot: Data & DB
    • Spring Boot: JPA & DI
    • Spring Boot: JPA Mappings
    • Spring Boot: JPA Relationships
    • Spring Boot: JPA Queries
    • Spring Boot: JPA Inherence
    • Spring Boot: Scaling

    • Spring Boot Laboratories
    • Lab#SB00-1: Library UML
    • Lab#SB00-2: CRUD User
    • Lab#SB00-3: LibraryManagement
    • Lab#SB00-4: API Rest
    • Lab#SB00-5: Rest & JPA-H2
    • Lab#SB00-6: Rest & MongoDB
    • Lab#SB00-7: Styling
    • Lab#SB01-1: DataBase
    • Lab#SB02-1: JPA Relationships
    • Lab#SB03-1: APIs & cloud
    • Lab#SB04-1: JPA Inherence
    • Lab#SB05-1: API Rest
    • Lab#SB06-1: employeeCourse
    • Lab#SB07-1: monitor Book
    • Lab#SB08-1: Restaurant UML
    • Lab#SB08-2: Vaadin
    • Lab#SB08-3: H2 and API Rest
    • Lab#SB08-4: JPA
    • Lab#SB08-5: Test API Rest
    • Lab#SB09-1: SpringIO Conference

    • Spring Boot readings
    • Spring Boot Resources
  • ReactJS
    • ReactJS: Principles
    • React JS: Introduction
    • React JS: render virtual DOM
    • React JS: Create a React project
    • React JS: Components
    • React JS: JSX
    • React JS: props and state

    • JavaScript: web scripting
    • JavaScript: basics
    • JavaScript: functions
    • JavaScript: objects
    • JavaScript: variables
    • JavaScript: flux control

    • ES6: ECMAScript 6
    • React JS ES6: arrow functions
    • React JS ES6: import modules
    • React JS ES6: array, data and key
    • React JS ES6: destructuring
    • React JS ES6: spread operator

    • ReacJS 18: Hooks
    • React JS: Rules of Hooks
    • ReactJS: useState
    • React JS: useReducer
    • React JS: useRef
    • React JS: useEffect
    • React JS: useContext
    • ReactJS: useMemo
    • ReactJS: custom hooks

    • ReactJS: Designing an App
    • React JS App: async
    • React JS App: events
    • React JS App: router
    • React JS App: conditional render
    • React JS App: styling

    • React JS: Laboratories
    • Lab#RE01-1: API Rest Axios
    • Lab#RE02-1: Router & Hooks
    • Lab#RE03-1: to-do app
    • Lab#RE03-2: HighCharts
    • Lab#RE03-3: API Rest Mono
    • Lab#RE03-4: API Rest Domains
    • Lab#RE03-5: data management
    • Lab#RE04-1: todo & server
    • Lab#RE04-2: Spring Boot & ReactJS
    • Lab#RE05-1: chat & websockets
    • Lab#RE05-2: chat: backend
    • Lab#RE05-3: chat & AWS
    • Lab#RE05-4: chat: test ws AWS
    • Lab#RE05-5: chat & front
    • Lab#RE05-6: chat & ws: front
    • Lab#RE06-1: healthyFood Restaurant
    • Lab#RE06-1-PR: create a pull request
    • Lab#RE07-1: traffic lights simulation

    • React JS readings
    • ReactJS Resources
  • Learning
    • Vocabulary
    • General Vocabulary
    • SCRUM Vocabulary
    • DevOps Vocabulary
    • Java SE Vocabulay
    • Spring Boot Vocabulary
    • DataBase Vocabulary
    • ReactJS Vocabulary
    • Web Vocabulary

    • Learning
    • Useful Questions
    • Learning: tips
    • Writing
    • Taking Notes
    • Comments
    • Document
    • Auto-Evaluate

    • Books & Articles
    • Books
    • Articles

    • What is SCRUM
    • SCRUM Agile Methodology
    • Agile Manifesto & Values
    • SCRUM Guide

    • Scrum Steps
    • Meetings, Impediments and Iterations
    • User stories, Tasks and Habits
    • Delivering Value & Communication
    • ScrumMaster, how it works
    • Mindset, the key to everything
    • Product Owner, how it works
    • Managing Time & Mind
    • Team & the Specialist
    • Albertus’ Dilemma
    • Before SCRUM
    • Team Dynamics
    • Emotions and Thoughts
    • Decision Making and Intuition
    • Beyond SCRUM
    • Balances, atmosphere and tools

    • Resources
    • SCRUM Resources
  • QGIS
    • QGIS basics
    • QGIS: basic concepts

    • QGIS laboratories
    • QGIS Laboratory 1: Introduction to Open Source GIS
  • ArcGIS Pro
    • ArcGIS Pro basics
    • ArcGIS Pro: basic concepts

    • ArcGIS Pro laboratories
    • ArcGIS Pro Laboratory 1: Getting Started
  • Bookmarks
    • Online Resources
    • Online Resources
  • About
    • About me and this site
    • About me
    • About this site
    • About images credit
  • Email
  • GitHub
  • LinkedIn
  1. Spring Boot Laboratories
  2. Lab#SB04-1: JPA Inherence
  • Spring

  • Spring Legacy
    • Spring Framework
    • Spring MVC
    • Springs Servlets

  • Spring Boot Basics
    • Spring Boot: fundamentals
    • Spring Boot: create a Project
    • Spring Boot: H2 DB and Thymeleaf
    • Spring Boot: cycle

  • Spring Boot Concepts
    • Spring Boot: Dependency Injection
    • Spring Boot: Annotations
    • Spring Boot: Controller
    • Spring Boot: View
    • Spring Boot: Thymeleaf
    • Spring Boot: Vaadin Flow
    • Spring Boot: Vaadin Hilla
    • Spring Boot: Model
    • Spring Boot: Rest
    • Spring Boot: Data & DB
    • Spring Boot: JPA & DI
    • Spring Boot: JPA Mappings
    • Spring Boot: JPA Relationships
    • Spring Boot: JPA Queries
    • Spring Boot: JPA Inherence
    • Spring Boot: Scaling

  • Spring Boot Laboratories
    • Lab#SB00-1: Library UML
    • Lab#SB00-2: CRUD User
    • Lab#SB00-3: LibraryManagement
    • Lab#SB00-4: API Rest
    • Lab#SB00-5: Rest & JPA-H2
    • Lab#SB00-6: Rest & MongoDB
    • Lab#SB00-7: Styling

    • Lab#SB01-1: DataBase
    • Lab#SB02-1: JPA Relationships
    • Lab#SB03-1: APIs & cloud
    • Lab#SB04-1: JPA Inherence
    • Lab#SB05-1: API Rest

    • Lab#SB06-1: employeeCourse

    • Lab#SB07-1: monitor Book

    • Lab#SB08-1: Restaurant UML
    • Lab#SB08-2: Vaadin
    • Lab#SB08-3: H2 and API Rest
    • Lab#SB08-4: JPA
    • Lab#SB08-5: Test API Rest

    • Lab#SB09-1: SpringIO Conference

  • Spring Boot readings
    • Spring Boot Resources

On this page

  • 1 Spring Boot Projects JPA Inherence strategies
  • 2 Inhrence with JPA and UML
    • 2.1 (0) @Entity Inhrence JPA
    • 2.2 (1) MappedSuperclass Inhrence JPA
    • 2.3 (2) Single Table with Discriminator Inhrence JPA
    • 2.4 (3) Joined Table Inhrence JPA
    • 2.5 (4) Table per class Inhrence JPA
    • 2.6 (0) Basic Spring Boot project
  • Edit this page
  • Report an issue
  1. Spring Boot Laboratories
  2. Lab#SB04-1: JPA Inherence

Lab#SB04-1: JPA Inherence

Spring Boot JPA Inherence strategies

Spring-Boot
lab
Spring Boot
Author

albertprofe

Published

Tuesday, June 1, 2021

Modified

Sunday, August 10, 2025

Welcome to the cifojava2022-6 wiki!

1 Spring Boot Projects JPA Inherence strategies

Name Type Description Link
universalPlanes Server Basic Spring Boot Project Done
JpaInherenceLibrary Server-Inherence Inhrence with JPA and UML @Entity Done
JpaInherenceLibrary1 Server-Inherence Inhrence with JPA and UML MappedSuperClass Done
JpaInherenceLibrary2 Server-Inherence Inhrence with JPA and UML Single Table with Discriminator Done
JpaInherenceLibrary3 Server-Inherence Inhrence with JPA and UML Joined Table Done
JpaInherenceLibrary4 Server-Inherence Inhrence with JPA and UML Table per class Done
  • there is no @Service neither @Controller
  • so, they are basically back-end projects
  • all work with @CrudRepository

2 Inhrence with JPA and UML

Inheritance is a fundamental concept of POO, but Relational databases have no concept of inheritance neither NoSQL (MongoDB, DymamoDB), so persisting inheritance in a SQL and NoSQL database _has its own particular way.

Because relational databases have no concept of inheritance, there is no standard way of implementing inheritance in database, so the hardest part of persisting inheritance is choosing how to represent the inheritance in the database.

JPA defines several inheritance mechanisms, mainly defined though the @Inheritance annotation or the <inheritance> element.

There are three inheritance strategies defined from the InheritanceType enum:

  1. SINGLE_TABLE
  2. TABLE_PER_CLASS
  3. JOINED
  • Single table inheritance is the default with discriminator values,
  • and table per class is an optional feature of the JPA spec, so not all providers may support it.
  • in joined strategy each class in the hierarchy is mapped to its table.

MAPPED SUPERCLASS

  • JPA also defines a mapped superclass concept defined through the @MappedSuperclass annotation or the <mapped-superclass> element.
  • A mapped superclass is not a persistent class, but allows common mappings to be defined for its subclasses.

Entity Inheritance

Entity Inheritance

Links: orientdb, logicbig, Java Persistence/Inheritance wikibooks and apache

2.1 (0) @Entity Inhrence JPA

JpaInherenceLibrary0
  • Base project:
    • POM
    • @Entity: Book (SuperClass), ItemBook, RareBook and Auhtor
    • n:m : Book<> Auhtor
    • DataBase H2: application.properties
    • Command Line Runner with methods to test
    • @CrudRepository JPA 2.0, @Component (CommandLineRunner) and @Test (Jupiter)
  • New Topics
    • How to code inherence and JPA uses SINGLE_TABLE strategy by default
          @Entity
          public class Book {}


          @Entity(name="BookItem")
          public class ItemBook extends Book {
          
             @ManyToMany(cascade = CascadeType.ALL, fetch = FetchType.EAGER)
             @JoinTable(name = "AUTHOR_BOOK_JOIN_TABLE",
                       joinColumns = { @JoinColumn(name = "AUTHOR_FK" )},
                       inverseJoinColumns = { @JoinColumn(name = "BOOK_FK" )})
             private Set<Author>authors = new HashSet<Author>();
          }

 
          @Entity(name="RareItem")
          public class RareItem extends Book {}


          @Entity(name="Author")
          @Table(name="AUTHOR_TABLE")
          public class Author {}
  • Versions
    • JpaInherenceLibrary v 1.1 : without @MappedSuperClass and @Entity superclass, Single Table strategy is applied BY DEFAULT

2.2 (1) MappedSuperclass Inhrence JPA

JpaInherenceLibrary1
  • Base project:
    • POM
    • @Entity: ItemBook, RareBook and Auhtor
    • Non-@Entity: Book
    • DataBase H2: application.properties
    • Command Line Runner with methods to test
    • @CrudRepository JPA 2.0, @Component (CommandLineRunner) and @Test (Jupiter)
  • New Topics
    • How can not we code @MappedSuperclass and @ManyToMany author
          @MappedSuperclass
          public abstract class Book {}


          @Entity(name="BookItem")
          @Table(name="ITEM_BOOK_TABLE")
          public class ItemBook extends Book {
          
             @ManyToMany(cascade = CascadeType.ALL, fetch = FetchType.EAGER)
             @JoinTable(name = "AUTHOR_BOOK_JOIN_TABLE",
                         joinColumns = { @JoinColumn(name = "AUTHOR_FK" )},
                         inverseJoinColumns = { @JoinColumn(name = "BOOK_FK" )})
             private Set<Author>authors = new HashSet<Author>();
          }

 
          @Entity(name="RareItem")
          @Table(name="RARE_ITEM_TABLE")
          public class RareItem extends Book {}


          @Entity(name="Author")
          @Table(name="AUTHOR_TABLE")
          public class Author {}
  • With @MappedSuperclass any relationship can’t be done

    With @MappedSuperclass

    With @MappedSuperclass
  • With @MappedSuperclass, one SuperClass and two SubClasses:

    With @MappedSuperclass

    With @MappedSuperclass
  • Versions

    • JpaInherenceLibrary1 v 1.0 : not using author just inherence without relatonship @ManyToMany

2.3 (2) Single Table with Discriminator Inhrence JPA

JpaInherenceLibrary2
  • Base project:
    • POM
    • @Entity: Book (SuperClass), ItemBook, RareBook and Auhtor
    • n:m : Book<> Auhtor
    • DataBase H2 : application.properties
    • Command Line Runner with methods to test
    • @CrudRepository JPA 2.0, @Component (CommandLineRunner) and @Test (Jupiter)
  • New Topics
    • How to code @Inheritance(strategy = InheritanceType.SINGLE_TABLE)
           @Entity
           @Inheritance(strategy = InheritanceType.SINGLE_TABLE)
           @DiscriminatorColumn(name="BOOK_TYPE", 
                 discriminatorType = DiscriminatorType.STRING)
           public class Book {}


          @Entity(name="BookItem")
          @Table(name="BOOK_ITEM_TABLE")
          @DiscriminatorValue(value= "ITEMBOOK")
          public class BookItem extends Book {
          
          @ManyToMany(cascade = CascadeType.ALL, fetch = FetchType.EAGER)
          @JoinTable(name = "AUTHOR_BOOK_JOIN_TABLE",
                 joinColumns = { @JoinColumn(name = "AUTHOR_FK" )},
                 inverseJoinColumns = { @JoinColumn(name = "BOOK_FK" )})
          private Set<Author>authors = new HashSet<Author>();}
 

          @Entity(name="RareItem")
          @Table(name="RARE_ITEM_TABLE")
          @DiscriminatorValue(value= "REAREBOOK")
          public class RareItem extends Book {}


          @Entity(name="Author")
          @Table(name="AUTHOR_TABLE")
          public class Author {}
  • With @Inheritance and SINGLE_TABLE

    ![@Inheritance ]( https://drive.google.com/uc?id=18nfiKnQaim4-lTD21iBwy313Daxtv73H)

version 1.1 : JpaInherenceLibrary2, SINGLE_TABLE strategy

2.4 (3) Joined Table Inhrence JPA

JpaInherenceLibrary3
  • Base project:
    • POM
    • @Entity: Book (SuperClass), ItemBook, RareBook and Auhtor
    • n:m : Book<> Auhtor
    • DataBase H2 : application.properties
    • Command Line Runner with methods to test
    • @CrudRepository JPA 2.0, @Component (CommandLineRunner) and @Test (Jupiter)
  • New Topics
    • How to code @Inheritance(strategy = InheritanceType.JOINED)
          @Entity
          @Table(name="BOOK_TABLE")
          @Inheritance(strategy = InheritanceType.JOINED)
          @DiscriminatorColumn(name="BOOK_TYPE",
                 discriminatorType = DiscriminatorType.STRING)
          public class Book {}


          @Entity(name="BookItem")
          @Table(name="BOOK_ITEM_TABLE")
          @PrimaryKeyJoinColumn(name = "bookItemId")
          @DiscriminatorValue(value= "ITEMBOOK")
          public class BookItem extends Book {
          
          @ManyToMany(cascade = CascadeType.ALL, fetch = FetchType.EAGER)
          @JoinTable(name = "AUTHOR_BOOK_JOIN_TABLE",
                 joinColumns = { @JoinColumn(name = "AUTHOR_FK" )},
                 inverseJoinColumns = { @JoinColumn(name = "BOOK_FK" )})
          private Set<Author>authors = new HashSet<Author>();}
 

          @Entity(name="RareItem")
          @Table(name="RARE_ITEM_TABLE")
          @PrimaryKeyJoinColumn(name = "rareItemId")
          @DiscriminatorValue(value= "RAREBOOK")
          public class RareItem extends Book {}


          @Entity(name="Author")
          @Table(name="AUTHOR_TABLE")
          public class Author {}
  • With @Inheritance and JOINED

    ![@Inheritance JOINED](https://drive.google.com/uc?id=1BpxaW7fV_kh4PyFWn3i49nG4SqnKYpAE)
verison 1.1 : JpaInherenceLibrary3

2.5 (4) Table per class Inhrence JPA

JpaInherenceLibrary4
  • Base project:
    • POM
    • @Entity: Book (SuperClass), ItemBook, RareBook and Auhtor
    • n:m : Book<> Auhtor
    • DataBase H2 : application.properties
    • Command Line Runner with methods to test
    • @CrudRepository JPA 2.0, @Component (CommandLineRunner) and @Test (Jupiter)
  • New Topics
    • How to code @Inheritance(strategy = InheritanceType.TABLE_PER_CLASS)

          @Entity
          @Table(name="BOOK_TABLE")
          @Inheritance(strategy = InheritanceType.TABLE_PER_CLASS)
          public class Book {}


          @Entity(name="BookItem")
          @Table(name="BOOK_ITEM_TABLE")
          public class BookItem extends Book {
          
          @ManyToMany(cascade = CascadeType.ALL, fetch = FetchType.EAGER)
          @JoinTable(name = "AUTHOR_BOOK_JOIN_TABLE",
               joinColumns = { @JoinColumn(name = "AUTHOR_FK" )},
               inverseJoinColumns = { @JoinColumn(name = "BOOK_FK" )})
          private Set<Author>authors = new HashSet<Author>();}
 

          @Entity(name="RareItem")
          @Table(name="RARE_ITEM_TABLE")
          public class RareItem extends Book {}


          @Entity(name="Author")
          @Table(name="AUTHOR_TABLE")
          public class Author {}
  • With @Inheritance and TABLE_PER_CLASS

@Inheritance TABLE PER CLASS

@Inheritance TABLE PER CLASS
version 1.1 : JpaInherenceLibrary4

2.6 (0) Basic Spring Boot project

Universal Planes
  • Preliminary works:
    • Create project on Spring Init
  • version 1.0 : spring boot executions
Back to top
Lab#SB03-1: APIs & cloud
Lab#SB05-1: API Rest

This website is built with Quarto.

Difficulties are just things to overcome, after all. Ernest Shackleton

  • Edit this page
  • Report an issue