mysql存储过程返回(mybatis调用mysql存储过程(返回参数,单结果集,多结果集))
本文目录
- mybatis调用mysql存储过程(返回参数,单结果集,多结果集)
- MYSQL如何把存储过程所返回的结果集插入到表
- golang xorm 怎么获取mysql存储过程的返回值
- MYSQL 存储过程能返回结果集吗
- MYSQL的存储过程如何返回查询到的行数据
- 如何用mysql 的存储过程 返回一个表
- mysql存储过程中能返回游标吗
- 如何创建MySQL存储过程可以返回一个表类型的数据
mybatis调用mysql存储过程(返回参数,单结果集,多结果集)
mybatis调用mysql存储过程(返回参数,单结果集,多结果集)
注: RETCODE、RETDESC 这里的输出值不用在函数里 SELECT RETCODE; ,因为即使没有,当执行成功后会自动返回在对象里(Object/Map),所以在函数里不用SELECT一下了。
Navicat中执行函数需要输入参数值,也是对应图1,@A@B表示输出值。(一个输入值两个输出值)
1. 标注一二三四五处如果存在,则执行成功后返回结果如下
标注一对应结果1 标注二对应结果2 标注三对应结果3 标注四对应结果4 标注五对应结果5 其中结果3返回的是集合。 存在这么多结果,想要取结果3中的集合是不好取的,只有像下图一样只有一个结果才好取出集合。
2. 标注一二四五处如果不存在,则执行成功后返回结果如下
只有结果1,对应的是标注三处的值。可以取出集合
函数p_duplicate_enroll
MYSQL如何把存储过程所返回的结果集插入到表
从存储过程返回表类型的值也有二种:1.存储过程使用浮标参数,即同时指定CURSOR VARYING OUTPUT项.调用者可以使用while及fetch循环遍历该浮标.2.直接将存储过程返回的结果集插入到表中,即使用insert into 表名 exec 存储过程.此种方式中注意存储过程返回的结果集列与insert的列要完全对应,可以在insert中指定列名来保证对应关系.------------------------------------------------------------------------------测试:----------------------------------------------------------------------------------建立测试用的临时表create table #tmp (colx int,coly int)insert into #tmp values(1,2)insert into #tmp values(2,3)insert into #tmp values(3,4)select * from #tmpGO----创建返回游标的存储过程create proc sp_c @cur CURSOR VARYING OUTPUTASbeginset @cur = CURSOR for select colx from #tmpopen @cur /*该过程返回游标,该游标为colx列的查询结果*/endGO----创建返回表的存储过程create proc sp_dasselect coly from #tmp /*该过程返回coly列的查询结果*/go----创建用于调用以上二个存储过程的存储过程create proc sp_easbegindeclare @x intdeclare @cur cursor----接收游标,并遍历游标EXEC sp_c @cur OUTPUTfetch next from @cur into @xwhile (@@FETCH_STATUS = 0)beginprint @xfetch next from @cur into @xENDclose @curdeallocate @cur----将存储过程返回的列值再重新插入源表中
golang xorm 怎么获取mysql存储过程的返回值
session := engine.NewSession()defer session.Close()// add Begin() before any actionerr := session.Begin()user1 := Userinfo{Username: "xiaoxiao", Departname: "dev", Alias: "lunny", Created: time.Now()}_, err = session.Insert(&user1)if err != nil { session.Rollback() return}user2 := Userinfo{Username: "yyy"}_, err = session.Where("id = ?", 2).Update(&user2)if err != nil { session.Rollback() return} _, err = session.Exec("delete from userinfo where username = ?", user2.Username)if err != nil { session.Rollback() return} // add Commit() after all actionserr = session.Commit()if err != nil { return}
MYSQL 存储过程能返回结果集吗
可以,存储过程只是把你的查询语句形成一个固定的格式,这样你要查询的时候就不用每次都执行查询语句了,sql在执行的时候都会将你的sql语句转换为字节码,然后机器才能运行,存储过程就节省了这一步,已经形成了字节码,所以速度才会快,特别是执行次数比较多的时候,可以节省很多时间
MYSQL的存储过程如何返回查询到的行数据
out返回只能是确定的某种类型的一个值,例如VARCHAR或者INT等等,你想返回多条记录的话只需要在最后加上一个或者多个SELECT语句就行了啊,然后在外面用ResultSet对象接住就行了。
如何用mysql 的存储过程 返回一个表
mysql中要获得存储过程的返回值,可以增加一个out参数,用来返回。mysql中存储过程的例子:CREATE PROCEDURE addvoucher (IN userid INT,IN voucherid INT,OUT result INT)BEGINSELECT@endate_a := endate ,@batch_a := batch ,@c_count_a := c_count,@isdead_a := isdeadFROMt_voucherWHEREid = voucherid;
mysql存储过程中能返回游标吗
MySQL中可以返回一个记录集 , 比如直接 select * from test_table; ,你在程序中直接调这个存储过程,存储过程会返回这些记录集到你的客户端应用程序中。但无法返回游标。
如何创建MySQL存储过程可以返回一个表类型的数据
首先需要知道“另一个存储过程”的结果集的所有列的类型。 假设“另一个存储过程”的名字是sp1,没有参数,返回的结果集共3列,全部为int型,那么“存储过程”里添加一个与结果集列数相同的临时表或表变量用于接收“另一个存储过程”的结果集如下CREATE PROCEDURE sp2ASDECLARE @t table(a int,b int,c int)INSERT INTO @t(a,b,c)EXEC sp1SELECT * FROM @t使用SQLSERVER存储过程可以很大的提高程序运行速度,简化编程维护难度,现已得到广泛应用。创建存储过程 和数据表一样,在使用之前需要创建存储过程,它的简明语法是: 引用: Create PROC 存储过程名称 AS SQL 语句 例: 引用: Create PROC upGetUserName @intUserId INT, @ostrUserName NVARCHAR(20) OUTPUT -- 要输出的参数 AS BEGIN -- 将uName的值赋给 @ostrUserName 变量,即要输出的参数 Select @ostrUserName=uName FROM uUser Where uId=@intUserId END 其中 Create PROC 语句(完整语句为Create PROCEDURE)的意思就是告诉SQL SERVER,现在需要建立一个存储过程,upGetUserName 就是存储过程名称,@intUserId 和 @ostrUserName 分别是该存储过程的两个参数,注意,在SQL SERVER中,所有用户定义的变量都以“@”开头,OUTPUT关键字表示这个参数是用来输出的,AS之后就是存储过程内容了。只要将以上代码在“查询分析器”里执行一次,SQL SERVER就会在当前数据库中创建一个名为“upGetUserName”的存储过程。你可以打开“企业管理器”,选择当前操作的数据库,然后在左边的树型列表中选择“存储过程”,此时就可以在右边的列表中看到你刚刚创建的存储过程了(如果没有,刷新一下即可)。 二、存储过程的调用 之前已经创建了一个名为“upGetUserName”的存储过程,从字面理解该存储过程的功能是用来取得某一个用户的名称。存储过程建立好了,接下来就是要在应用程序里调用了,下面看一下在ASP程序里的调用。 引用: Dim adoComm ’// 创建一个对象,我们用来调用存储过程 Set adoComm = CreateObject("ADODB.Command") With adoComm ’// 设置连接,设 adoConn 为已经连接的 ADODB.Connection 对象 .ActiveConnection = adoConn ’// 类型为存储过程,adCmdStoredProc = 4 .CommandType = 4 ’// 存储过程名称 .CommandText = "upGetUserName" ’// 设置用户编号 .Parameters.Item("@intUserId").Value = 1 ’// 执行存储过程 .Execute ’// 取得从存储过程返回的用户名称 Response.Write "用户名:" & .Parameters.Item("@ostrUserName").Value End With ’// 释放对象 Set adoComm = Nothing 通过以上两步,已经可以创建和使用简单的存储过程了。下面来看一个稍微复杂点的存储过程,以进一步了解存储过程的应用。三、存储过程的实际应用 用户登录在ASP项目中经常会使用到,但使用存储过程来做验证可能不多,那么做例子,写一个简单的用户登录验证的存储过程。 引用: Create PROC upUserLogin @strLoginName NVARCHAR(20), @strLoginPwd NVARCHAR(20), @blnReturn BIT OUTPUT AS -- 定义一个临时用来保存密码的变量 DECLARE @strPwd NVARCHAR(20) BEGIN -- 从表中查询当前用户的密码,赋值给 @strPwd 变量,下面要对他进行比较 Select @strPwd=uLoginPwd FROM uUser Where uLoginName=@strLoginName IF @strLoginPwd = @strPwd BEGIN SET @blnReturn = 1 -- 更新用户最后登录时间 Update uUser SET uLastLogin=GETDATE() Where uLoginName=@strLoginName END ELSE SET @blnReturn = 0 END 用户登录的存储过程建立好了。注意,在一个区域内如果有多条语句时,必需使用BEGIN...END关键字。引用: Dim adoComm ’// 创建一个对象,我们用来调用存储过程 Set adoComm = CreateObject("ADODB.Command") With adoComm ’// 设置连接,设 adoConn 为已经连接的 ADODB.Connection 对象 .ActiveConnection = adoConn ’// 类型为存储过程,adCmdStoredProc = 4 .CommandType = 4 ’// 存储过程名称 .CommandText = "upUserLogin" ’// 设置登录名称 .Parameters.Item("@strLoginName").Value = "***" ’// 设置登录密码 .Parameters.Item("@strLoginPwd").Value = "123456" ’// 执行存储过程 .Execute ’// 判断是否登录成功 If .Parameters.Item("@blnReturn").Value = 1 Then Response.Write "恭喜你,登录成功!" Else Response.Write "不是吧,好像错了哦。。。" End If End With ’// 释放对象 Set adoComm = Nothing 通过以上的步骤,简单用户登录验证过程也做完了,现在只要把它整合到程序中就可以实现简单的用户登录验证了,关于其他细节就由你自己来处理了。 上面介绍的两个存储过程都是只返回一个值的,下面我们来看一个返回一个记录集的存储过程。 引用: Create PROC upGetUserInfos @intUserGroup INT AS BEGIN -- 从数据库中抽取符合条件的数据 Select uName,uGroup,uLastLogin FROM uUser Where uGroup=@intUserGroup -- 插入一列合计 UNION Select ’合计人数:’,COUNT(uGroup),NULL FROM uUser Where uGroup=@intUserGroupEND 现在我们来看一下ASP程序的调用。 引用: Dim adoComm Dim adoRt ’// 创建一个对象,我们用来调用存储过程 Set adoComm = CreateObject("ADODB.Command") Set adoRs = CreateObject("ADODB.Recordset") With adoComm ’// 设置连接,设 adoConn 为已经连接的 ADODB.Connection 对象 .ActiveConnection = adoConn ’// 类型为存储过程,adCmdStoredProc = 4 .CommandType = 4 ’// 存储过程名称 .CommandText = "upGetUserInfos" ’// 设置用户组 .Parameters.Item("@intUserGroup").Value = 1 ’// 执行存储过程,和以上几个例子不同,这里使用RecordSet的Open方法 adoRs.Open adoComm ’// 显示第一个值 Response.write adoRs.Fields(0).Value End With ’// 释放对象 Set adoRs = Nothing Set adoComm = Nothing
更多文章:
三国志战略版15章以后还有吗?高考“立德树人”写作素材之十五:《三国志》15句
2024年5月29日 03:08
backgroundcolor(CSS中的background和background-color的区别)
2023年6月26日 07:40
ipad2越狱后怎么装软件(ipad2越狱后怎么装软件游戏)
2024年7月15日 06:48
免红外线遥控万能遥控app(手机没红外线功能怎么用空调万能遥控器)
2024年7月20日 11:30
单词背的超级痛苦!!有没有一些好的背单词的建议?怎么样记单词快,又全部都是对的
2024年7月2日 18:29
记忆卡数据恢复(我不小心把手机记忆卡内的文件都删除了可以恢复吗 急)
2024年3月21日 09:20
手机windows10模拟器(wins10simulator手机版为什么进不去)
2024年7月10日 17:32
搜道网美女时钟(怎样被美女时钟街拍啊,都说上传到百度,具体什么意思啊)
2024年6月13日 05:52