文章目录

  • 前言
  • 一、举例说明
  • 二、主要代码如下

前言

之前使用过mybatis和mybatis plus来调用数据库函数和存储过程,这也是目前使用比较广泛和流行的方法,但是今天遇到一个要求就是在一个项目中添加函数调用的功能,这个项目不是使用的mybatis,而是JPA,所以想找一下如何使用JPA调用函数的方法,但是好像没有特别好的方法(可能是我没找到)。
后来找到一篇英文解答,使用的是JDBC,然后我试了一下是可以实现功能的,写篇文章记录一下。


一、举例说明

比如我们有这个表,现在测试用函数从这个表中查出我们想要的数据
±-------±-----------±---------------+
| Name | DOB | Location |
±-------±-----------±---------------+
| Amit | 1989-09-26 | Hyderabad |
| Sumith | 1989-09-01 | Vishakhapatnam |
| Sudha | 1980-09-01 | Vijayawada |
±-------±-----------±---------------+

函数如下:
CREATE FUNCTION getDob(emp_name VARCHAR(50)) RETURNS DATE
BEGIN
declare dateOfBirth DATE;
select DOB into dateOfBirth from EMP where Name = emp_name;
return dateOfBirth;
END

二、主要代码如下

import java.sql.CallableStatement;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
import java.sql.Types;
public class CallingFunctionsExample {public static void main(String args[]) throws SQLException {//Registering the DriverDriverManager.registerDriver(new com.mysql.jdbc.Driver());//Getting the connection//tableName替换为自己的数据库的名字String mysqlUrl = "jdbc:mysql://localhost/tableName";//root替换为自己的数据库的账号名字,12345678为密码Connection con = DriverManager.getConnection(mysqlUrl, "root", "12345678");System.out.println("Connection established......");//Preparing a CallableStatement to call a function//function为所要调用的函数的名字//(?)表示输入参数CallableStatement cstmt = con.prepareCall("{? = call getDob(?)}");//Registering the out parameter of the function (return type)/Types.DATE表示输出参数的类型cstmt.registerOutParameter(1, Types.DATE);//Setting the input parameters of the function//Amit表示输入参数cstmt.setString(2, "Amit");//Executing the statementcstmt.execute();//打印出输出的值System.out.print("Date of birth: "+cstmt.getDate(1));}
}

最后输出:
Connection established…
Date of birth: 1989-09-26

Java使用JDBC调用Mysql函数和存储过程相关推荐

  1. pb 调用mysql过程_pb调用mysql函数或存储过程异常

    pb调用mysql函数或存储过程异常.尤其是mysql函数带传入传出参数时,pb调用时候无法正常执行,提示SQLSTATE=37000错误. 在pb程序中正常更新mysql表中字段或读取mysql表中 ...

  2. jaba窗体连接mysql增删改查_知识实现——Java使用jdbc连接MySql数据库,实现增删改查...

    Java使用jdbc连接MySql数据库,实现增删改查 首先,导入MySql连接数据库的jar包,我用的是 mysql连接jar包 DB类,用于获得数据库连接 import java.sql.Driv ...

  3. C mysql带参数存储过程_C# 调用Mysql 带参数存储过程

    使用C#调用Mysql 带参数的存储过程: 1.创建带参数的存储过程:USP_Temp_Test 2.两个参数:IN 参数为 P_XML , OUT 参数为 P_ErrorOut 3.C#代码调用该存 ...

  4. Java使用Jdbc操作MySql数据库(一)

    这个示例是Java操作MySql的基本方法. 在这个示例之前,要安装好MySql,并且配置好账户密码,创建一个logininfo数据库,在数据库中创建userinfo数据表.并且在表中添加示例数据. ...

  5. ibatis调用mysql函数

    调用mysql函数 <select id="F_DELETEObj" resultClass="java.lang.Integer" parameterC ...

  6. java使用jdbc调用hive出现The query did not generate a result set!

    2019独角兽企业重金招聘Python工程师标准>>> java使用jdbc调用hive出现The query did not generate a result set! 博客分类 ...

  7. 本地方法(JNI)——从java 程序中调用C函数

    [0]README 1) 本文部分文字描述 转自 core java volume 2 , 旨在理解 本地方法--从java 程序中调用C函数 的基础知识 : 2) for source code, ...

  8. java通过jdbc访问mysql,update数据返回值的思考

    java通过jdbc访问mysql,update数据返回值的思考 先不说那么多,把Java代码贴出来吧. public static void main(String[] args) throws I ...

  9. 一、JAVA通过JDBC连接mysql数据库(连接)

    JDBC ----JDBC(Java DataBase Connectivity)是Java与数据库的接口规范,JDBC定义了一个支持标准SQL功能的通用低层的应用程序编程接口(API),它由Java ...

最新文章

  1. DOM4J_Xpath的XML操作总结
  2. text-indent无效解决方案
  3. Computer Vision的尴尬
  4. Ubuntu 18.04下命令安装VMware Tools
  5. leetcode169. 多数元素
  6. SpringBoot —— Bean的注入方式
  7. python字典属于无序序列_Python序列结构--字典
  8. [bzoj4881][Lydsy2017年5月月赛]线段游戏
  9. 一些php+mysql的开源网上商城
  10. java.net.URISyntaxException: Illegal character in query at index,http请求url中有非法字符导致
  11. socket编程:SO_REUSEADDR例解
  12. 用jquery怎么删除table的一行
  13. 【训练计划】--2019-04
  14. 西门子1212c 通过高速脉冲输出控制台达B2伺服电机
  15. 三端线性稳压器工作原理与典型应用电路分析——78XX与LM317
  16. UI设计初学者教程:色彩基础知识
  17. Qt Creator启动慢的解决方法
  18. arcgis许可服务器不运行,ArcGIS许可服务管理器无法启动问题解决方法
  19. 面试官问我:什么是静态代理?什么是动态代理?注解、反射你会吗?
  20. Go语言核心之美 2.3-复数

热门文章

  1. 『解疑』flex布局 flex-wrap:wrap 自动换行属性,导致两行div中间有大空行。
  2. ERP系统-销售子系统-销售订单
  3. 浅析MOS管串联并联的驱动应用
  4. NLP 自然语言初体验
  5. Linux 各种top命令
  6. [架构之路-182]-《软考-系统分析师》-19- 系统可靠性分析与设计 - 概览
  7. ct值在哪里看_来,带你见识一下CT三维重建
  8. 小程序云开发实现微信支付,不需要搭建服务器
  9. 腾讯做互联网之水:从马化腾多元化遇挫说起
  10. flink的广播、累加、缓存