您好,我写了我的DAL调用存储过程,但是我仍然不知道我是否应该对某些过程使用ExecuteScalar,NonQuery或Reader。

例如,我编写了要调用的函数

CREATE FUNCTION `retornarIdArea`(cod longtext) RETURNS int(11)

BEGIN

DECLARE id int;

select AreaId into id FROM area where Codigo = cod;

return id;

END

此过程应返回数据集

CREATE PROCEDURE `consultar_n_asunto`(in asun longtext, in est int)

BEGIN

select * from notas where Asunto LIKE CONCAT('%',CONCAT(asun,'%')) AND Estado = est;

END$$

最后是插入一些数据的过程,然后使用输出参数进行选择以验证这一点。

CREATE PROCEDURE `registrar_dest`(in nomb longtext,

in dir longtext, in inst int, in mail longtext, in tel longtext,

in act int, out res tinyint(1))

BEGIN

-- verificar que no exista el destinatario

select count(*) into res from destinatario WHERE Nombre = nomb AND

Direccion = dir AND Email = mail AND Telefono = tel AND Activo = act;

IF res = 0 THEN

INSERT INTO destinatario (Nombre, Direccion, InstitucionId, Email, Telefono, Activo)

VALUES (nomb, dir, inst, mail, tel, act);

select count(*) into res from destinatario WHERE Nombre = nomb AND

Direccion = dir AND Email = mail AND Telefono = tel AND Activo = act;

ELSE

set res = -1;

END IF;

END$$

现在,我用C#编写了此函数以从FUNCTIONS返回值

public object ejecutarFuncion()

{

using (MySqlConnection conn = new MySqlConnection(stringDeConexion))

{

using (MySqlCommand cmd = new MySqlCommand(procedimiento, conn))

{

cmd.CommandType = System.Data.CommandType.StoredProcedure;

//Se abre la conexión

conn.Open();

//existen parámetros los recorremos y agregamos.

foreach (KeyValuePair pars in parametros)

{

cmd.Parameters.Add(new MySqlParameter(pars.Key, pars.Value));

}

//Se crea la variable de retorno

cmd.Parameters.Add(new MySqlParameter(nombreOut, tipoParOut));

cmd.Parameters[nombreOut].Direction = System.Data.ParameterDirection.ReturnValue;

cmd.ExecuteNonQuery();

// Cerramos conexión

conn.Close();

return cmd.Parameters[nombreOut].Value;

}

}

}

If you see I do a ExecuteNonQuery() here, but should I used Execute Scalar? or just use the return value from parms?

然后,我编写了此方法以使用输出值(其中一些进行更新,插入)操作来执行Procedures,然后使用输出值来检查操作是否正确完成。

public object ejecutarProcedimientoConOutput()

{

using (MySqlConnection conn = new MySqlConnection(stringDeConexion))

{

using (MySqlCommand cmd = new MySqlCommand(procedimiento, conn))

{

cmd.CommandType = System.Data.CommandType.StoredProcedure;

//Se abre la conexión

conn.Open();

//verificamos si se mando la lista de parámetros

if (parametros.Count > 0)

{

//existen parámetros los recorremos y agregamos.

foreach (KeyValuePair pars in parametros)

{

cmd.Parameters.Add(new MySqlParameter(pars.Key, pars.Value));

cmd.Parameters[pars.Key].Direction = System.Data.ParameterDirection.Input;

}

}

cmd.Parameters.Add(new MySqlParameter(nombreOut, tipoParOut));

cmd.Parameters[nombreOut].Direction = System.Data.ParameterDirection.Output;

cmd.ExecuteNonQuery();

conn.Close();

return cmd.Parameters[nombreOut].Value;

}

}

}

同样,如果我正在执行更新或插入操作,但是我使用输出参数来检查是否已完成,则可以检查插入存储过程,是否应该使用ExecuteNonQuery或ExecuteScalar?

对于返回数据集的过程,与我上面编写的方法相同,但是没有输出参数,我使用的是executeReader,因为我仅执行选择操作而不使用输出参数。

我只想知道我是否对这些过程使用了正确的执行命令。

如果要返回受查询影响的行数

然后使用ExecuteNonReader()。

如果要返回第一行的第一列,请使用

ExecuteScalar。

如果您需要创建SqlDataReader以便进行迭代

在结果上使用ExecuteReader。

因此,您可以对函数retornarIdArea使用ExecuteScalar,因为您只返回一列和一行(id),因此该函数适合上下文。

对于过程consultar_n_asunto,可以在选择多行时使用ExecuteReader,并期望返回结果集。

c# 调用mysql存储过程 返回值_C#调用MySQL存储过程,函数的最佳方法相关推荐

  1. c oracle存储过程返回值,C#调用存储过程详解(带返回值、参数输入输出等)

    本文实例讲述了C#调用存储过程的方法.分享给大家供大家参考,具体如下: CREATE PROCEDURE [dbo].[GetNameById] @studentid varchar(8), @stu ...

  2. bat 存储过程返回值_MySQL-存储过程和函数详述

    1.1 存储过程和函数概述 存储过程和函数是 事先经过编译并存储在数据库中的一段 SQL 语句的集合,调用存储过程和函数可以简化应用开发人员的很多工作,减少数据在数据库和应用服务器之间的传输,对于提高 ...

  3. mysql pool返回值_【Mysql】你知道一条查询语句是如何执行的吗?

    [Mysql]你知道一条查询语句是如何执行的吗?​mp.weixin.qq.com 前言 在默认大家学习了Mysql结构的基础上,我们来深入的解析一下sql语句在mysql中是如何流转和实现的.本文会 ...

  4. ibatis mysql存储过程返回值_ibatis调用mysql存储过程

    ibtatis调用有输出参数的mysql存储过程的时候,居然要使用insert写法,汗! procedure============================================== ...

  5. php oracle 存储过程 返回值,PHP 调用 Oracle 存储过程 之 查询

    在网上找了很久都没找到结果,今天看帮助,结合JAVA程序中的一个实例,写出了这个PHP调用Oracle存储过程的例子,也许有人会说PHP调用存储过程是很简单的,但在这里我还是想把这点小成就拿来共享一下 ...

  6. dapper 调用 存储过程返回值_数据库事务、存储过程、函数以及触发器之间的区别和联系...

    一.[事务概念] 事务(Transaction)是指构成单一逻辑工作单元的操作集合,要么完整地执行,要么完全不执行. 1,如果事务中有的操作没有成功完成,则事务中的所有操作都需要被回滚,回到事务执行前 ...

  7. C#获取存储过程返回值和输出参数值的方法

    //转自网络,先留个底 1.获取Return返回值 //存储过程 //Create PROCEDURE MYSQL // @a int, // @b int //AS // return @a + @ ...

  8. dotnet 获得存储过程返回值和输出参数有什么不同 @@IDENTITY SCOPE_IDENTITY()

    存储过程1: Create PROCEDURE CreateNewUser @UserName varchar(50), @Password varchar(50), @Description var ...

  9. 获取存储过程返回值及代码中获取返回值

    获取存储过程返回值及代码中获取返回值 1.OUPUT参数返回值例: 向Order表插入一条记录,返回其标识 CREATE PROCEDURE [dbo].[nb_order_insert]( @o_b ...

最新文章

  1. HoloLens开发手记 - 语音输入 Voice input
  2. swift_031(Swift 中的枚举/原始值(RawValues))
  3. 在大厂干了几年开发后,太真实了。
  4. Linux无法登陆,var目录权限修改导致SSH失败
  5. Spring 2.5 jar 所有开发包及完整文档及项目开发实例
  6. android中edittext监听文字变化,使用TextWatcher监听EditText变化
  7. 虚幻4服务端linux,UE4 虚幻4教程 服务端构建后启动错误的解决方法
  8. 【Unity】Transform—用代码设置父子关系
  9. 自然语言处理NLPIR-ICTCLAS 授权文件过期问题
  10. Silvaco TCAD LTPS双栅器件仿真收敛不了,有没有好的解决办法
  11. ubuntu16.04安装QQ完整版(附网盘资源)
  12. 用VC++6.0制作简易浏览器
  13. 祝cattom考研成功
  14. win7下安装ArcGIS9.3步骤与破解过程
  15. win11磁盘分区怎么分?手把手教会你
  16. 码字 层映射 预编码的概念总结
  17. Webpack是什么?(webpack初学简单易理解)
  18. python查看电脑配置_怎么看电脑配置_怎么查看电脑配置好坏|信息【图文】-太平洋IT百科...
  19. 如何用R画折线图,散点图,平滑曲线图
  20. 艺工交叉之神--达芬奇

热门文章

  1. Terraform 实战 | 万字长文
  2. 2.2 Go语言中的布尔型和整型
  3. 阿里云杨敬宇再谈边缘计算:ENS从1.0到2.0进化论
  4. Nginx优化之expires缓存设置
  5. 接口测试系列——转转交易业务场景接口测试实践
  6. PCB钻孔工艺故障及解决办法
  7. 失去5G先机或致OPPO走向衰落
  8. 数据会说话 | 这届年轻人为什么开始在B站看刑法了?
  9. 如何给证件照换背景色并压缩到100K
  10. 基于java的扫雷游戏的设计