相信大家都知道.net中有四个关于参数传入传出的类型 分别是:

System.Data.ParameterDirection.Input

System.Data.ParameterDirection.InputOutput

System.Data.ParameterDirection.Output

System.Data.ParameterDirection.ReturnValue

感官上理解就是只能传入 即可以传入又可以传出 只能传出 和 返回值 实际应用中和感官的理解一致吗?我也不大清楚 反正以前做的系统都没有遇见问题 所以也没有把这几个参数搞的很明白 不过心中始终有疑问 所以今天就抽了点时间做了一个例子把原理搞清楚

首先我把.Net中的参数定义为形式参数 而把存储过程的参数定义为实际参数

比如:cmd.Parameters.Add("@Input", System.Data.SqlDbType.Int);  @Input为形式参数

而存储过程的@Input int,  @Input为实际参数

得到的结论如下:

数据库存储过程的实际参数如果没有默认值则形式参数必须传值给实际参数

但是如果形式参数的类型为ParameterDirection.Output 则传给实际参数的永远是空值

如果形式参数的类型为ParameterDirection.ReturnValue 则形式参数不会传值给实际参数 实际参数必须有默认值  否则代码会报错

如果形式参数类型为ParameterDirection.InputOutput 或者 ParameterDirection.Output 则实际参数必须有output 关键字

另外需要注意的是在.net中 System.DBNull.Value表示数据库参数为空值 而不是null

用于测试的存储过程如下:

/*

function:测试C#中 ParameterDirection 枚举类的作用

coder:benniuniu

time:2007-11-25

*/

CREATE PROCEDURE proc_test_SQLParametersValue

@Input int,

@InputOutput int output,

@Output int output,

@ReturnValue int=1

AS

select @Input as Input,@InputOutput as InputOutput,@Output as [Output],@ReturnValue as ReturnValue

return 2

Go

测试用的C# 代码类如下:

using System;

using System.Collections.Generic;

using System.Text;

using System.Data.SqlClient;

using System.Configuration;

using System.Data;

namespace CoderHelper.Test

{

class SQLParametersValue

{

public SQLParametersValue()

{

}

public int? Input=1;

public int? InputOutput=2;

public int? Output=3;

public int? ReturnValue=4;

public int? Input2;

public int? InputOutput2;

public int? Output2;

public int? ReturnValue2;

public void GetData(DataTable dt)

{

SqlConnection conn = newSqlConnection(ConfigurationSettings.AppSettings["LocalSqlConnectionString"]);

SqlCommand cmd = new SqlCommand();

cmd.Connection = conn;

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

cmd.CommandText = "proc_test_SQLParametersValue";

cmd.Parameters.Add("@Input", System.Data.SqlDbType.Int);

cmd.Parameters["@Input"].Direction = System.Data.ParameterDirection.Input;

if (Input == null)

{

cmd.Parameters["@Input"].Value = System.DBNull.Value;

}

else

{

cmd.Parameters["@Input"].Value = Input;

}

cmd.Parameters.Add("@InputOutput", System.Data.SqlDbType.Int);

cmd.Parameters["@InputOutput"].Direction = System.Data.ParameterDirection.InputOutput;

if (InputOutput == null)

{

cmd.Parameters["@InputOutput"].Value = System.DBNull.Value;

}

else

{

cmd.Parameters["@InputOutput"].Value = InputOutput;

}

cmd.Parameters.Add("@Output", System.Data.SqlDbType.Int);

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

if (Output == null)

{

cmd.Parameters["@Output"].Value = System.DBNull.Value;

}

else

{

cmd.Parameters["@Output"].Value = Output;

}

cmd.Parameters.Add("@ReturnValue", System.Data.SqlDbType.Int);

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

if (ReturnValue == null)

{

cmd.Parameters["@ReturnValue"].Value = System.DBNull.Value;

}

else

{

cmd.Parameters["@ReturnValue"].Value = ReturnValue;

}

SqlDataAdapter sa = new SqlDataAdapter(cmd);

try

{

if (conn.State == System.Data.ConnectionState.Closed)

{

conn.Open();

}

sa.Fill(dt);

if (cmd.Parameters["@Input"].Value != System.DBNull.Value)

Input2 = Convert.ToInt32(cmd.Parameters["@Input"].Value);

if (cmd.Parameters["@InputOutput"].Value != System.DBNull.Value)

InputOutput2 = Convert.ToInt32(cmd.Parameters["@InputOutput"].Value);

if (cmd.Parameters["@Output"].Value != System.DBNull.Value)

Output2 = Convert.ToInt32(cmd.Parameters["@Output"].Value);

if (cmd.Parameters["@ReturnValue"].Value != System.DBNull.Value)

ReturnValue2 = Convert.ToInt32(cmd.Parameters["@ReturnValue"].Value);

}

catch (Exception ex)

{

}

finally

{

conn.Close();

}

}

}

}

如上代码

public int? Output=3; 但是实际传给存储过程的值还是空值

public int? ReturnValue=4; 但是实际没有传值给存储过程

ReturnValue2 = Convert.ToInt32(cmd.Parameters["@ReturnValue"].Value); 取的是存储过程return的返回值此例存储过程代码是return 2 所以取得值是2。

注意:

1:return只能是int类型,有很大的局限性,所以Procedure返回值一般使用output。

2:Procedure中output和out是一样的,大多数网上写的是错的

3:ParameterDirection(Input,Output,InputOutput,ReturnValue)中的Output,InputOutput只是代表C#怎么传值给Procedure,Output传空,InputOutput传实际的值

关于System.Data.ParameterDirection四个枚举类型所起的作用(转)的更多相关文章

  1. 使用EF访问数据库,出现“System.Data.Entity.Internal.AppConfig”的类型初始值设定项引发异常。

    今天在使用的EF时候,发生了"System.Data.Entity.Internal.AppConfig"的类型初始值设定项引发异常.这样的一个错误 查了原因,原来是appconf ...

  2. “System.Data.Entity.Internal.AppConfig"的类型初始值设定项引发异常。{转}

    <connectionStrings> <add name="ConnectionStringName" providerName="System.Da ...

  3. System.Data.Entity.Internal.AppConfig"的类型初始值设定项引发异常

    在学习EF code First的小案例的时候,遇见了这个异常 <configSections> <!-- For more information on Entity Framew ...

  4. Entityframework:“System.Data.Entity.Internal.AppConfig”的类型初始值设定项引发异常。

    <configSections> <!-- For more information on Entity Framework configuration, visit http:// ...

  5. Language Guide (proto3) | proto3 语言指南(四)枚举类型

    枚举类型 定义消息类型时,可能希望其中一个字段只包含预定义值列表中的一个.例如,假设您想为每个SearchRequest添加一个corpus(语料库)字段,其中语料库的值可以是UNIVERSAL.WE ...

  6. EF中System.Data.Entity.Internal.AppConfig的类型初始值设定项引发异常

    使用Entity的时候遇到的一个错 问题出在项目的App.config中 解决: 1.configSections要写在最顶端 2. 当中的incariantName会变成incariantNodeN ...

  7. System.Data.Entity.Internal.AppConfig 类型初始值设定项引发异常

    在一开始时将connectionStrings 写在了configSections之上如下图一示,结果抛出:“System.Data.Entity.Internal.AppConfig”的类型初始值设 ...

  8. Method 'ExecuteAsync' in type 'System.Data.Entity.SqlServer.DefaultSqlExecutionStrategy' does not have an implementation

    一.错误信息 Entity Framework 6.0数据迁移:Add-Migration XXXX 命令发生错误 System.Reflection.TargetInvocationExceptio ...

  9. C#枚举类型的常用操作总结

    枚举类型是定义了一组"符号名称/值"配对.枚举类型是强类型的.每个枚举类型都是从system.Enum派生,又从system.ValueType派生,而system.ValueTy ...

随机推荐

  1. TensorFlow——共享变量的使用方法

    1.共享变量用途 在构建模型时,需要使用tf.Variable来创建一个变量(也可以理解成节点).当两个模型一起训练时,一个模型需要使用其他模型创建的变量,比如,对抗网络中的生成器和判别器.如果使用t ...

  2. SpringBoot优雅的全局异常处理

    前言 本篇文章主要介绍的是SpringBoot项目进行全局异常的处理. SpringBoot全局异常准备 说明:如果想直接获取工程那么可以直接跳到底部,通过链接下载工程代码. 开发准备 环境要求 JD ...

  3. js 面试的坑:变量提升

    全局中的解析和执行过程 预处理:创建一个词法环境(LexicalEnvironment,在后面简写为LE),扫描JS中的用声明的方式声明的函数,用var定义的变量并将它们加到预处理阶段的词法环境中去. ...

  4. ImportError: cannot import name patterns

    The use of patterns is deprecated in Django1.10. Therefore do not import 'patterns' and your url pat ...

  5. fastjson设置生成的json属性的顺序

    目标JSON顺序: {,,} 1.url2.w3.h4.s 如果使用默认情况生成,则顺序为: w,h,s,url 在fastJson中,可以使用@JSONField来指定属性顺序(需要1.1.42以上 ...

  6. Node.js自动化技术实现(Java)

    Node.js自动化测试框架(NodeTestFramework):

  7. JAVA_Error initializing endpoint怎么办

    1 运行CMD,输入命令netstat –ano,找到这个TCP,后缀为8080的PID(我的是2660),然后打开任务管理器,在进程选项卡中打开PID查看   2 在右侧的进程窗口找到PID是左侧的 ...

  8. cookie-小总结吧

    写入common.js文件,其他页面调用即可: //添加cookie值 function addcookie(name, value, days) { days = days || 0; var ex ...

  9. Visual Studio 2015官方下载 秘钥破解

    微软刚刚为开发人员奉上了最新大礼Visual Studio 2015正式版.如果你是MSDN订阅用户,现在就可以去下载丰富的相关资源.如果你指向体验一把尝尝鲜,微软也是很慷慨的. Visual Stu ...

  10. .NET面试题汇总

    目录 本次给大家介绍的是我收集以及自己个人保存一些.NET面试题 简介 1.C# 值类型和引用类型的区别 2.如何使得一个类型可以在foreach 语句中使用 3.sealed修饰的类有什么特点 4. ...