动网论坛,站长建站首选,国内使用量最多的论坛软件 动网论坛官方技术讨论区 站长工具 申请属于您自己的免费论坛
首页 | 新闻资讯 | 网站运营 | 网络编程 | 数据库 | 服务器 | 网页设计 | 图像媒体 | 网络应用 | 搜索优化 | 资源下载 | 动网主机 | DVBOX
    本站内  互联网 ASP论坛  ASP.Net论坛  PHP论坛
   .Net → 阅读文章

 DBEngine的类片段(使用自动填充)

作者:raxzhang 来源:开发者俱乐部 
阅读 4086 人次 , 2002-2-27 

private bool IsInitializeDataAccess()
{
bool IsInit=false;
#region intialize
if(this.accessSql ==null)
{
if(this.cnnstr!="")
{
this.accessSql =new DataAccessSQL(this.cnnstr);
IsInit =true;
}
else
{
throw new Exception("The Connectstring is null! program can't create a connect with SQL server.");
}
}
else
{
IsInit =true;
}
#endregion
return IsInit;
}
private SqlCommand sqlSPCmd(String spname,Hashtable values)
{
#region intialize
if(!IsInitializeDataAccess())
return null;
#endregion
SqlCommand cmd= new SqlCommand();
cmd.Connection=new SqlConnection(this.cnnstr);
cmd.CommandText =spname;
cmd.CommandType =CommandType.StoredProcedure;
cmd.CommandTimeout =30;
cmd=accessSql.getStroeProcedureParamsByName(cmd)
foreach(SqlParameter sp in cmd.Parameters)
{
if(values[sp.ParameterName.Substring(1)].ToString()!="" ||values[sp.ParameterName.Substring(1)]!=null)
{
object o=(object)values[sp.ParameterName.Substring(1)];
cmd.Parameters[sp.ParameterName].Value =o;
}
else
{
cmd.Parameters[sp.ParameterName].Value =null;
}

}
return cmd;
}
private Hashtable CreateHashTable(string[] cutkeys,object[] cutvalues)
{
Hashtable newvalues=new Hashtable();
for(int i=0;i<cutkeys.Length;i++)
{
newvalues.Add(cutkeys[i],cutvalues[i]);
Console.WriteLine("key="+cutkeys[i].ToString()+"|value="+cutvalues[i].ToString());
}
return newvalues;
}
public void ExecuteNonQuery(String spname,string[] capation,Object[] values)
{
Hashtable newvalues=this.CreateHashTable(capation,values);
#region build sqlcommand.Parameters and execute command
//SqlConnection conn = new SqlConnection(this.cnnstr);
SqlCommand noretcmd=this.sqlSPCmd(spname,newvalues);
try
{
noretcmd.Connection.Open();
noretcmd.Prepare();
noretcmd.ExecuteNonQuery();
}
catch(SqlException se)
{
throw(se);
}
finally
{
if(noretcmd.Connection.State==ConnectionState.Open )//(conn.State==ConnectionState.Open)
{
noretcmd.Connection.Close();
}
}
#endregion
}  
 
 收藏本文  打印本文  论坛讨论  关闭窗口
· 上一篇:ASP.NET程序中动态修改web.config中的设置项目(后台CS代码)
· 下一篇:自动填充SqlCommand.Parameters的类(2)
· signlog 登陆实现
· 图片上传的Codebehind(自动生成所略图)
· URTracker 2.11版 license验证原理剖析
· .NET Compact Framework的强大二维图形引擎
· 实现HtmlButton客户端控制网页提交


关于本站 | 联系我们 | 业务合作 | 客户案例 | 诚聘英才 | 广告合作 | 收藏本站
海口动网先锋网络科技有限公司版权所有
Copyright © 2000 - 2006 Cndw.Com
中华人民共和国电信与信息服务业务经营许可证编号 琼 ICP 020077