声明:本栏目所使用的素材都是凯哥学堂VIP学员所写,学员有权匿名,对文章有最终解释权;凯哥学堂旨在促进VIP学员互相学习的基础上公开笔记。
Jdbc Java连接数据库连接调用存储过程。
什么是过程?过程与函数类似,拥有着带入值与带出值的参数,并且在过程中可以完成数据库代码的执行。这片代码存储与数据库,叫存储过程。是功能的封装,代码的封装调用。
Jdbc调用存储过程准备,获得连接对象:
Jdbc调用过程1、不带任何参数的存储过程:
数据库创建存储过程:
Delimiter //定界符,从//开始 到//结束
Procedure存储过程的名词,翻译是:程序
创建存储过程,过程名,begin end过程执行的代码
//结束,delimiter ;分号结束语句
Jdbc发起调用:
连接对象.prepareCall得到存储过程执行Statement对象 {call 过程名},call调用按过程名调用,外面使用{}括号包裹
返回值是使用out关键字表示带出值。但我们过程中执行select语句不使用out,不会带出值,但会有记录的出现。于是使用query捕获到输出的记录。得到result对象,取值。
Jdbc调用存储过程2、需带入参数:
创建存储过程:
Delimiter //描述定界符,//开始处与//结束处为执行代码的书写
Create创建procedure存储过程,过程名(in id int)。in表示这要入参,id是参数名,int参数类型
Begin与end之间代码的书写。我们这里拿到了入参,还可以做其他的事情,比如条件约束等。但这里仅是调试入参的传递
调用过程:
过程中没有out带出值,但里面有select查询,是记录集的返回,虽然不会返回在变量上,但我们可以捕获。executeQuery执行查询方式运行,得到记录集,取值。
Jdbc调用存储过程3、带入带出值调用:
创建存储过程:
定界符//,创建procedure过程。过程名(in a int,out b varchar(100))有入参,有出参
Begin与out代码书写。select查询address一个列数据。into交给带出参数。使用带入参数做条件判断。接收,语句结束。
调用过程:
得到过程执行Statement对象,call 名称(?,?)按名称调用。过程有2个参数。一个入一个出,使用?占位。到时填充数据。
setInt给第一个的带入的参数,按类型赋值。这是入参。第二个参数是出参,reginsterOutParamter表示这是出参,第二个问号是出带出值。
没有记录集的返回,execute执行,在得到第二个出参即可。
也可以在数据库本地发起调用:
Call调用过程,入参传值,@表示出参的接收,等同于引用。此时select @名。等于查询这个变量。这个变量没有丢失,能查询得到出参。
Jdbc调用存储过程,如果是入参?则由set去填充。如果是出参?则去存储过程调用对象注册这是出参,届时get去得到出参的值。
Jdbc调用出参过程,即有出参,又有记录集返回:
创建存储过程:
Delimiter定界符,create创建procedure过程(in a int,out b,varchar(100))有带入带出参数。
Begin与end之间,代码的属性。定界符结束,分号结束语句。
查询address一个列,into交给out带出的变量引用。使用in带入参数做条件约束。这一句中使用了带入与带出参数。紧接着又执行select语句。
现在在这个存储过程中,即有变量返回,又有记录的返回。
调用过程:
从连接对象,获得存储过程执行对象。{call 名(?,?)}call按过程名调用过程,(?,?)有2个参数,一个入一个出。
Set给第一个入参赋值,registerOutParamter登记第二个?是返回值,返回类型的varchar。
有记录集的返回使用executeQuery,获得Result记录集返回对象,取值。并使用存储过程执行对象.getString(2)得到存储过程身上的第二个?参数。也就是出值的参数
本地发起调用:
第一个?传入141为入参,做条件约束的。第二个参数使用变量去接收出参。查询到记录集,并出参带出来了。
事务:事务有什么用?
举个简单例子:用户消费100元购买商品,此时100元消费经过这么几个步骤。1:商品库存-1、2:用户金额扣除100元、3:增加订单、4:用户消费记录+1
在这几个步骤中,任何一个环节出现纰漏。比如库存已-1,但金额扣除失败。这个时候库存应该还原。如果这几个环节是独立开来执行,则任何一步写入到库还原就比较麻烦了。于是我们将这几个环节放入在事务范围内,这几个环节都在事务的管理范围内。
我们控制事务的提交与回滚,事务干什么?事务就可以这样使用。对逻辑进行管理。如果某一个环节出现误差,则可以进行事务控制,控制这个事务范围内的数据下一步走向。
事务又分自动事务与手动事务。自动事务是:一条SQL发送过去执行,如果出现问题则回滚,没有问题则提交。
而手动事务是,我们自己控制事务的提交与回滚。
自动事务不使用,因为自动事务是针对一条SQL,SQL发送过去要么提交要么回滚。而手动事务是一个环节,一个过程。在这个过程内,如果出现问题有我们决定。也就是手动事务不止是控制提交与回滚,重要的是,这个事务如何提交回滚可以由我们来控制。我们决定这个过程有多长。我们可以让事务贯穿管理整个逻辑。
Jdbc管理事务,开启手动事务:
得到连接对象
setAutoCommit设置自动提交为false,则是手动管理事务了。
在这个过程中执行的任何SQL,写入的数据。在当前连接对象关闭前都可以回滚与提交
在关闭连接对象时,如果没有指定回滚也没有要求提交,则默认回滚
举例:
执行此insert语句,得到SQL预处理执行对象,update执行,返回影响行数1
查询表格:
Uid_u为80的数据,并没有进去。是插入失败吗?数据确实进去了,不过被回滚了。因为我们没有提交与回滚,在关闭时就默认回滚了。
测试数据是否写下去了:
插入ID为70,报出key重复。说明什么?说明数据确实写下去了,才会有key重复。说明之前的80也是写下去了。但数据库没有数据说明什么?写下去在这个事务内又回滚了。
在connection关闭时,连接对象关闭。
当connection开启手动事务,在commit与rollback这个过程中,事务的范围将一直影响着执行逻辑范围。
当connection,commit与rollback后。这个事务的范围结束。但这个connection还可以使用。在上一个事务完成后,继续使用的过程中,又是新的事务范围。也就是事务结束,紧接着又是新的事务开始管理逻辑了。直到连接对象被关闭。
连接对象可以一直使用,在线程中连接对象是独立运行的。手动事务在connection事务提交与回滚,接着又是进入事务范围内了。手动事务由我们管理事务的贯穿逻辑范围。
相关推荐
【标题】"求精要诀——JavaEE编程开发案例精讲 源代码(8-12)"涉及的是JavaEE平台上的高级编程实践,主要涵盖第8至12章的关键知识点。JavaEE,全称Java Platform, Enterprise Edition,是Java语言在企业级应用开发...
这样的项目旨在让学生在实践中掌握Java编程语言以及相关的企业级开发技能,如Servlet、JSP、JDBC、MVC模式、Spring框架等。 首先,我们来探讨JavaEE技术栈。JavaEE,即Java企业版,是用于构建分布式、多层的企业级...
【JavaEE项目——手机销售公司】是一个基于JavaEE技术栈的Web应用程序,旨在模拟和管理一个手机销售公司的业务流程。这个项目涵盖了多个重要的IT知识点,包括但不限于以下几点: 1. **JavaEE架构**:JavaEE(Java ...
3. **JDBC与数据库交互**:在企业级应用中,数据存储和管理是必不可少的。JavaEE通过JDBC(Java Database Connectivity)提供了一种与各种数据库进行交互的标准接口。Day19可能涉及了连接数据库、执行SQL语句、处理...
在本文中,我们将深入探讨如何使用JavaEE与百度AI的...尽管页面设计可能简单,但核心功能——即准确、安全地通过面部识别验证用户身份——已经实现。随着技术的进步,这种无密码的登录方式可能会成为未来的一个趋势。
在本项目“Struts宿舍管理系统”中,我们主要探讨的是如何使用JavaEE的核心框架之一——Struts来实现一个针对学生和管理员的宿舍管理应用。 Struts是一个开源的MVC(Model-View-Controller)框架,它使得开发者能够...
描述中提到“基于JavaEE的职工薪资管理系统使用MyEclipse与MySQL”,这表明这个项目或教程是关于如何利用JavaEE技术来构建一个实际的管理应用——职工薪资管理系统。MyEclipse是一款集成开发环境(IDE),专门用于...
系统中可能包含了数据库设计,如参赛者信息、比赛项目、成绩等,这些数据的存储和查询都需要通过JDBC来实现。 3. **EJB(Enterprise JavaBeans)**:JavaEE的高级组件,包括会话bean(Session Beans)和实体bean...
3. **MyBatis**:MyBatis是一个优秀的持久层框架,它支持定制化SQL、存储过程以及高级映射。MyBatis避免了几乎所有的JDBC代码和手动设置参数以及获取结果集。MyBatis可以使用简单的XML或注解进行配置和原始映射,将...
《JavaEE大学生宿舍管理系统》是一款基于Java技术,利用JSP/Servlet、JDBC进行开发,以Oracle数据库为存储后台,采用Tomcat作为Web服务器,并在MyEclipse集成开发环境中实现的系统。本系统主要目标是提供高效、便捷...
这个"javaee.zip"文件包含了基于JavaEE技术的课程设计项目——一个个性化的学生信息管理系统。该项目着重于前端界面设计与后端数据处理,提供了学生信息的增、删、查、改等基本功能,适合用于教学和实践。 首先,让...
1. **MVC模式**:MVC模式将应用分为三个主要组件——模型(Model)、视图(View)和控制器(Controller)。模型负责处理业务逻辑和数据管理,视图负责显示数据,而控制器接收用户请求并协调模型和视图。 2. **...
《基于Springboot的药房管理系统——Javaee项目详解》 在现代信息技术的推动下,药房管理系统的开发已经成为提升药房运营效率、保障药品安全的重要工具。本项目以Springboot框架为基础,结合Javaee技术,构建了一个...
本文主要探讨了基于JavaEE架构开发的通用商城系统的设计与实现。JavaEE(Java Platform, Enterprise ...关键词:JavaEE、MVC模型、Oracle数据库、B/S结构系统、Struts2、Spring、Hibernate、SSH、Ajax、JQuery、JDBC。
《企业财务管理系统设计与实现——基于JavaEE、Servlet和MySQL》 在当今信息化时代,企业对财务管理系统的依赖日益增强,高效、准确的财务管理系统成为企业管理的核心组成部分。本系统设计与实现利用了JavaEE技术栈...
《基于JavaEE的医院管理系统——JSP网站设计与MySQL数据库应用》 在信息化时代,医院管理系统的构建对于提升医疗服务质量和效率具有重要意义。本系统采用JavaEE技术栈,结合JSP进行网页设计,并利用MySQL作为后台...
本项目——试卷分析报告产生系统,旨在简化教育工作者对学生考试成绩的处理和分析工作。以下是该系统的设计要点和功能详细说明: 1. **设计时间**: - 通常,JavaEE课程设计会持续一段时间,让学生有足够的时间...
【标签】"论文"提示我们这是一篇深入的技术文档,可能包含理论分析、技术选型、架构设计和实施策略等内容,旨在分享和探讨JavaEE在特定应用场景——婚介系统中的应用。 【压缩包子文件的文件名称】"基于JavaEE技术...
《简单订餐系统详解——基于JavaEE的课程设计实践》 在信息技术日新月异的今天,开发一个订餐系统已经成为了许多计算机专业学生期末课程设计的常见课题。本资料包“简单订餐系统文档+PPT+项目源码(数据库包)对付...