首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

ExecuteReader在执行有输出参数存储过程时拿不到输出参数

www.cnblogs.com/dunitian/p/4523006.html 后期会在博客首发更新:http://dnt.dkill.net/Article/Detail/312 今天一同志问我这个问题,这个是过程还原...: 调用SQLHelper时候发现输出参数没值了???...~~的确,reader没关闭,那输出参数就没值(其实也可以理解~reader说:本大王还没读取完呢,你丫急什么,给我等着) ?...不能就这样算了啊,我不能总自己写吧,sqlhelper问题还是得解决 ? 我去,还是没有。。。。。。。这可不行,看看sqlhelper源码怎么搞 ? 万恶清除啊!再试试 ?...贴一个比较弱转换(有更好可以贴评论,我就先抛个砖头) public static IEnumerable SqlDataReaderToList(SqlDataReader reader

1.3K70
您找到你想要的搜索结果了吗?
是的
没有找到

MySQL存储过程详解

什么是存储过程 简单说,就是一组SQL语句集,功能强大,可以实现一些比较复杂逻辑功能,类似于Java语言中方法; ps:存储过程跟触发器有点类似,都是一组SQL集,但是存储过程是主动调用,且功能比触发器更加强大...,触发器是某件事触发后自动调用; 有哪些特性 有输入输出参数,可以声明变量,有if/else, case,while等控制语句,通过编写存储过程,可以实现复杂逻辑功能; 函数普遍特性:模块化,封装,...pro_test; 参数: IN:  表示输入参数,可以携带数据带存储过程 OUT: 表示输出参数,可以从存储过程返回结果 INOUT: 表示输入输出参数,既可以输入功能,也可以输出功能 1....带有输出参数存储过程 DELIMITER $ CREATE PROCEDURE pro_testOut(OUT str VARCHAR(20))  -- OUT:输出参数 BEGIN        ...带有输入输出参数存储过程 DELIMITER $ CREATE PROCEDURE pro_testInOut(INOUT n INT)  -- INOUT: 输入输出参数 BEGIN   -- 查看变量

2.3K10

MySQL存储过程_MySQL创建存储过程

什么是存储过程 存储过程就是事先经过编译并存储在数据库一段 SQL 语句集合; 为什么使用存储过程 调用存储过程可以简化应用开发人员很多工作,减少数据在数据库和应用服务器之间传输,对于提高数据处理效率是有好处...存储过程特点: 封装,复用, 可以把某一业务SQL封装在存储过程,需要用到时候直接调用即可; 可以接收参数,也可以返回数据, 在存储过程,可以传递参数,也可以接收返回值; 减少网络交互,提升效率,...PROCEDURE [ IF EXISTS ] 存储过程名称 ; 注意点:上面创建存储过程语句在navicat或者sqlyog没问题,但是放到命令行执行会报错,在命令行模式下,需要通过关键字...很明显,不够灵活,通常来说,在实际业务,我们更希望存储过程能够接收参数,并且返回处理结果,以便提供给后续业务逻辑使用,这就需要用到存储过程输入输出参数了; 五、存储过程输入输出参数使用 存储过程中使用到参数类型...,使用存储过程也可以完成,但是存储函数局限在于,函数必须要有返回结果; 八、存储过程中游标的使用 游标(CURSOR)是用来存储查询结果集数据类型 , 在存储过程和函数可以使用游标对结果集进行循环处理

22.2K21

在.NET调用存储过程

因为做项目要用到数据库,因此存储过程是必不可少,看了一点如何在.NET调用存储过程资料,颇有点心得,觉得这个东西是当用到数据库时候必须要会一项技术。...下面是它定义: 存储过程(Stored Procedure)是一组为了完成特定功能SQL语句集,经编译后存储在数据库。用户通过指定存储过程名字并给出参数(如果该存储过程带有参数)来执行它。...存储过程是数据库一个重要对象,任何一个设计良好数据库应用程序都应该用到存储过程。....NET调用存储过程。...2:有参数存储过程 调用有参数存储过程其实并不复杂,和类中方法参数传递相似,只不过存储过程里面的参数前必须要有“@”作用!

2.1K10

Mysql存储过程

存储过程(Stored Procedure)是一种在数据库存储复杂程序,以便外部程序调用一种数据库对象。...存储过程是为了完成特定功能SQL语句集,经编译创建并保存在数据库,用户可通过指定存储过程名字并给定参数(需要时)来调用执行。...存储过程性能调校与撰写,受限于各种数据库系统。 3、存储过程创建和调用   存储过程就是具有名字一段代码,用来完成一个特定功能。   创建存储过程保存在数据库数据字典。...3.3、调用存储过程: 解析:在存储过程设置了需要传参变量p_playerno,调用存储过程时候,通过传参将57赋值给p_playerno,然后进行存储过程SQL操作。...7.4、MySQL存储过程调用   删除一个存储过程比较简单,和删除表一样: 1 DROP PROCEDURE  从 MySQL 表格删除一个或多个存储过程

6.7K10

数据库存储过程语法

大家好,又见面了,我是你们朋友全栈君。...数据库存储过程语法 本文主要总结在数据库存储过程语法: 存储过程创建 存储过程删除 参数使用 变量声明 if条件语句语法 case when条件语句语法 循环语句语法 ---- 存储过程创建...drop procedure 存储过程存储过程参数说明 参数添加类型如下: @author by liu 1. in 表示参数为输入类型,如:in user_name varchar(20...); 2. out 表示参数为输出类型 , 如:out user_name varchar(20); 3. inout 表示参数为输入出类型 , 如:inout user_name varchar...存储过程参数列表可以有输入、输出类型参数,而且可以多个或不加参数create procedure proTest([in pwd varchar(20)] …); 5. 默认类型为输入类型。

1K20

Oracle存储过程及举例(几种参数情况存储过程

大家好,又见面了,我是你们朋友全栈君。 存储过程 存储过程可以有多个或者零个输入输出参数,但通常没有返回值。...存储过程是已经编译好代码,所以执行效率非常高 存储过程创建语句 create [or replace] procedure 存储过程名 [(输入、输出参数、in/out模式参数)] is/as begin...sentences; [exception sentences;] end 存储过程名; 举例一个没有参数存储过程 create or replace procedure pro_no_par...举例一个带in模式参数存储过程 参数方式有三种:指定名称传递;按位置传递;混合方式传递 注意混合方式传递从使用【指定名称传递】位置开始,后面的参数必须使用【指定名称传递】 create or...*Action: 观察存储过程变量使用(存储过程输入输入参数,字符型不用定义长度,内部字符型型变量是需要带长度) 内部变量不需要用declare,内部变量定义在as之后, begin end

1.4K30

大数据计算复杂存储过程替代方案

基于这些需要,我们引入了存储过程存储过程是目前复杂数据计算首选工具,在数据计算领域起着很大作用。然而,存储过程也会造成各种不便。...举个简单例子,如果要在区域销售报表找出“在任何州都最畅销N个产品”,编写存储过程就显得有些复杂了。...尽管语法细节略有不同,但各厂商SQL语句都基于ANSI标准。但是,存储过程就不一样了。因为各个厂商标准不尽相同,差异还比较大,存储过程迁移比重写还要复杂。...任何数据库都有基本SQL功能,但存储过程就不一定了。有的数据库提供存储过程功能较弱,有的干脆就不提供。...esProc灵活语法可以更容易地表示复杂计算,例如计算多级分组相对位置,并通过指定集合进行分组汇总。

6.1K70

【问答】MySQL存储过程 ?? 和 是什么?

在平时工作,有时我们会编写存储过程。在存储过程我们会在网上看到一些例子,在例子中会有类似 DELIMITER ??...我们在MySQL客户端写完SQL时会以分隔符;来作为一条完整SQL语句终止符,比如: 但是在存储过程我们会在一个存储过程内写很多以;结束语句,设置变量,循环,具体多个SQL语句等都会以;结束,...比如你想写一个包含两个查询SQL语句存储过程。...这次两个报错,是因为它把你写存储过程看成三个语句来交给服务器执行了,而只有中间语句select * from teacher where id = 1;是正确SQL。...此时你已经成功创建了一个存储过程了。然后你可以把分隔符重新改为默认;,然后执行存储过程

2.3K10

数据库存储过程_数据库存储过程语句

大家好,又见面了,我是你们朋友全栈君。 一、存储过程与函数区别:   1.一般来说,存储过程实现功能要复杂一点,而函数实现功能针对性比较强。   ...二、存储过程优点:   1.执行速度更快 – 在数据库中保存存储过程语句都是编译过   2.允许模块化程序设计 – 类似方法复用   3.提高系统安全性 – 防止SQL注入   4.减少网络流通量...– 只要传输存储过程名称 系统存储过程一般以sp开头,用户自定义存储过程一般以usp开头 三、定义存储过程语法,”[” 里面的内容表示可选项   create proc 存储过程名   @参数...  @gender nvarchar(10) [=’男’],   @age int [=30],   –加output表示该参数是需要在存储过程赋值并返回   @recorderCount int...,就是调用者需要传递一个变量进来,然后在存储过程为该变量完成赋值工作,存储过程执行完成以后,将执行对应结果返回给传递进来变量。

3.9K20
领券