GP Coder

Trang chia sẻ kiến thức lập trình Java

  • Java Core
    • Basic Java
    • OOP
    • Exception Handling
    • Multi-Thread
    • Java I/O
    • Networking
    • Reflection
    • Collection
    • Java 8
  • Design pattern
    • Creational Pattern
    • Structuaral Pattern
    • Behavior Pattern
  • Web Service
    • SOAP
    • REST
  • JPA
  • Java library
    • Report
    • Json
    • Unit Test
  • Message Queue
    • ActiveMQ
    • RabbitMQ
  • All
Trang chủ JPA Hibernate mapping type

Hibernate mapping type

Đăng vào 01/11/2019 . Được đăng bởi GP Coder . 7761 Lượt xem . Toàn màn hình

Khi tạo Entity trong Hibernate, chúng ta phải ánh xạ (mapping) các kiểu dữ liệu Java vào các kiểu dữ liệu trong database. Việc mapping này rất quan trọng, nó giúp Hibernate có thể chuyển đổi từ kiểu dữ liệu Java sang SQL và ngược lại một cách chính xác.

Trong bài này, tôi sẽ tổng hợp lại các kiểu dữ liệu tương ứng giữa Java, Hibernate và JDBC.

Nội dung

  • 1 Các kiểu dữ liệu nguyên thủy
  • 2 Các kiểu Date Time
  • 3 Các kiểu Date Time trong Java 8
  • 4 Các kiểu Binary và đối tượng lớn

Các kiểu dữ liệu nguyên thủy

Mapping typeJava typeJDBC typeHibernate type (org.hibernate.type package)
integerint hoặc java.lang.IntegerINTEGERIntegerTypes
longlong hoặc java.lang.LongBIGINTLongType
shortshort hoặc java.lang.ShortSMALLINTShortType
floatfloat hoặc java.lang.FloatFLOATFloatType
doubledouble hoặc java.lang.DoubleDOUBLEDoubleType
big_decimaljava.math.BigDecimalNUMERICBigDecimalType
characterjava.lang.StringCHAR(1)CharacterType
stringjava.lang.StringVARCHARStringType
bytebyte hoặc java.lang.ByteTINYINTByteType
booleanboolean hoặc java.lang.BooleanBITBooleanType
yes/noboolean hoặc java.lang.BooleanCHAR(1) (‘Y’ hoặc ‘N’)YesNoType
true/falseboolean hoặc java.lang.BooleanCHAR(1) (‘T’ hoặc ‘F’)TrueFalseType

Các kiểu Date Time

Mapping typeJava typeJDBC typeHibernate type (org.hibernate.type package)
datejava.util.Date hoặc java.sql.DateDATEDateType
timejava.util.Date hoặc java.sql.TimeTIMETimeType
timestampjava.util.Date hoặc java.sql.TimestampTIMESTAMPTimestampType
calendarjava.util.CalendarTIMESTAMPCalendarType
calendar_datejava.util.CalendarDATECalendarDateType
calendar_timejava.util.CalendarTIMECalendarTimeType
localejava.util.LocaleVARCHARLocaleType

Các kiểu Date Time trong Java 8

Mapping typeJava typeJDBC typeHibernate type (org.hibernate.type package)
Durationjava.time.DurationBIGINTDurationType
Instantjava.time.InstantTIMESTAMPInstantType
LocalDateTimejava.time.LocalDateTimeTIMESTAMPLocalDateTimeType
LocalDatejava.time.LocalDateDATELocalDateType
LocalTimejava.time.LocalTimeTIMELocalTimeType
OffsetDateTimejava.time.OffsetDateTimeTIMESTAMPOffsetDateTimeType
OffsetTimejava.time.OffsetTimeTIMEOffsetTimeType
ZonedDateTimejava.time.ZonedDateTimeTIMESTAMPZonedDateTimeType

Các kiểu Binary và đối tượng lớn

Mapping typeJava typeJDBC typeHibernate type (org.hibernate.type package)
binarybyte[]VARBINARY (hoặc BLOB)BinaryType
textjava.lang.StringCLOBClobType
serializableany Java class that implements java.io.SerializableVARBINARY (hoặc BLOB)SerializableType
clobjava.sql.ClobCLOBClobType
blobjava.sql.BlobBLOBBlobType

Trên đây là một số mapping kiểu dữ liệu giữa Java, Hibernate và JDBC. Còn nhiều kiểu dữ liệu khác , các bạn tham khảo thêm ở link bên dưới.

Tài liệu tham khảo:

  • https://docs.jboss.org/hibernate/orm/5.4/userguide/html_single/Hibernate_User_Guide.html#domain-model
5.0
05
Nếu bạn thấy hay thì hãy chia sẻ bài viết cho mọi người nhé! Và Donate tác giả

Shares

Chuyên mục: JPA Được gắn thẻ: Hibernate

Cài đặt và sử dụng Hibernate
Các Annotation của Hibernate

Có thể bạn muốn xem:

  • Sử dụng Hibernate Tool tạo các Hibernate Entity một cách tự động từ các table (26/11/2019)
  • Hibernate Native SQL Queries (24/02/2020)
  • Hibernate Query Language (HQL) (13/02/2020)
  • Giới thiệu về Hibernate (28/10/2019)
  • Tạo database table tự động từ Hibernate Entity (15/12/2019)

Bình luận

bình luận

Tìm kiếm

Bài viết mới

  • Clean code 13/01/2024
  • Giới thiệu CloudAMQP – Một RabbitMQ server trên Cloud 02/10/2020
  • Kết nối RabbitMQ sử dụng Web STOMP Plugin 19/06/2020
  • Sử dụng publisher confirm trong RabbitMQ 16/06/2020
  • Sử dụng Dead Letter Exchange trong RabbitMQ 13/06/2020

Xem nhiều

  • Hướng dẫn Java Design Pattern – Factory Method (98056 lượt xem)
  • Hướng dẫn Java Design Pattern – Singleton (97695 lượt xem)
  • Giới thiệu Design Patterns (87758 lượt xem)
  • Lập trình đa luồng trong Java (Java Multi-threading) (86427 lượt xem)
  • Giới thiệu về Stream API trong Java 8 (83830 lượt xem)

Nội dung bài viết

  • 1 Các kiểu dữ liệu nguyên thủy
  • 2 Các kiểu Date Time
  • 3 Các kiểu Date Time trong Java 8
  • 4 Các kiểu Binary và đối tượng lớn

Lưu trữ

Thẻ đánh dấu

Annotation Authentication Basic Java Behavior Pattern Collection Creational Design Pattern Cấu trúc điều khiển Database Dependency Injection Design pattern Eclipse Exception Executor Service Google Guice Gson Hibernate How to Interceptor IO Jackson Java 8 Java Core JDBC JDK Jersey JMS JPA json JUnit JWT Message Queue Mockito Multithreading OOP PowerMockito RabbitMQ Reflection Report REST SOAP Structuaral Pattern Swagger Thread Pool Unit Test Webservice

Liên kết

  • Clean Code
  • JavaTpoint
  • Refactoring Guru
  • Source Making
  • TutorialsPoint
  • W3Schools Online Web Tutorials

Giới thiệu

GP Coder là trang web cá nhân, được thành lập với mục đích lưu trữ, chia sẽ kiến thức đã học và làm việc của tôi. Các bài viết trên trang này chủ yếu về ngôn ngữ Java và các công nghệ có liên quan đến Java như: Spring, JSF, Web Services, Unit Test, Hibernate, SQL, ...
Hi vọng góp được chút ít công sức cho sự phát triển cộng đồng Coder Việt.

Donate tác giả

Tìm kiếm các bài viết của GP Coder với Google Search

Liên hệ

Các bạn có thể liên hệ với tôi thông qua:
  • Trang liên hệ
  • Linkedin: gpcoder
  • Email: contact@gpcoder.com
  • Skype: ptgiang56it

Follow me

Copyright 2025 © GP Coder · All Rights Reserved · Giới thiệu · Chính sách · Điều khoản · Liên hệ ·

Share

Blogger
Delicious
Digg
Email
Facebook
Facebook messenger
Flipboard
Google
Hacker News
Line
LinkedIn
Mastodon
Mix
Odnoklassniki
PDF
Pinterest
Pocket
Print
Reddit
Renren
Short link
SMS
Skype
Telegram
Tumblr
Twitter
VKontakte
wechat
Weibo
WhatsApp
X
Xing
Yahoo! Mail

Copy short link

Copy link