* Hibernate, Relational Persistence for Idiomatic Java * * Copyright (c) 2007-2011, Red Hat Inc. or third-party contributors as * indicated by the @author tags or express copyright attribution * statements applied by the authors. All third-party contributions are * distributed under license by Red Hat Inc. * * This copyrighted material is made available to anyone wishing to use, modify, * copy, or redistribute it subject to the terms and conditions of the GNU * Lesser General Public License, as published by the Free Software Foundation. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY * or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License * for more details. * * You should have received a copy of the GNU Lesser General Public License * along with this distribution; if not, write to: * Free Software Foundation, Inc. * 51 Franklin Street, Fifth Floor * Boston, MA 02110-1301 USA */ package org.hibernate.test.jdbc; import java.sql.Connection; import java.sql.ResultSet; import java.sql.SQLException; import java.sql.Statement; import org.hibernate.JDBCException; import org.hibernate.Session; import org.hibernate.jdbc.ReturningWork; import org.hibernate.jdbc.Work; import org.junit.Test; import org.hibernate.testing.junit4.BaseCoreFunctionalTestCase; import static org.junit.Assert.assertEquals; import static org.junit.Assert.fail; /** * GeneralWorkTest implementation * * @author Steve Ebersole */ public class GeneralWorkTest extends BaseCoreFunctionalTestCase { @Override public String getBaseForMappings() { return "org/hibernate/test/jdbc/"; } @Override public String[] getMappings() { return new String[] { "Mappings.hbm.xml" }; } @Test public void testGeneralUsage() throws Throwable { Session session = openSession(); session.beginTransaction(); session.doWork( new Work() { public void execute(Connection connection) throws SQLException { // in this current form, users must handle try/catches themselves for proper resource release Statement statement = null; try { statement = connection.createStatement(); ResultSet resultSet = null; try { resultSet = statement.executeQuery( "select * from T_JDBC_PERSON" ); } finally { releaseQuietly( resultSet ); } try { resultSet = statement.executeQuery( "select * from T_JDBC_BOAT" ); } finally { releaseQuietly( resultSet ); } } finally { releaseQuietly( statement ); } } } ); session.getTransaction().commit(); session.close(); } @Test public void testSQLExceptionThrowing() { Session session = openSession(); session.beginTransaction(); try { session.doWork( new Work() { public void execute(Connection connection) throws SQLException { Statement statement = null; try { statement = connection.createStatement(); statement.executeQuery( "select * from non_existent" ); } finally { releaseQuietly( statement ); } } } ); fail( "expecting exception" ); } catch ( JDBCException expected ) { // expected outcome } session.getTransaction().commit(); session.close(); } @Test public void testGeneralReturningUsage() throws Throwable { Session session = openSession(); session.beginTransaction(); Person p = new Person( "Abe", "Lincoln" ); session.save( p ); session.getTransaction().commit(); session = openSession(); session.beginTransaction(); long count = session.doReturningWork( new ReturningWork<Long>() { public Long execute(Connection connection) throws SQLException { // in this current form, users must handle try/catches themselves for proper resource release Statement statement = null; long personCount = 0; try { statement = connection.createStatement(); ResultSet resultSet = null; try { resultSet = statement.executeQuery( "select count(*) from T_JDBC_PERSON" ); resultSet.next(); personCount = resultSet.getLong( 1 ); assertEquals( 1L, personCount ); } finally { releaseQuietly( resultSet ); } } finally { releaseQuietly( statement ); } return personCount; } } ); session.getTransaction().commit(); session.close(); assertEquals( 1L, count ); session = openSession(); session.beginTransaction(); session.delete( p ); session.getTransaction().commit(); session.close(); } private void releaseQuietly(Statement statement) { if ( statement == null ) { return; } try { statement.close(); } catch ( SQLException e ) { // ignore } } private void releaseQuietly(ResultSet resultSet) { if ( resultSet == null ) { return; } try { resultSet.close(); } catch ( SQLException e ) { // ignore } } }
很牛x的网站
相关推荐
hibernate调用存储过程 hibernate调用存储过程 hibernate调用存储过程 hibernate调用存储过程 hibernate调用存储过程 hibernate调用存储过程 hibernate调用存储过程
在Hibernate中,调用存储过程通常通过Session对象的createNativeQuery()方法实现,这个方法用于创建原生SQL查询,可以方便地调用数据库的自定义SQL或者存储过程。以下是一个简单的示例,展示了如何调用一个不带参数...
总结来说,Hibernate调用存储过程是通过`StoredProcedureQuery`对象实现的,提供了更简便的对象化API。对比JDBC,Hibernate更注重开发者体验,而JDBC则更适合对数据库操作有深度控制的需求。在实际开发中,根据项目...
本文将深入探讨如何使用Hibernate调用存储过程,并结合提供的资源文件——`proc.sql`、`hibernateProc.sql`和`hibernateProc.java`,来阐述具体的操作步骤和注意事项。 首先,我们理解存储过程的意义。存储过程可以...
hibernate本对数据库的操作有些不完美,有必要的时候可以调用存储过程来补足。
在Java的持久化框架Hibernate中,调用数据库的存储过程是一项常见的需求。本文将深入探讨在Hibernate3中如何实现这一功能,以及相关的知识点。 一、为什么要使用存储过程 存储过程是预编译的SQL语句集合,它们在...
结合Spring和Hibernate,你可以在Spring的Service层使用Hibernate的Session来调用存储过程,或者在Repository层通过JdbcTemplate或NamedParameterJdbcTemplate进行调用。具体选择哪种方式取决于你的项目结构和需求。...
在Hibernate中调用这个存储过程,我们需要创建一个事务,获取数据库连接,然后通过CallableStatement对象执行存储过程: ```java Transaction tx = session.beginTransaction(); Connection con = session....
在hibernate中调用oracle中的存储过程的详细代码。可以借鉴使用,帮助学习。
### Hibernate调用存储过程详解 #### 一、建立存储过程 在进行Hibernate调用存储过程之前,首先需要在数据库中创建存储过程。本例中创建了一个名为`getUserInfo`的简单存储过程,其功能是从`user`表中选择所有记录...
- 使用Hibernate调用存储过程可以保持代码的统一性,但也可能导致封装性降低,因为存储过程的逻辑不再完全在Java代码中。 - 在处理大量数据或性能敏感的场景下,使用存储过程可能带来性能提升。 综上所述,...
本文将深入探讨如何搭建Hibernate环境并进行存储过程的调用。 首先,让我们了解什么是Hibernate。Hibernate是一个开源的ORM框架,它允许Java开发者将Java类与数据库表进行映射,通过对象的方式来操作数据库。它提供...
#### 三、Hibernate调用存储过程的方法 在Hibernate中调用存储过程通常有两种方式:通过`Query`接口或使用`StoredProcedureQuery`。这里我们主要介绍使用`StoredProcedureQuery`的方式,因为这种方式更适合处理复杂...
标题“hibernate调存储过程的方法”明确指出了本文档将介绍如何使用Hibernate框架来调用存储过程。文档中提到了调用IN和OUT参数的两种方法。 #### 描述解析 描述部分进一步明确了文档的主要内容:该文档将介绍具体...
总之,Hibernate不仅支持简单的ORM操作,还提供了调用存储过程和定义命名SQL查询的能力,使得开发者可以灵活地处理各种数据库交互需求,提高代码的灵活性和可维护性。在实际开发中,理解并熟练掌握这些特性,将有助...
总结来说,这篇文章深入浅出地介绍了如何在Hibernate 3.x中使用存储过程,涵盖了创建存储过程、在Java代码中调用存储过程的关键步骤,为开发者提供了清晰的实践指导。这对于那些希望在Java应用中充分利用数据库功能...