转帖:http://blog.csdn.net/myfmyfmyfmyf/article/details/45503919
在编写hql语句时,如果使用自定义的函数,hql在编译过程中将无法编译通过,这时我们需要重写下dialect方言类,这里我的oracle是10,可以根据自己的oracle版本继承不同的oracle方言类。
解决错误的步骤:
一、重写dialect类,如Oracle10gDialect
二、修改hibernate的配置文件,将默认的方言类,改成我们重写的方言类
---------------数据库函数WX_F_GET_PARTYSTR 输入number输出varchar2------------
CREATE OR REPLACE FUNCTION WX_F_GET_PARTYSTR(V_DEPT_ID NUMBER --人员信息中包含的部门ID) RETURN VARCHAR2 AS
T_UP_DEPT NUMBER(10);--上级部门ID,临时参数
T_DEPT_TEMP VARCHAR2(2000);--部门名称
T_DEPT_STR VARCHAR2(2000);--要返回的已拼接部门名称字符串
BEGIN
//省略
END WX_F_GET_PARTYSTR;
--------------------------------一、重写方言类,函数名用小写 ---------------------------------------------------------
- import org.hibernate.dialect.Oracle10gDialect;
- import org.hibernate.dialect.function.SQLFunctionTemplate;
- import org.hibernate.type.StringType;
- public class MyDialect extends Oracle10gDialect{
- public MyDialect(){
- super();
- //函数名必须是小写,试验大写出错
- //SQLFunctionTemplate函数第一个参数是函数的输出类型,varchar2对应new StringType() number对应new IntegerType()
- //?1代表第一个参数,?2代表第二个参数 这是数据库wx_f_get_partystr函数只需要一个参数,所以写成wx_f_get_partystr(?1)
- this.registerFunction("wx_f_get_partystr", new SQLFunctionTemplate(new StringType(), "wx_f_get_partystr(?1)"));
- }
- }
------------------------二、修改hibernate配置文件,修改完成后重启服务---------------------------------------------
将原来的hibernate.dialect由原来的hibernate默认默认的,改成我们重写的方言类
"wx_f_get_partystr(a.department), " +
"a.position, a.mobile,a.email,a.weixinId,a.avatar,a.status) " +
"from WxContacts a where a.userId in("+userId_str+") order by substr(a.userName,0,1)";
相关推荐
本文将深入探讨如何在Hibernate中调用Oracle的函数,以实现高效的数据操作。 首先,我们需要理解Hibernate的核心理念,它允许开发者通过面向对象的方式来处理数据库操作,而无需编写大量的SQL语句。Hibernate通过...
### NHibernate HQL 可用函数详解 #### 一、查询基本语法与示例 **1. 基本查询** - **语法**: `FROM <类名> [WHERE <条件>]` - **示例**: `FROM Category c WHERE c.name > 'c5'` **2. 排序查询** - **语法**: `...
在WebLogic 12环境中部署应用程序时,如果应用依赖于特定版本的Hibernate框架,并且该版本与WebLogic服务器默认提供的Hibernate版本存在差异,则可能会导致`org.hibernate.hql.ast.HqlToken`类冲突。此类冲突主要...
hibernate-HQL语句大全
在Hibernate中,通过Session对象的createQuery或createSQLQuery方法创建HQL查询,然后调用list、uniqueResult、scroll等方法执行查询。执行过程中,Hibernate会自动进行类型转换和结果集的封装,极大地降低了开发...
对hibernate的hql进行了详尽的讲解
Hibernate(HQL、QBC查询)源码 Hibernate(HQL、QBC查询)源码 Hibernate(HQL、QBC查询)源码 Hibernate(HQL、QBC查询)源码 Hibernate(HQL、QBC查询)源码
在Hibernate中,调用存储过程通常通过Session对象的createNativeQuery()方法实现,这个方法用于创建原生SQL查询,可以方便地调用数据库的自定义SQL或者存储过程。以下是一个简单的示例,展示了如何调用一个不带参数...
《Hibernate HQL查询语法详解》 Hibernate,作为Java领域中广泛应用的对象关系映射(ORM)框架,极大地简化了数据库操作。其内置的HQL(Hibernate Query Language)是一种面向对象的查询语言,它允许开发者以类和...
### Hibernate中HQL语句查询学习笔记 #### HQL基础 **HQL**(Hibernate Query Language)是Hibernate框架推荐使用的查询语言,它提供了一种面向对象的方式来查询数据库,支持多种复杂的查询操作,如继承、多态及...
Hibernate查询之HQL是ORM(对象关系映射)框架Hibernate中的一个重要组成部分,它是一种面向对象的查询语言,与SQL有着显著的区别。HQL允许开发者使用类名和属性而不是表名和列名进行查询,从而更好地适应面向对象的...
"Hibernate-HQL语句多对多写法" Hibernate 是一个流行的 Java 持久层框架,它提供了强大的对象关系映射(ORM)功能,使得开发者可以方便地与数据库交互。但是,在使用 Hibernate 时,我们经常会遇到多对多关系的...
对Hibernate中HQL语句的讲解
【描述】:在ORM框架Hibernate中,数据查询和检索是一个核心功能,它提供了多种查询方式,包括标准化对象查询(Criteria Query)、Hibernate查询语言(HQL)和原生SQL查询。其中,HQL作为官方推荐的查询方式,具有...
hql开窗函数.sql
在Hibernate中,HQL(Hibernate Query Language)是其内置的一种面向对象的查询语言,它是SQL的面向对象版本,用于检索和操作持久化对象。HQL查询的使用极大地提高了开发效率,因为它将数据操作与具体的数据库结构...
Hibernate 查询语言 HQL Hibernate 查询语言 HQL 是一种面向对象的查询语言,用于检索对象。它提供了灵活多样的查询机制,包括导航对象图、通过标识符检索、使用 HQL 检索对象、使用 Hibernate 条件 API 和使用本地...
HQL能够处理复杂的对象关系,如继承、多态和关联,使得在进行SSH(Spring、Struts、Hibernate)开发时能更高效地调用和操作数据。 1. **大小写敏感性**:HQL对Java类和属性名称是大小写敏感的,但关键字和别名在...
标题和描述中提到的"邮箱(hibernate+Servlet+自定义标签,内带hibernate配置,自定义标签分页)"是一个基于Java技术栈的Web应用项目,它利用Hibernate作为持久层框架,Servlet作为控制层,以及自定义标签来实现前端展示...
《深入理解Hibernate HQL:Java数据库交互利器》 Hibernate,作为一款强大的对象关系映射(ORM)框架,极大地简化了Java开发者与数据库之间的交互。其中,Hibernate查询语言(HQL)是其核心特性之一,它为开发者...