c#操作sql server 2000数据库的类。

原创 2006年05月22日 19:39:00

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

namespace RFID.PublicClass.DataBase
{
 /// <summary>
 /// SqlDB 的摘要说明。
 /// </summary>
 public class SqlDB
 {
  private const string CONKEY = "SqlConnStr";
  private SqlConnection SqlConn=null;
 
  //HttpContext.Current

  /// <summary>
  /// 构造函数
  /// </summary>
  public SqlDB()
  {
   try
   {
    string ConnStr="server=202.200.119.111;database=RFID;uid=sa;pwd=sa";
    SqlConn  = new SqlConnection(ConnStr);
    SqlConn.Open ();
   }
   catch
   {
    
   }
  }
  /// <summary>
  /// 析构函数
  /// </summary>
  ~SqlDB()
  {
   CloseConn();
  }
  /// <summary>
  /// 返回Connection对象
  /// </summary>
  /// <returns></returns>
  public SqlConnection GetConnection()
  {   
   return(SqlConn);
  }
  /// <summary>
  /// 返回Command对象
  /// </summary>
  /// <param name="strsql"></param>
  /// <returns></returns>
  public SqlCommand GetCommand(string strsql)
  {
 
   try
   {
    SqlCommand  SqlComm=new SqlCommand( strsql, SqlConn);

    return(SqlComm);
   }
   catch
   {
    return(null);
   }
  }
  /// <summary>
  ///返回DataAdapter对象
  /// </summary>
  /// <param name="strsql"></param>
  /// <returns></returns>
  public SqlDataAdapter GetDataAdapter(string strsql)
  {
   SqlDataAdapter adp = null;
   try
   {
    adp= new SqlDataAdapter(strsql, SqlConn);
    return(adp);
   }
   catch
   {
    adp = null;
    return(adp);
   }

  }
  /// <summary>
  /// 返回DataReader对象
  /// </summary>
  /// <param name="strsql"></param>
  /// <returns></returns>
  public SqlDataReader GetDataReader( string strsql)
  {
   SqlCommand Comm = null;
   SqlDataReader reader;
   Comm = GetCommand(strsql);
   try
   {
    reader = Comm.ExecuteReader();
   }
   catch
   {
    reader = null;
   }
   return(reader);
  }
  
  /// <summary>
  /// 执行SQL,返回结果值;
  /// </summary>
  /// <param name="strsql"></param>
  /// <returns></returns>
  public string GetDataValue(string strsql)
  {   try
   {
   SqlCommand  Comm;
   Comm=GetCommand(strsql);

    return(Comm.ExecuteScalar().ToString());
  
   }
   catch
   {
    return("");
   }
              
  }
  /// <summary>
  /// 返回DataSet
  /// </summary>
  /// <param name="strsql"></param>
  /// <param name="datasetname"></param>
  /// <returns></returns>
  public DataSet GetDataSet(string strsql, string datasetname)
  {
   SqlDataAdapter Adpt;
   DataSet dsData= new DataSet() ;
   Adpt = GetDataAdapter(strsql);
   try
   {
    Adpt.Fill(dsData, datasetname); 
   }
   catch
   { 
    dsData=null;
   }
   Adpt.Dispose ();
   return (dsData);
  }
  /// <summary>
  /// 执行SQL插入、更新、删除操作
  /// </summary>
  /// <param name="strsql"></param>
  /// <returns></returns>
  public bool Execute(string strsql)
  {
   SqlCommand Comm;
   Comm = GetCommand(strsql);
   try
   {
    Comm.ExecuteNonQuery();
    return(true);
   }
   catch
   {
    return(false);
   }
  }
  /// <summary>
  ///
  /// </summary>
  /// <param name="strsql"></param>
  /// <param name="Parameters"></param>
  /// <param name="DataByte"></param>
  /// <returns></returns>
  public bool Execute(string strsql,string Parameters,byte [] DataByte)
  {
   SqlCommand Comm;
   Comm = GetCommand(strsql);
   try
   {
    Comm.Parameters.Add(Parameters, DataByte);
    Comm.ExecuteNonQuery();
    return(true);
   }
   catch
   {
    return(false);
   }
  }
  //一种执行存储过程的方法
  public bool Execute(string StorageName,string[][] Params)

  {   SqlCommand comm=new SqlCommand();
   comm.Connection = SqlConn;
   comm.CommandType=CommandType.StoredProcedure;
   comm.CommandText=StorageName;
   try
   {
    int count = Params.Length;
    for(int i=0;i<count;i++)
    {
     comm.Parameters.Add(Params[i][0],Params[i][1]).Value = Params[i][2];

    }
                comm.ExecuteNonQuery();
    return(true);

   }
   catch
   {return (false);
   
   }
  }
  //另外一种执行存储过程的方法
  public bool ExecutePro(string StorageName,SqlParameter[] paras)
  {
   SqlCommand comm = new SqlCommand();
   comm.Connection = SqlConn;
   comm.CommandText = StorageName;
   comm.CommandType = CommandType.StoredProcedure;
  try 
  {
   foreach(SqlParameter para in paras)
   {
    comm.Parameters.Add(para);
   }
   comm.ExecuteNonQuery();
   comm.Parameters.Clear();
   comm.Dispose();
   comm = null;
   return(true);
  
  }
  catch(Exception ex)
  {   string err=ex.Message;
    return (false);
  }
  }
 
  public void CloseConn()
  {
   try
   {
    if(SqlConn.ConnectionString !=null)
    {
     SqlConn.Close ();
     SqlConn.Dispose ();
    }
   }
   catch
   {   }
  }
 }
}

相关文章推荐

SQL Server数据库操作类(C#)

  • 2016年11月21日 10:34
  • 8KB
  • 下载

C#操作SQL SERVER数据库的类

  • 2013年09月22日 15:56
  • 4KB
  • 下载

ODBC-C语言操作数据库(SQL Server 2000)(下)

1.SQLBindParameter参数绑定 SQLRETURN SQLBindParameter(                           SQLHSTMT  hstmt,//SQL语句...

SQL Server 2000数据库操作技术

  • 2010年05月15日 15:22
  • 828KB
  • 下载

ODBC-C语言操作数据库(SQL Server 2000)(上)

1.SQLExecDirect直接执行SQL语句 SQLRETURN SQLExecDirect(                            SQLHSTMT  hstmt,//SQL语句...

oracle与sql server2000中不在同一个服务器上的数据库数据操作的方法对比

如何操坐不在同一个数据库中的数据操作: 一。对于SQL server来讲:   1.采用创建链接服务器的方式:     (1).创建链接服务器        exec sp_addli...

C# SQL SERVER数据库操作类

  • 2013年12月24日 20:19
  • 546KB
  • 下载
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:c#操作sql server 2000数据库的类。
举报原因:
原因补充:

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