我积累的数据库操作类(ASP.NET)

转载 2006年06月21日 16:07:00

拿它做了两个项目了,感觉还是很实用,拿出来大家一起学习,都是做项目的时候想到了就写上,肯定有很多地方需要改进,大家多指教。

 

using System;
using System.Web;
using System.Data.SqlClient;
using System.Data;
using System.Configuration;

namespace op_db
{
/// <summary>
/// 专门用来处理与数据库的操作
/// </summary>

    public class db_class
    
{
        
#region 成员
        
private SqlConnection conn=new SqlConnection();
        
/// <summary>
        
/// 私有成员
        
/// </summary>

        private string _sql;
        
/// <summary>
        
/// 属性:数据库查询语句
        
/// </summary>

        private string _er;
        
public string er
        
{
            
get{return _er;}
            
        }

        
public string sql
        
{
            
get{return _sql;}
            
set{_sql=value;}
        }

        
#endregion



        
#region 函数

        
/// <summary>
        
/// 构造函数
        
/// </summary>

        public db_class()
        
{
            
//
            
// TODO: 在此处添加构造函数逻辑
            
//
            conn.ConnectionString=System.Configuration.ConfigurationSettings.AppSettings["constr"].ToString();
        }

        
/// <summary>
        
/// 析构函数
        
/// </summary>

        ~ db_class()
        
{
            
if (conn.State==ConnectionState.Open)
            conn.Close();
        }


        
/// <summary>
        
/// 打开数据库连接
        
/// </summary>

        public void db_open()
        
{
            
try
            
{
                
if (conn.State==ConnectionState.Closed)
                
{
                    conn.ConnectionString
=System.Configuration.ConfigurationSettings.AppSettings["constr"].ToString();
                    conn.Open();
                }

            }

            
catch(Exception ex)
            
{
                
//System.Web.HttpContext.Current.Response.Redirect(System.Configuration.ConfigurationSettings.AppSettings["conn_admin"].ToString());
                System.Web.HttpContext.Current.Response.Write(ex.Message);
                System.Web.HttpContext.Current.Response.End();
            }


        }


        
/// <summary>
        
/// 关闭数据库连接
        
/// </summary>

        public void db_close()
        
{
            
if (conn.State==ConnectionState.Open){
                conn.Close();
                conn.Dispose();
            }

        }



        
/// <summary>
        
/// 执行非返回型查询语句
        
/// </summary>
        
/// <returns>是否执行成功</returns>

        public bool executesql()
        
{
            SqlCommand cmd
=new SqlCommand(_sql,conn);
            
this.db_open();
            
try
            
{
                cmd.ExecuteNonQuery();
                
this.db_close();
                
return true;
            }

            
catch(Exception ex)
            
{
                
this.db_close();
                System.Web.HttpContext.Current.Response.Write(ex.Message);
                System.Web.HttpContext.Current.Response.End();
                
return false;
            }


        }


        
/// <summary>
        
/// 执行返回datareader的数据库查询
        
/// </summary>
        
/// <returns>datareader对象</returns>

        public SqlDataReader executereader()
        
{
            SqlCommand cmd
=new SqlCommand(_sql,conn);
            
this.db_open();
            SqlDataReader dr;
            
try
            
{
                dr
=cmd.ExecuteReader(CommandBehavior.CloseConnection);//参数表示关闭datagrid对象就会关闭connection对象
                if (dr.HasRows==true)
                
{
                    
return dr;
                }

                
else
                
{
                    _er
="数据为空";
                    
return null;
                }

            }

            
catch
            
{
                _er
="语句错误";
                
return null;
            }

        }



        
/// <summary>
        
/// 将sql语句返回为dataview
        
/// </summary>
        
/// <returns>dataview对象</returns>

        public DataView executedv()
        
{
            System.Data.SqlClient.SqlDataAdapter da
=new SqlDataAdapter(_sql,conn);
            DataSet ds
=new DataSet();
            
this.db_open();
            
try
            
{
                da.Fill(ds,
"tb");
                DataView dv
=new DataView(ds.Tables["tb"]);
                
if (dv.Count>0)
                
{
                    
this.db_close();
                    
return dv;
                }

                
else
                
{
                    
this.db_close();
                    _er
="数据出错";
                    
return null;
                }

            }

            
catch
            
{
                _er
="数据出错";
                
return null;
            }

            
finally
            
{
                
this.db_close();
            }

        }


        
/// <summary>
        
/// 将只返回一条记录的sql语句执行并且返回结果
        
/// </summary>
        
/// <param name="def">如果没有记录的话的默认值</param>
        
/// <returns>返回结果为string</returns>

        
        
public string sql2str(string def)
        
{
            
string rr="";
            SqlCommand cmd
=new SqlCommand(_sql,conn);
            System.Data.SqlClient.SqlDataReader dr;
            
this.db_open();
            
try
            
{
                dr
=cmd.ExecuteReader(CommandBehavior.CloseConnection);
                
if(dr.HasRows)
                
{
                    dr.Read();
                    rr
=dr[0].ToString();
                    dr.Close();
                    
this.db_close();
                }

            }

            
catch
            
{
                rr
="";
            }

            
finally{this.db_close();}
            
if(rr=="")
                rr
=def;
            
return rr;
        }



        
/// <summary>
        
/// 执行返回BOOL的存储过程
        
/// </summary>
        
/// <returns>是否执行成功</returns>

        public bool exepro()
        
{
            
this.db_open();
            SqlCommand cmd
=new SqlCommand(_sql,conn);
            cmd.CommandType
=CommandType.StoredProcedure;
            
try
            
{
                cmd.ExecuteNonQuery();
                
this.db_close();
                
return true;
            }

            
catch
            
{
                
this.db_close();
                
return false;
            }


        }

        
#endregion

    }

}

 

http://guanvee.cnblogs.com/archive/2006/06/16/427510.html

ASP.NET 母版页与内容页 修改、加载、调用控件等问题汇总

一、使用多种方式为内容页加载母版页 默认情况下是给单个内容页指定一个母版页加载,当多个内容页需加载到同一个母版页时,我们可以通过配置文件为多个内容页批量加载母版页,另外,还可以在PreInit事件中...
  • VS_URL
  • VS_URL
  • 2012年06月03日 15:27
  • 2411

【Monogdb】MongoDB之十大应用设计技巧

技巧一、速度和完整性的折中  在多个文档中使用的数据可以采用内嵌(反范式话)的方式,也可以采用引用(范式化)的方式。这种策略并没有优劣之分,各自都有优缺点。关键是要选择适合自己的应用场景方案。 反范式...

asp.net数据库操作类

  • 2010年12月08日 19:38
  • 13KB
  • 下载

C# asp.net 以XML为数据库操作的类

  • 2012年10月20日 16:39
  • 86KB
  • 下载

ASP.NET数据库操作类——打包

using System; using System.Data; using System.Data.SqlClient; using System.Configuration; ...

asp.net(C#) 数据库操作类

using System; using System.Data; using System.Configuration; using System.Web; using System.Web....
  • neso520
  • neso520
  • 2011年09月22日 23:27
  • 216

Asp.net中有关数据库操作的定义类 DataControl

一、不管是Asp.net、C#还是其他开发语言,都必不可少的用到数据库方面的操作,执行数据库表的增、删、改、查,这就需要我们定义一个数据库操作类,方便程序中调用,简化操作。 1.下面定义一个Data...

asp.net数据库操作类--DbHelper.cs

其实,微软的企业库中有一个非常不错的数据操作类了。但是,不少公司(起码我遇到的几个...),对一些"封装"了些什么的东西不太敢用,虽然我推荐过微软的企业库框架了...但是还是要"评估"...一评就是几...

ASP.NET数据库操作类

using System; using System.Data; using System.Configuration; using System.Web; using System.Web....

ASP.NET MongoDB数据库操作类

1、Web.config文件中配置数据库连接信息,如下代码:                    -->                                -->...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:我积累的数据库操作类(ASP.NET)
举报原因:
原因补充:

(最多只允许输入30个字)