每日一课 | 如何在Hibernate中调用存储过程

2023-12-24 03:32

本文主要是介绍每日一课 | 如何在Hibernate中调用存储过程,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在本教程中,您将学习如何在Hibernate中调用存储过程。

MySQL存储过程

这是一个MySQL存储过程,该过程接受股票代码参数并返回相关的股票数据。

DELIMITER $$
CREATE PROCEDURE `GetStocks`(int_stockcode varchar(20))
BEGINSELECT * FROM stock where stock_code = int_stockcode;END $$
DELIMITER ;

在MySQL中,您可以使用call关键字简单地调用它:

CALL GetStocks('7277');

休眠调用存储过程

在Hibernate中,有三种方法可以调用数据库存储过程。

1.本机SQL – createSQLQuery

您可以使用createSQLQuery()直接调用存储过程。

Query query = session.createSQLQuery("CALL GetStocks(:stockCode)").addEntity(Stock.class).setParameter("stockCode", "7277");List result = query.list();
for(int i=0; i<result.size(); i++){Stock stock = (Stock)result.get(i);System.out.println(stock.getStockCode());
}

2.注解中的NamedNativeQuery

在@NamedNativeQueries批注中声明存储过程。

//Stock.java
...
@NamedNativeQueries({@NamedNativeQuery(name = "callStockStoreProcedure",query = "CALL GetStocks(:stockCode)",resultClass = Stock.class)
})
@Entity
@Table(name = "stock")
public class Stock implements java.io.Serializable {
...

用getNamedQuery()调用它。

Query query = session.getNamedQuery("callStockStoreProcedure").setParameter("stockCode", "7277");
List result = query.list();
for(int i=0; i<result.size(); i++){Stock stock = (Stock)result.get(i);System.out.println(stock.getStockCode());
}

3. XML映射文件中的sql-query

在“ sql-query ”标签中声明您的存储过程。

<!-- Stock.hbm.xml -->
...
<hibernate-mapping><class name="com.mkyong.common.Stock" table="stock" ...><id name="stockId" type="java.lang.Integer"><column name="STOCK_ID" /><generator class="identity" /></id><property name="stockCode" type="string"><column name="STOCK_CODE" length="10" not-null="true" unique="true" /></property>...</class>    <sql-query name="callStockStoreProcedure"><return alias="stock" class="com.mkyong.common.Stock"/><![CDATA[CALL GetStocks(:stockCode)]]></sql-query>
</hibernate-mapping>

用getNamedQuery()调用它。

Query query = session.getNamedQuery("callStockStoreProcedure").setParameter("stockCode", "7277");
List result = query.list();
for(int i=0; i<result.size(); i++){Stock stock = (Stock)result.get(i);System.out.println(stock.getStockCode());
}

结论

上面的三种方法做同样的事情,在数据库中调用存储过程。三种方法之间没有太大区别,您选择哪种方法取决于您的个人喜好。

翻译自: https://mkyong.com/hibernate/how-to-call-store-procedure-in-hibernate/

推荐阅读--

当一个程序员飞速敲键盘时,他在干嘛?

卧槽!最新编程语言排名,Java 沦为老二。。

为何程序员上班时间总戴个耳机,看完恍然大悟...

每日一课 | 如何将Java对象读取和写入文件

每日一课 | Java Final关键字示例

球分享

球点赞

球在看

这篇关于每日一课 | 如何在Hibernate中调用存储过程的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/530421

相关文章

浅析Spring Security认证过程

类图 为了方便理解Spring Security认证流程,特意画了如下的类图,包含相关的核心认证类 概述 核心验证器 AuthenticationManager 该对象提供了认证方法的入口,接收一个Authentiaton对象作为参数; public interface AuthenticationManager {Authentication authenticate(Authenti

异构存储(冷热数据分离)

异构存储主要解决不同的数据,存储在不同类型的硬盘中,达到最佳性能的问题。 异构存储Shell操作 (1)查看当前有哪些存储策略可以用 [lytfly@hadoop102 hadoop-3.1.4]$ hdfs storagepolicies -listPolicies (2)为指定路径(数据存储目录)设置指定的存储策略 hdfs storagepolicies -setStoragePo

HDFS—存储优化(纠删码)

纠删码原理 HDFS 默认情况下,一个文件有3个副本,这样提高了数据的可靠性,但也带来了2倍的冗余开销。 Hadoop3.x 引入了纠删码,采用计算的方式,可以节省约50%左右的存储空间。 此种方式节约了空间,但是会增加 cpu 的计算。 纠删码策略是给具体一个路径设置。所有往此路径下存储的文件,都会执行此策略。 默认只开启对 RS-6-3-1024k

作业提交过程之HDFSMapReduce

作业提交全过程详解 (1)作业提交 第1步:Client调用job.waitForCompletion方法,向整个集群提交MapReduce作业。 第2步:Client向RM申请一个作业id。 第3步:RM给Client返回该job资源的提交路径和作业id。 第4步:Client提交jar包、切片信息和配置文件到指定的资源提交路径。 第5步:Client提交完资源后,向RM申请运行MrAp

如何在页面调用utility bar并传递参数至lwc组件

1.在app的utility item中添加lwc组件: 2.调用utility bar api的方式有两种: 方法一,通过lwc调用: import {LightningElement,api ,wire } from 'lwc';import { publish, MessageContext } from 'lightning/messageService';import Ca

【机器学习】高斯过程的基本概念和应用领域以及在python中的实例

引言 高斯过程(Gaussian Process,简称GP)是一种概率模型,用于描述一组随机变量的联合概率分布,其中任何一个有限维度的子集都具有高斯分布 文章目录 引言一、高斯过程1.1 基本定义1.1.1 随机过程1.1.2 高斯分布 1.2 高斯过程的特性1.2.1 联合高斯性1.2.2 均值函数1.2.3 协方差函数(或核函数) 1.3 核函数1.4 高斯过程回归(Gauss

【每日一题】LeetCode 2181.合并零之间的节点(链表、模拟)

【每日一题】LeetCode 2181.合并零之间的节点(链表、模拟) 题目描述 给定一个链表,链表中的每个节点代表一个整数。链表中的整数由 0 分隔开,表示不同的区间。链表的开始和结束节点的值都为 0。任务是将每两个相邻的 0 之间的所有节点合并成一个节点,新节点的值为原区间内所有节点值的和。合并后,需要移除所有的 0,并返回修改后的链表头节点。 思路分析 初始化:创建一个虚拟头节点

速了解MySQL 数据库不同存储引擎

快速了解MySQL 数据库不同存储引擎 MySQL 提供了多种存储引擎,每种存储引擎都有其特定的特性和适用场景。了解这些存储引擎的特性,有助于在设计数据库时做出合理的选择。以下是 MySQL 中几种常用存储引擎的详细介绍。 1. InnoDB 特点: 事务支持:InnoDB 是一个支持 ACID(原子性、一致性、隔离性、持久性)事务的存储引擎。行级锁:使用行级锁来提高并发性,减少锁竞争

Solr 使用Facet分组过程中与分词的矛盾解决办法

对于一般查询而言  ,  分词和存储都是必要的  .  比如  CPU  类型  ”Intel  酷睿  2  双核  P7570”,  拆分成  ”Intel”,”  酷睿  ”,”P7570”  这样一些关键字并分别索引  ,  可能提供更好的搜索体验  .  但是如果将  CPU  作为 Facet  字段  ,  最好不进行分词  .  这样就造成了矛盾  ,  解决方法

【LabVIEW学习篇 - 21】:DLL与API的调用

文章目录 DLL与API调用DLLAPIDLL的调用 DLL与API调用 LabVIEW虽然已经足够强大,但不同的语言在不同领域都有着自己的优势,为了强强联合,LabVIEW提供了强大的外部程序接口能力,包括DLL、CIN(C语言接口)、ActiveX、.NET、MATLAB等等。通过DLL可以使用户很方便地调用C、C++、C#、VB等编程语言写的程序以及windows自带的大