关于c#的一些问题

来源:百度知道 编辑:UC知道 时间:2024/06/05 09:16:34
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

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