关于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代表什么 ? 展开
{
// 打开数据库连接
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代表什么 ? 展开
2个回答
展开全部
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的实例
如果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的实例
展开全部
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对象.应该在你的其它代码中有实例.
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对象.应该在你的其它代码中有实例.
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询