C# 访问数据库的用法

C#访问数据库无疑是非常方便的,下面给出了C#访问MSSQL的基本方法。

 

首先声明命名空间using System.Data.SqlClient;

再使用SqlConnection类连接,SqlCommand类执行SQL命令,结果返回给SqlDataReader类或其它类。

 

各类的基本用法介绍:

SqlConnection

在构造时传入连接数据库字符串,也可以定义后通过ConnectionString属性来设置。

用Open()连接数据库,用Close()关闭连接。

 

SqlCommand

在构造时传入SQL命令和SqlConnection类对象,也可以定义后通过CommandText属性和Connection属性来设置。

执行SQL命令并得到结果                 SqlDataReader ExecuteReader()

执行SQL命令并得到受影响的行数    int ExecuteNonQuery()

 

SqlDataReader

得到共有多少列          FieldCount属性

得到第i列的列名         string GetName(int i)

得到第i列的数据类型  Type GetFieldType(int i)

判断第i列是否为空     bool IsDBNull(int i)

得到第i列的数据        Object GetValue(int i)也可以直接sr[i].ToString()

前进到下一列            bool Read()

关闭                         void Close()

 

 

对于每个关联的 SqlConnection,一次只能打开一个 SqlDataReader,在第一个关闭之前,打开另一个的任何尝试都将失败。类似地,在使用 SqlDataReader 时,关联的 SqlConnection 正忙于为它提供服务,直到调用 Close()时为止。

 

下面一些示例代码:

[csharp] view plain copy
  1. //连接数据库  
  2. string SQLCONNECT = @"server=PC-200907281720\SQLEXPRESS;database=master;uid=morewindows;pwd=12345";  
  3. SqlConnection conn = new SqlConnection(SQLCONNECT);  
  4. conn.Open();  
  5.   
  6. //连接数据库之后就可以执行SQL命令了  
  7. //使用SqlCommand类的ExecuteReader()返回执行的结果  
  8. string SQLCOMMAND = "select CName, names, C4.LastLogin from C4, S4 where C4.LastLogin = S4.LastLogin order by CName, names";  
  9. SqlCommand sqlcmd = new SqlCommand(SQLCOMMAND, conn);  
  10. SqlDataReader sr = sqlcmd.ExecuteReader();  
  11.   
  12. Console.WriteLine("列数:" + sr.FieldCount);     
  13.           
  14. Console.WriteLine("列类型分别为:");   
  15. int nSqlCol = sr.FieldCount;  
  16. for (int i = 0; i < nSqlCol; ++i)  
  17. Console.Write(sr.GetFieldType(i) + " ");  
  18. Console.WriteLine();  
  19.   
  20. while (sr.Read())  
  21. {  
  22. for (int i = 0; i < nSqlCol; i++)  
  23. Console.Write(sr[i].ToString() + " ");  
  24. Console.WriteLine();  
  25. }  
  26. sr.Close();  
  27.   
  28. //通过SqlCommand 类的ExecuteNonQuery()来返回受影响的行数。  
  29. string SQLCOMMAND2 = "update dbo.Messages set MessageNum='15' where MessageID='2'";  
  30. SqlCommand sqlcmd2 = new SqlCommand(SQLCOMMAND2, conn);//也可以用sqlcmd. ConnectionString = SQLCOMMAND2 代替  
  31. int nResult = sqlcmd2.ExecuteNonQuery();  
  32. Console.WriteLine("受影响行数:" + nResult);  
  33.   
  34. conn.Close();  

 

 

在VC++中,可以使用ADO方式访问数据库,请参阅《VC++ ADO方式访问数据库简要笔记


  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值