Bibernate ORM is a powerful object/relational mapping solution for Java, and makes it easy to develop persistence logic for applications, libraries, and frameworks.
Bibernate implements JPA, the standard API for object/relational persistence in Java, but also offers an extensive set of features and APIs which go beyond the specification.
Bibernate is a conceptual Object/Relational Mapping (ORM) framework tailored for Java applications, designed to streamline the interaction between Java objects and relational databases. It abstracts the complexity of database access, allowing developers to work with database entities as if they were Java objects. Here's a more detailed look at its features, with an emphasis on language support:
- Action Queue Manages the order of database operations (inserts, updates, deletes) to ensure transactional integrity.
- Annotations: Used to define how Java classes and fields map to database tables and columns without verbose XML configuration files.
- Connection Pool: A cache of database connections that allows for reuse, improving performance by reducing the overhead of establishing connections.
- CRUD Operations: Simplifies Create, Read, Update, and Delete operations with straightforward methods, abstracting the underlying SQL.
- Dirty Checking: Automatically detects changes in entities since the last synchronization with the database, minimizing unnecessary updates.
- First Level Cache: A per-session cache that reduces database hits by storing entities retrieved during the session's lifetime.
- Lazy Loading: Delays the loading of certain properties or collections of an entity until they are explicitly accessed, optimizing resource usage.
- Pessimistic Locking: Locks data at the database level to prevent concurrent modifications, ensuring data consistency in high-concurrency environments.
- Query Language (Native Query BiQL): A custom query language or API designed for efficient and flexible database querying beyond standard SQL capabilities.
- Transaction: Supports transactions to ensure data integrity, allowing multiple operations to be executed as a single atomic action.
- DDL table creation: Supports automates table creation for entities annotated with
@Entity
, managing SQL types and constraints, and supports relationships except for@ManyToMany
, enhancing database schema management with a simple property configuration.
Bibernate aims to reduce the boilerplate associated with database programming in Java and potentially other JVM languages, offering a developer-friendly API and improving application performance through efficient data management practices. Its design reflects a commitment to flexibility, performance, and ease of use in the development of Java-based applications and beyond.
Make sure that you are using Java 17
Follow these steps to integrate Bibernate Framework into your project:
- Open your project's
pom.xml
file. - Add the following Maven dependency:
<dependency>
<groupId>io.github.bobocode-breskul</groupId>
<artifactId>bibernate</artifactId>
<version>2.0</version>
</dependency>
- Add
application.properties
file.
# Connection pool type: HikariCP, Apache, c3p0, or leave blank for default DataSource
bibernate.datasource.type=HikariCP
# Database connection details
bibernate.connection.url=jdbc:postgresql://localhost:5432/postgres
bibernate.connection.username=postgres
bibernate.connection.password=postgres
bibernate.connection.driver_class=org.postgresql.Driver
bibernate.dialect=com.breskul.bibernate.persistence.dialect.PostgresDialect
# Option available to suppress notifications for executed SQL queries
bibernate.show_sql=true
# Enabling create_tables property will drop tables and create them from entities
bibernate.ddl.create_tables=true
Now you are ready to use Bibernate framework features.
You can find the example of a Bibernate application here.
public class Main {
public static void main(String[] args) {
SessionFactory sessionFactory = Persistence.createSessionFactory();
try (Session session = sessionFactory.openSession()) {
// Create
Person firstPerson = new Person("Ivan", "Franko", 59);
Person secondPerson = new Person("Taras", "Shevchenko", 47);
session.persist(firstPerson);
session.persist(secondPerson);
// Find by ID
Person foundPerson = session.findById(Person.class, firstPerson.getId());
// Update
foundPerson.setAge(40);
// Delete
session.delete(foundPerson);
session.flush();
// Use @OneToMany, @ManyToOne, @OneToOne relations
Note note1 = new Note("Svitaye, kray neba palaye", secondPerson);
Note note2 = new Note("Meni trynadtsyatyy mynalo", secondPerson);
session.persist(note1);
session.persist(note2);
// Use transactions
Transaction transaction = session.getTransaction();
try {
transaction.begin();
Person thirdPerson = new Person("Ivan", "Kotliarevsky", 69);
Person fourthPerson = new Person("Larysa", "Kosach", 42);
session.persist(thirdPerson);
session.persist(fourthPerson);
transaction.commit();
} catch (Exception e) {
transaction.rollback();
}
// Execute queries using BiQL
String biQLQuery = "from Person";
List<Person> personList = session.executeBiQLQuery(biQLQuery, Person.class);
for (Person person : personList) {
System.out.println(person);
}
// Execute queries using native queries
String nativeQuery = "SELECT * FROM notes";
List<Note> notes = session.executeNativeQuery(nativeQuery, Note.class);
for (Note note : notes) {
System.out.println(note);
}
// Use pessimistic locking
Person lockedUser = session.findById(Person.class, secondPerson.getId(), LockType.PESSIMISTIC_READ);
System.out.println(lockedUser);
} catch (Exception e) {
throw new RuntimeException(e);
}
}
}
@Data
@NoArgsConstructor
@Entity
@DynamicUpdate
@Table(name = "persons")
@ToString
public class Person {
@Id
@Column(columnDefinition = "BIGSERIAL")
private Long id;
@Column(name = "first_name")
private String firstName;
@Column(name = "last_name")
private String lastName;
@Column(name = "age")
private Integer age;
@OneToMany
private List<Note> noteList;
public Person(String firstName, String lastName, Integer age) {
this.firstName = firstName;
this.lastName = lastName;
this.age = age;
}
}
@Data
@Entity
@Table(name = "notes")
@NoArgsConstructor
public class Note {
@Id
@Column(columnDefinition = "BIGSERIAL")
private Long id;
private String note;
@ManyToOne
@ToString.Exclude
private Person persons;
public Note(String note, Person persons) {
this.note = note;
this.persons = persons;
}
}
Explore additional features in the Introduction section. There's more to uncover!
We welcome contributions! If you'd like to contribute to Bibernate, please contact with the team Breskul.
This project is licensed under the Apache License.