C#写的数据库操作类!

王朝c#·作者佚名  2006-01-09
窄屏简体版  字體: |||超大  

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

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();

}

}

}

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
 
 
© 2005- 王朝網路 版權所有 導航