Java使用JDBC调用Mysql函数和存储过程
文章目录
- 前言
- 一、举例说明
- 二、主要代码如下
前言
之前使用过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函数和存储过程相关推荐
- pb 调用mysql过程_pb调用mysql函数或存储过程异常
pb调用mysql函数或存储过程异常.尤其是mysql函数带传入传出参数时,pb调用时候无法正常执行,提示SQLSTATE=37000错误. 在pb程序中正常更新mysql表中字段或读取mysql表中 ...
- jaba窗体连接mysql增删改查_知识实现——Java使用jdbc连接MySql数据库,实现增删改查...
Java使用jdbc连接MySql数据库,实现增删改查 首先,导入MySql连接数据库的jar包,我用的是 mysql连接jar包 DB类,用于获得数据库连接 import java.sql.Driv ...
- C mysql带参数存储过程_C# 调用Mysql 带参数存储过程
使用C#调用Mysql 带参数的存储过程: 1.创建带参数的存储过程:USP_Temp_Test 2.两个参数:IN 参数为 P_XML , OUT 参数为 P_ErrorOut 3.C#代码调用该存 ...
- Java使用Jdbc操作MySql数据库(一)
这个示例是Java操作MySql的基本方法. 在这个示例之前,要安装好MySql,并且配置好账户密码,创建一个logininfo数据库,在数据库中创建userinfo数据表.并且在表中添加示例数据. ...
- ibatis调用mysql函数
调用mysql函数 <select id="F_DELETEObj" resultClass="java.lang.Integer" parameterC ...
- java使用jdbc调用hive出现The query did not generate a result set!
2019独角兽企业重金招聘Python工程师标准>>> java使用jdbc调用hive出现The query did not generate a result set! 博客分类 ...
- 本地方法(JNI)——从java 程序中调用C函数
[0]README 1) 本文部分文字描述 转自 core java volume 2 , 旨在理解 本地方法--从java 程序中调用C函数 的基础知识 : 2) for source code, ...
- java通过jdbc访问mysql,update数据返回值的思考
java通过jdbc访问mysql,update数据返回值的思考 先不说那么多,把Java代码贴出来吧. public static void main(String[] args) throws I ...
- 一、JAVA通过JDBC连接mysql数据库(连接)
JDBC ----JDBC(Java DataBase Connectivity)是Java与数据库的接口规范,JDBC定义了一个支持标准SQL功能的通用低层的应用程序编程接口(API),它由Java ...
最新文章
- DOM4J_Xpath的XML操作总结
- text-indent无效解决方案
- Computer Vision的尴尬
- Ubuntu 18.04下命令安装VMware Tools
- leetcode169. 多数元素
- SpringBoot —— Bean的注入方式
- python字典属于无序序列_Python序列结构--字典
- [bzoj4881][Lydsy2017年5月月赛]线段游戏
- 一些php+mysql的开源网上商城
- java.net.URISyntaxException: Illegal character in query at index,http请求url中有非法字符导致
- socket编程:SO_REUSEADDR例解
- 用jquery怎么删除table的一行
- 【训练计划】--2019-04
- 西门子1212c 通过高速脉冲输出控制台达B2伺服电机
- 三端线性稳压器工作原理与典型应用电路分析——78XX与LM317
- UI设计初学者教程:色彩基础知识
- Qt Creator启动慢的解决方法
- arcgis许可服务器不运行,ArcGIS许可服务管理器无法启动问题解决方法
- 面试官问我:什么是静态代理?什么是动态代理?注解、反射你会吗?
- Go语言核心之美 2.3-复数