博客
关于我
Spring(十三)之SQL存储过程
阅读量:469 次
发布时间:2019-03-06

本文共 5393 字,大约阅读时间需要 17 分钟。

基于Spring JDBC框架与SimpleJdbcCall调用带有IN和OUT参数的存储过程

本文将通过一个完整的示例,展示如何利用Spring JDBC框架和SimpleJdbcCall类来调用带有IN和OUT参数的存储程序。该示例将涵盖从存储程序的创建到实际应用程序的集成,适用于MySQL、Oracle等多种数据库。

1. 创建存储程序

首先,我们需要为Student表创建一个存储程序getRecord,该存储程序接受一个IN参数和返回两个OUT参数。

DELIMITER $$CREATE PROCEDURE `test`.`getRecord` (IN in_id INTEGER, OUT out_name VARCHAR(20), OUT out_age INTEGER)BEGIN    SELECT NAME, age INTO out_name, out_age FROM Student WHERE id = in_id;END$$DELIMITER ;

2. 定义实体类

创建一个Student实体类来表示数据库中的学生记录。

package com.tutorialspoint;public class Student {    private Integer age;    private String name;    private Integer id;    public void setAge(Integer age) {        this.age = age;    }    public Integer getAge() {        return age;    }    public void setName(String name) {        this.name = name;    }    public String getName() {        return name;    }    public void setId(Integer id) {        this.id = id;    }    public Integer getId() {        return id;    }}

3. 实现StudentDAO接口

StudentDAO接口定义了与学生数据相关的数据库操作方法。

package com.tutorialspoint;import java.util.List;import javax.sql.DataSource;public interface StudentDAO {    void setDataSource(DataSource ds);    void create(String name, Integer age);    Student getStudent(Integer id);    List
listStudents();}

4. 实现StudentMapper

StudentMapper用于将数据库结果映射到Student对象。

package com.tutorialspoint;import java.sql.ResultSet;import java.sql.SQLException;import org.springframework.jdbc.core.RowMapper;public class StudentMapper implements RowMapper {    public Student mapRow(ResultSet rs, int rowNum) throws SQLException {        Student student = new Student();        student.setId(rs.getInt("id"));        student.setName(rs.getString("name"));        student.setAge(rs.getInt("age"));        return student;    }}

5. 实现StudentJDBCTemplate

StudentJDBCTemplate实现了StudentDAO接口,负责执行具体的数据库操作。

package com.tutorialspoint;import java.util.List;import java.util.Map;import javax.sql.DataSource;import org.springframework.jdbc.core.JdbcTemplate;import org.springframework.jdbc.core.namedparam.MapSqlParameterSource;import org.springframework.jdbc.core.namedparam.SqlParameterSource;import org.springframework.jdbc.core.simple.SimpleJdbcCall;public class StudentJDBCTemplate implements StudentDAO {    private DataSource dataSource;    private SimpleJdbcCall jdbcCall;    public void setDataSource(DataSource dataSource) {        this.dataSource = dataSource;        this.jdbcCall = new SimpleJdbcCall(dataSource).withProcedureName("getRecord");    }    public void create(String name, Integer age) {        JdbcTemplate jdbcTemplate = new JdbcTemplate(dataSource);        String SQL = "insert into Student (name, age) values (?, ?)";        jdbcTemplate.update(SQL, name, age);        System.out.println("Created Record Name = " + name + " Age = " + age);    }    public Student getStudent(Integer id) {        Map
in = new MapSqlParameterSource().addValue("in_id", id); Map
out = jdbcCall.execute(in); Student student = new Student(); student.setId(id); student.setName((String) out.get("out_name")); student.setAge((Integer) out.get("out_age")); return student; } public List
listStudents() { JdbcTemplate jdbcTemplate = new JdbcTemplate(dataSource); String SQL = "select * from Student"; List
students = jdbcTemplate.query(SQL, new StudentMapper()); return students; }}

6. 主应用程序MainApp

MainApp类用于演示如何使用StudentJDBCTemplate进行数据库操作。

package com.tutorialspoint;import java.util.List;import org.springframework.context.ApplicationContext;import org.springframework.context.support.ClassPathXmlApplicationContext;import com.tutorialspoint.StudentJDBCTemplate;public class MainApp {    public static void main(String[] args) {        ApplicationContext context = new ClassPathXmlApplicationContext("Beans.xml");        StudentJDBCTemplate studentJDBCTemplate = (StudentJDBCTemplate) context.getBean("studentJDBCTemplate");                System.out.println("------创建记录--------" );        studentJDBCTemplate.create("Zara", 11);        studentJDBCTemplate.create("Nuha", 2);        studentJDBCTemplate.create("Ayan", 15);                System.out.println("------列出多个记录--------" );        List
students = studentJDBCTemplate.listStudents(); for (Student record : students) { System.out.print("ID : " + record.getId()); System.out.print(", 姓名 : " + record.getName()); System.out.println(", 年龄 : " + record.getAge()); } System.out.println("----列出ID=2的记录----" ); Student student = studentJDBCTemplate.getStudent(2); System.out.print("ID : " + student.getId()); System.out.print(", 姓名 : " + student.getName()); System.out.println(", 年龄 : " + student.getAge()); }}

7. 配置文件Beans.xml

Spring配置文件,定义数据源和StudentJDBCTemplate bean。

8. 运行主应用程序

运行MainApp.java主方法,查看输出结果。

------创建记录--------Created Record Name = Zara, Age = 11Created Record Name = Nuha, Age = 2Created Record Name = Ayan, Age = 15------列出多个记录--------ID : 1, 姓名 : Zara, 年龄 : 11ID : 2, 姓名 : Nuha, 年龄 : 2ID : 3, 姓名 : Ayan, 年龄 : 15----列出ID=2的记录----ID : 2, 姓名 : Nuha, 年龄 : 2

通过上述步骤,可以看到如何通过Spring JDBC框架和SimpleJdbcCall类来调用带有IN和OUT参数的存储程序,并实现与数据库的交互。

转载地址:http://moobz.baihongyu.com/

你可能感兴趣的文章
tableviewcell 中使用autolayout自适应高度
查看>>
Symbolic Aggregate approXimation(SAX,符号聚合近似)介绍-ChatGPT4o作答
查看>>
Orcale表被锁
查看>>
svn访问报错500
查看>>
sum(a.YYSR) over (partition by a.hy_dm) 不需要像group by那样需要分组函数。方便。
查看>>
ORCHARD 是什么?
查看>>
Struts2中使用Session的两种方法
查看>>
Stream API:filter、map和flatMap 的用法
查看>>
STM32工作笔记0032---编写跑马灯实验---寄存器版本
查看>>
Static--用法介绍
查看>>
ssm旅游信息管理系统的设计与实现bus56(程序+开题)
查看>>
order by rand()
查看>>
SSM(Spring+SpringMvc+Mybatis)整合开发笔记
查看>>
ViewHolder的改进写法
查看>>
Orderer节点启动报错解决方案:Not bootstrapping because of 3 existing channels
查看>>
org.apache.axis2.AxisFault: org.apache.axis2.databinding.ADBException: Unexpected subelement profile
查看>>
sql查询中 查询字段数据类型 int 与 String 出现问题
查看>>
org.apache.commons.beanutils.BasicDynaBean cannot be cast to ...
查看>>
org.apache.dubbo.common.serialize.SerializationException: com.alibaba.fastjson2.JSONException: not s
查看>>
sqlserver学习笔记(三)—— 为数据库添加新的用户
查看>>