什么是Hibernate方言和方言列表

Hibernate中的方言方言是Java JDBC类型和SQL类型之间的类和桥梁,其中包含Java语言数据类型和数据库数据类型之间的映射。Dialect允许Hibernate生成针对特定关系数据库优化的SQL。Hibernate基于Dialect该类为特定数据库生成查询。

1.Hibernate方言类

  1. 创建JPAEntityManagerFactory或HibernateSessionFactory实例后,Dialect将在内部创建该实例。
  2. Dialect实例创建时,它注册所有的配置提供方言的SQL函数,翻译Hibernate查询SQL查询,也登记所有SQL类型和Java JDBC类型到Java类型映射到数据库类型,反之亦然。
  3. 对于所有数据库,SQL类型都不相同,因此特定的数据库将具有特定的方言,例如,DB2数据库的org.hibernate.dialect.DB2Dialect方言是,MySql 5数据库的方言是org.hibernate.dialect.MySQL5Dialect
  4. 从一个数据库切换到另一个数据库时,一项主要更改就是将对应的Dialect更改为该数据库。
  5. 要实现自定义方言,扩展Dialect类Sub类应提供一个公共的默认构造函数,该构造函数注册一组类型映射和默认的Hibernate属性。子类应该是不可变的。

2.示例方言配置

2.1hibernate.properties示例:db2数据库的Hibernate方言

hibernate.connection.driver_class = com.ibm.db2.jcc.DB2Driver

hibernate.connection.url = jdbc:db2://<host>:<port50000>/<dbname>

hibernate.connection.username = myuser

hibernate.connection.password = secret

hibernate.dialect = org.hibernate.dialect.DB2Dialect

2.2hibernate.cfg.xml示例:org.hibernate.dialect.MySQL8Dialect

<property name="connection.url">jdbc:mysql://localhost:3306/jpa_jbd?serverTimezone=UTC&useSSL=false</property>

<property name="connection.username">root</property>

<property name="connection.password">password</property>

<property name="connection.driver_class">com.mysql.jdbc.Driver</property>

<property name="dialect">org.hibernate.dialect.MySQL8Dialect</property>

2.3HibernateConfiguration示例:mysql方言

Configuration cfg = new Configuration()

.addClass(org.javabydeveloper.domain.Student.class)

.setProperty("hibernate.dialect","org.hibernate.dialect.MySQL5Dialect")

.setProperty("hibernate.connection.datasource","jdbc:mysql://localhost:3306/<dbname>")

.setProperty("hibernate.order_updates","true");

2.4JPA persistence.xml示例:PostgreSQL方言

<persistence-unit name="RESOURCE_LOCAL">

<provider>org.hibernate.jpa.HibernatePersistenceProvider</provider>

<properties>

<property name="javax.persistence.jdbc.driver" value="org.postgresql.Driver" />

<property name="javax.persistence.jdbc.url" value="jdbc:postgresql://localhost/dbName" />

<property name="javax.persistence.jdbc.user" value="dbuser" />

<property name="javax.persistence.jdbc.password" value="password" />

<property name="hibernate.show_sql" value="true" />

<property name="hibernate.dialect" value="org.hibernate.dialect.PostgreSQLDialect"/>

</properties>

</persistence-unit>

3.为什么要在Hibernate中使用方言?

当需要将实体映射和Hibernate查询转换为特定于数据库的特定查询时,Hibernate会使用Dialect生成所有实体映射和Hibernate查询到“特定数据库”查询,并使用JDBC来执行它们。让我们看一个示例,下图显示了有关Dialect的清晰图片。

如果将hbm2ddl.auto设置为在配置中创建并创建会话工厂new Configuration().configure().buildSessionFactory()

  1. 对于所有实体,Hibernate都会为创建表生成本机查询,并使用JDBC执行该查询。
  2. 为了生成本机查询,Hibernate使用您的实体映射并使用提供的方言类将Java类型映射到数据库数据类型。
  3. 同样,当需要创建特定于数据库的查询时,Hibernate将使用Dialect类。

4.如果不指定方言怎么

如果未在配置中指定Dialect类,则对于大多数Hibernate数据库,请尝试从数据库连接解析方言名称。最好的做法是提供方言,以便HibernateDialect为特定的数据库版本标识适当的类。

5. Hibernate中的SQL方言列表

org.hibernate.dialect包中提供了所有Hibernate方言。以下是Hibernate中流行的SQL方言列表。

方言名称

方言类

描述

DB2

org.hibernate.dialect.DB2Dialect

DB2的SQL方言。

DB2 AS / 400

org.hibernate.dialect.DB2400Dialect

DB2 / 400的SQL方言。

DB2 OS390

org.hibernate.dialect.DB2390Dialect

DB2 / 390的SQL方言。

DB2390V8方言

org.hibernate.dialect.DB2390V8Dialect

DB2 / 390版本8的SQL方言。

DB2400V7R3Dialect

org.hibernate.dialect.DB2400V7R3Dialect

i的SQL方言。

DB297方言

org.hibernate.dialect.DB297Dialect

DB2 9.7的SQL方言。

H2

org.hibernate.dialect.H2Dialect

与H2数据库兼容的方言。

HyperSQL(HSQL)

org.hibernate.dialect.HSQLDialect

与HSQLDB(HyperSQL)兼容的SQL方言。

Informix

org.hibernate.dialect.InformixDialect

似乎可以与Informix Dynamic Server版本7.31.UD3,Informix JDBC驱动程序版本2.21JC3一起使用。

英格利斯

org.hibernate.dialect.IngresDialect

用于Ingres 9.2的SQL方言。

英格利斯9

org.hibernate.dialect.Ingres9Dialect

用于Ingres 9.3和更高版本的SQL方言。

Ingres 10

org.hibernate.dialect.Ingres10Dialect

用于Ingres 10和更高版本的SQL方言。

玛丽亚方言

org.hibernate.dialect.MariaDBDialect

这是所有MariaDB方言的基类,并且可以与任何MariaDB版本一起使用

玛丽亚DB53方言

org.hibernate.dialect.MariaDB53Dialect

旨在与MariaDB 5.3或更高版本一起使用

玛丽亚DB10方言

org.hibernate.dialect.MariaDB10Dialect

MariaDB 10或更高版本

玛丽亚DB103方言

org.hibernate.dialect.MariaDB103Dialect

适用于MariaDB 10.3和更高版本的SQL方言提供序列支持,锁定超时等。

玛丽亚DB102方言

org.hibernate.dialect.MariaDB102Dialec

MariaDB 10.2或更高版本

Microsoft SQL Server 2000

org.hibernate.dialect.SQLServerDialect

Microsoft SQL Server 2000的方言

Microsoft SQL Server 2005

org.hibernate.dialect.SQLServer2005Dialect

Microsoft SQL 2005的方言。

Microsoft SQL Server 2008年

org.hibernate.dialect.SQLServer2008Dialect

带有JDBC Driver 3.0及更高版本的Microsoft SQL Server 2008的方言

Microsoft SQL Server 2012

org.hibernate.dialect.SQLServer2012Dialect

Microsoft SQL Server 2012方言

的MySQL

org.hibernate.dialect.MySQLDialect

MySQL的SQL方言(低于5.x)。

带有InnoDB的MySQL

org.hibernate.dialect.MySQLInnoDBDialect

弃用使用“ hibernate.dialect.storage_engine = innodb”环境变量或JVM系统属性。

MySQL与MyISAM

org.hibernate.dialect.MySQLMyISAMDialect

不建议使用“ hibernate.dialect.storage_engine = myisam”环境变量或JVM系统属性。

MySQL5的

org.hibernate.dialect.MySQL5Dialect

用于MySQL 5.x特定功能的SQL方言。

带有InnoDB的MySQL5

org.hibernate.dialect.MySQL5InnoDBDialect

弃用使用“ hibernate.dialect.storage_engine = innodb”环境变量或JVM系统属性。

MySQL8方言

org.hibernate.dialect.MySQL8Dialect

MySQL 8.x特定功能的SQL方言。

甲骨文8i

org.hibernate.dialect.Oracle8iDialect

Oracle 8i的方言。

甲骨文9i

org.hibernate.dialect.Oracle9iDialect

Oracle 9i数据库的方言。

Oracle 10g及更高版本

org.hibernate.dialect.Oracle10gDialect

专用于Oracle 10g的方言。

甲骨文12cDialect

org.hibernate.dialect.Oracle12cDialect

Oracle 12c的SQL方言。

OracleTypesHelper

org.hibernate.dialect.OracleTypesHelper

用于处理OracleTypes类的助手

PostgreSQL 8.1

org.hibernate.dialect.PostgreSQL81Dialect

Postgres的SQL方言

PostgreSQL 8.2

org.hibernate.dialect.PostgreSQL82Dialect

用于Postgres 8.2和更高版本的SQL方言,在删除表时增加了对“如果存在”的支持

PostgreSQL 9及更高版本

org.hibernate.dialect.PostgreSQL9Dialect

Postgres 9及更高版本的SQL方言。

PostgreSQL91语言

org.hibernate.dialect.PostgreSQL91Dialect

用于Postgres 9.1和更高版本的SQL方言添加了对PARTITION BY的支持,作为关键字。

PostgreSQL92方言

org.hibernate.dialect.PostgreSQL92Dialect

Postgres 9.2及更高版本的SQL方言增加了对JSON数据类型的支持

PostgreSQL93方言

org.hibernate.dialect.PostgreSQL93Dialect

PostgreSQL 9.3及更高版本的SQL方言。

PostgreSQL94方言

org.hibernate.dialect.PostgreSQL94Dialect

Postgres 9.4及更高版本的SQL方言。

PostgreSQL95方言

org.hibernate.dialect.PostgreSQL95Dialect

Postgres 9.5及更高版本的SQL方言。

PostgreSQL方言

org.hibernate.dialect.PostgreSQLDialect

不推荐使用使用 PostgreSQL82Dialect 替代

PostgresPlus方言

org.hibernate.dialect.PostgrePlusDialect

Postgres Plus的SQL方言

SAP数据库

org.hibernate.dialect.SAPDBDialect

与SAP DB兼容的SQL方言。

SAP HANA(列存储)

org.hibernate.dialect.HANAColumnStoreDialect

SAP HANA列存储的SQL方言。

SAP HANA(行存储)

org.hibernate.dialect.HANARowStoreDialect

SAP HANA行存储的SQL方言。

Sybase公司

org.hibernate.dialect.SybaseDialect

所有Sybase方言共享一个IN列表大小限制。

Sybase 11

org.hibernate.dialect.Sybase11Dialect

适用于Sybase 11.9.2的SQL方言(特别是:避免使用ANSI JOIN语法)

Sybase ASE 15.5

org.hibernate.dialect.SybaseASE15Dialect

针对Sybase Adaptive Server Enterprise(ASE)15及更高版本的SQL方言。

Sybase ASE 15.7

org.hibernate.dialect.SybaseASE157Dialect

针对Sybase Adaptive Server Enterprise(ASE)15.7和更高版本的SQL方言。

Sybase Anywhere

org.hibernate.dialect.SybaseAnywhereDialect

用于Sybase Anywhere的SQL方言扩展了Sybase(企业)方言(在ASA 8.x上测试)

Teradata14方言

org.hibernate.dialect.Teradata14Dialect

Teradata数据库的方言

Teradata

org.hibernate.dialect.TeradataDialect

MCR在方言认证过程中为Teradata数据库创建的方言。

5.结论

在本指南中,我们介绍了什么是方言以及为什么要在“Hibernate”“流行的Hibernate方言列表”中使用它。

参考文献

  1. 方言类hibernatedoc
  2. Hibernate用户手册
  3. MariaDB JbossDoc
  4. JPA MySQL示例

 

原文地址:https://blog.csdn.net/allway2

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


学习编程是顺着互联网的发展潮流,是一件好事。新手如何学习编程?其实不难,不过在学习编程之前你得先了解你的目的是什么?这个很重要,因为目的决定你的发展方向、决定你的发展速度。
IT行业是什么工作做什么?IT行业的工作有:产品策划类、页面设计类、前端与移动、开发与测试、营销推广类、数据运营类、运营维护类、游戏相关类等,根据不同的分类下面有细分了不同的岗位。
女生学Java好就业吗?女生适合学Java编程吗?目前有不少女生学习Java开发,但要结合自身的情况,先了解自己适不适合去学习Java,不要盲目的选择不适合自己的Java培训班进行学习。只要肯下功夫钻研,多看、多想、多练
Can’t connect to local MySQL server through socket \'/var/lib/mysql/mysql.sock问题 1.进入mysql路径
oracle基本命令 一、登录操作 1.管理员登录 # 管理员登录 sqlplus / as sysdba 2.普通用户登录
一、背景 因为项目中需要通北京网络,所以需要连vpn,但是服务器有时候会断掉,所以写个shell脚本每五分钟去判断是否连接,于是就有下面的shell脚本。
BETWEEN 操作符选取介于两个值之间的数据范围内的值。这些值可以是数值、文本或者日期。
假如你已经使用过苹果开发者中心上架app,你肯定知道在苹果开发者中心的web界面,无法直接提交ipa文件,而是需要使用第三方工具,将ipa文件上传到构建版本,开...
下面的 SQL 语句指定了两个别名,一个是 name 列的别名,一个是 country 列的别名。**提示:**如果列名称包含空格,要求使用双引号或方括号:
在使用H5混合开发的app打包后,需要将ipa文件上传到appstore进行发布,就需要去苹果开发者中心进行发布。​
+----+--------------+---------------------------+-------+---------+
数组的声明并不是声明一个个单独的变量,比如 number0、number1、...、number99,而是声明一个数组变量,比如 numbers,然后使用 nu...
第一步:到appuploader官网下载辅助工具和iCloud驱动,使用前面创建的AppID登录。
如需删除表中的列,请使用下面的语法(请注意,某些数据库系统不允许这种在数据库表中删除列的方式):
前不久在制作win11pe,制作了一版,1.26GB,太大了,不满意,想再裁剪下,发现这次dism mount正常,commit或discard巨慢,以前都很快...
赛门铁克各个版本概览:https://knowledge.broadcom.com/external/article?legacyId=tech163829
实测Python 3.6.6用pip 21.3.1,再高就报错了,Python 3.10.7用pip 22.3.1是可以的
Broadcom Corporation (博通公司,股票代号AVGO)是全球领先的有线和无线通信半导体公司。其产品实现向家庭、 办公室和移动环境以及在这些环境...
发现个问题,server2016上安装了c4d这些版本,低版本的正常显示窗格,但红色圈出的高版本c4d打开后不显示窗格,
TAT:https://cloud.tencent.com/document/product/1340