关于c#的一些问题

privatevoidOpen(){//打开数据库连接if(con==null){con=newSqlConnection("DataSource=a\\a;DataBa... private void Open()
{
// 打开数据库连接
if (con == null)
{
con = new SqlConnection("Data Source=a\\a;DataBase=db_SIS;User ID=sa;PWD=");
}
if (con.State == System.Data.ConnectionState.Closed)
con.Open();

}
private void Open()
{
// 打开数据库连接
if (con == null)
{
con = new SqlConnection("Data Source=a\\a;DataBase=db_SIS;User ID=sa;PWD=");
}
if (con.State == System.Data.ConnectionState.Closed)
con.Open();

}
疑问 为何要 用两次if 这两个if有何区别

public void Dispose()
{
// 确认连接是否已经关闭
if (con != null)
{
con.Dispose();
con = null;
}
}
为何要关两次 有何区别

public SqlParameter MakeParam(string ParamName, SqlDbType DbType, Int32 Size, ParameterDirection Direction, object Value)
{
SqlParameter param;

if (Size > 0)
param = new SqlParameter(ParamName, DbType, Size);
else
param = new SqlParameter(ParamName, DbType);

param.Direction = Direction;
if (!(Direction == ParameterDirection.Output && Value == null))
param.Value = Value;
return param;
}

这里的size>0的区分 是啥意思

private SqlCommand CreateCommand(string procName, SqlParameter[] prams)
{
// 确认打开连接
this.Open();
SqlCommand cmd = new SqlCommand(procName, con);
cmd.CommandType = CommandType.Text; //执行类型:命令文本

// 依次把参数传入命令文本
if (prams != null)
{
foreach (SqlParameter parameter in prams)
cmd.Parameters.Add(parameter);
}
// 加入返回参数
cmd.Parameters.Add(
new SqlParameter("ReturnValue", SqlDbType.Int, 4,
ParameterDirection.ReturnValue, false, 0, 0,
string.Empty, DataRowVersion.Default, null));

return cmd;
}

foreach 里边声明的parameter

为何 foreach完了 parameter还在用

为sqldataadapter对象指定deletecommand属性

adapter.deletecommand=command;

这里 command代表什么 ?
展开
 我来答
ml0133
2008-06-30 · TA获得超过312个赞
知道小有建树答主
回答量:220
采纳率:0%
帮助的人:263万
展开全部
if (con == null)
如果con为空,就是为null的时候,这个时候,con未初始化,
if (con.State == System.Data.ConnectionState.Closed)
如果con不为null,而且con是关闭的,就是连接是关闭的,则打开con
一个是为null
一个判断的是,连接是不是关闭。

con.Dispose();//释放con的资源
con = null;//设置为null
说实话,第一个语句之后,con已经为null,第二个在让它为null,没有实际意义的,只不过是为了代码的安全考虑的。

c#和sql数据类型不一样,当然,有的也兼容,为了区分,加了sqldbtype类,你可以自己看一下。

public SqlParameter MakeParam(string ParamName, SqlDbType DbType, Int32 Size, ParameterDirection Direction, object Value)

你看清了这个函数!
size是你给的参数,你再调用它的时候,想给它多少,就是多少!
size的主要意思是,判断数据的长度。
我这么解释吧。
调用你这个函数的时候,我有一个int的,我有一个varchar的。
看,应该这么调。
MakeParam("paramname",sqldbtype.varchar,50,ParameterDirection.output,this.txtusersname)
MakeParam("paramid",sqldbtype.integer,0,ParameterDirection.output,this.txtuserid)

size 是你给的,int不需要长度,我给size这个参数-1也可以

在 foreach 里边声明 新的对象
但是,这个对象只在『』中起作用
foreach (SqlParameter parameter in prams)
cmd.Parameters.Add()
c#区分大小写,一个是大写P,一个是小写。

adapter.deletecommand=command;

这里 command代表什么 ?
就是,它,
this.Open();
SqlCommand cmd = new SqlCommand(procName, con);
就是一个sqlcommand的实例
到茧照
2008-06-30 · TA获得超过1901个赞
知道大有可为答主
回答量:1589
采纳率:0%
帮助的人:2012万
展开全部
1.两个if

if (con == null)//这个if是判断con对象有没有实例化.如果没有实例化的话.为null.此时new一个新的对象.

if (con.State == System.Data.ConnectionState.Closed)//这个if 是判断con对象当前的状态.如果已关闭的话.打开它.

2.关闭两次

con.Dispose();//释放资源.此时con对象仍然存在.

con=null;//将该对象清空.此时要是再使用con.得重新实例化.一般不用这么写.直接con.close()就行了.下次使用的时候再con.open().

3.size>0的区分

函数接收的size这个参数如果大于0.则在实例SqlParameter参数对象的时候.将该size传参过去.如果size小于等于0.则在实例SqlParameter参数时使用另一种构造函数.不传size.

4.为何 foreach完了 parameter还在用

parameter是在循环中声明的.所以只能在循环中使用.你再看看代码.下面使用的是cmd的属性Parameters.而不是循环中声明的变量parameter.

5.这里 command代表什么

你提供的代码中并没有出现这个command.而这里的command是一个SqlCommand对象.应该在你的其它代码中有实例.
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式