黑马程序员技术交流社区
标题:
ParameterDirection的问题
[打印本页]
作者:
宋兴征
时间:
2013-4-10 14:34
标题:
ParameterDirection的问题
本帖最后由 宋兴征 于 2013-4-10 14:44 编辑
<div class="blockcode"><blockquote> private static void PrepareCommand(SqlCommand cmd, SqlConnection conn, SqlTransaction trans, string cmdText, SqlParameter[] cmdParms)
{
if (conn.State != ConnectionState.Open)
conn.Open();
cmd.Connection = conn;
cmd.CommandText = cmdText;
if (trans != null)
cmd.Transaction = trans;
cmd.CommandType = CommandType.Text;//cmdType;
if (cmdParms != null)
{
foreach (SqlParameter parameter in cmdParms)
{
if ((parameter.Direction == ParameterDirection.InputOutput || parameter.Direction == ParameterDirection.Input) &&
(parameter.Value == null))
{
parameter.Value = DBNull.Value;
}
cmd.Parameters.Add(parameter);
}
}
}
复制代码
ParameterDirection是一个枚举类型,值有:
// 摘要:
// 参数是输入参数。
Input = 1,
//
// 摘要:
// 参数是输出参数。
Output = 2,
//
// 摘要:
// 参数既能输入,也能输出。
InputOutput = 3,
//
// 摘要:
// 参数表示诸如存储过程、内置函数或用户定义函数之类的操作的返回值。
ReturnValue = 6,
请问,
if ((parameter.Direction == ParameterDirection.InputOutput || parameter.Direction == ParameterDirection.Input) &&
(parameter.Value == null))
{
parameter.Value = DBNull.Value;
}
复制代码
该怎么理解?是什么意思? 为什么要设参数为DBNull.Value?
作者:
张正强
时间:
2013-4-10 16:13
仔细看过,我是这样理解的:目的是将没有值的参数设置为Null
foreach (SqlParameter parameter in cmdParms)//循环所有的参数
{
if ((parameter.Direction == ParameterDirection.InputOutput || parameter.Direction == ParameterDirection.Input) &&(parameter.Value == null))//参数没有值并且为空
{
parameter.Value = DBNull.Value;//将它设置为数据库的空值Null
}
cmd.Parameters.Add(parameter);
}
作者:
郑丹丹1990
时间:
2013-4-10 16:38
Direction 获取或设置一个值,该值指示参数是只可输入、只可输出、双向还是存储过程返回值参数。
ParameterDirection是一个枚举类型:
Input 参数是输入参数。
InputOutput 参数既能输入,也能输出。
Output 参数是输出参数。
个人认为:
if ((parameter.Direction == ParameterDirection.InputOutput || parameter.Direction == ParameterDirection.Input) &&(parameter.Value == null))
//1.参数一定有(类型要么是即可输入也可输出,要么是输入型)2.参数的值为Null(c#中的null对应数据库中的DBNull) 1和2同时满足。
参考资料出处:http://msdn.microsoft.com/zh-cn/library/vstudio/system.data.sqlclient.sqlparameter_properties.aspx
http://msdn.microsoft.com/zh-cn/library/system.data.parameterdirection(VS.80).aspx
希望对您有所帮助!
作者:
宋兴征
时间:
2013-4-11 11:14
郑丹丹1990 发表于 2013-4-10 16:38
Direction 获取或设置一个值,该值指示参数是只可输入、只可输出、双向还是存储过程返回值参数。
ParameterDirection.InputOutput,参数是输入或输出参数,该怎么理解?参数传进去,还能再传出来吗?传出来怎么用?
欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/)
黑马程序员IT技术论坛 X3.2