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

 C#写的数据库操作类!

作者:郁郁小蝎 来源:中国站长学院 
阅读 3409 人次 , 2006-2-15 14:31:00 

        由于某些原因,软件依赖的数据库软件会出现更换!如果数据库的打开和操作代码都出现在每个页里,那么更换数据库软件后带来的代码修改将相当麻烦。所以把数据库操作代码写成一个类,将不会出现上述情况并可以减少代码量。以下是源码

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

namespace news.common
{
 /**
  * -----------------
  * 数据库联接 / 操作类
  * 2005-03-18 创建
  * Ryan_bin@126.com
  * ----------------
  */

 public class DBClass
 {
  /*----全局变量定义------*/

  private SqlConnection     conn;   
  private SqlCommand    comm;   
  public  SqlDataReader         dr;
  public  DataSet                      ds;
  public  SqlDataAdapter      dad;
  private string                         sql;
  private string                 connStr;   /* 数据库联接字符串 */
  private string              errInfo ="";
  /*----------------------*/

  public DBClass()
  {
  }
  /* 数据库操作异常信息 只读属性 */
  public string ErrInfo
  {
   get
   {
    return errInfo;
   }
  }
  /* 要操作的Sql语句 */
  public string Sql
  {
   get{
    return sql;
   }
   set{
    sql = value;
   }
  }
  /* 数据库链接字符串 */
  public string ConnStr
  {
   get
   {
    return connStr;
   }
   set
   {
    connStr = value;
   }
  }
  private void connDb()
  {
   conn = new SqlConnection(connStr);
   try
   {
    conn.Open();
   }
   catch(SqlException e)
   {
    for(int i=0;i<e.Errors.Count;i++)
    {
     errInfo += "错误序号:"+i+"\n"+
                       "出错信息:"+e.Errors[i].Message+"\n"+
                       "出错来源:"+e.Errors[i].Source+"\n"+
                       "程序:"+e.Errors[i].Procedure;
    }
    conn.Close();
   }
  }
  /* 用于窗体绑定 */
  public void dataView()
  {
   connDb();
   dad = new SqlDataAdapter(sql,conn);
   ds  = new DataSet();
   dad.Fill(ds);
   DataView dv = new DataView(ds.Tables[0]);
  }
  /* 执行SQL语句,返回结果 */
  public void readerData()
  {
   connDb();
   comm = new SqlCommand(sql,conn);
   dr   = comm.ExecuteReader();
  }
  /* 执行SQL语句,不返回结果 */
  public void exeSql()
  {
   connDb();
   comm = new SqlCommand(sql,conn);
   comm.ExecuteNonQuery();
  }
  /* 关闭链接 */
  public void clear()
  {
   conn.Close();
  }
 }
}

  
 本文Tags数据库  C#  
 收藏本文  打印本文  论坛讨论  关闭窗口
· 上一篇:在RichTextBox控件加入图片
· 下一篇:使用响应文件编译C#源文件
· 自动生成SERVER CONTROLS在程序里的应用
· 开心就贴(四)
· .NET体系中的源程序安全问题(4)
· 十天学会ASP.net(5)
· 关于C# 查询 功能的实现代码


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