第05篇:C#星夜拾遗之使用数据库

前言

C#常用来开发数据管理类软件,所以学会在C#程序中使用数据库是非常有必要的。目前微软的两个常用数据库软件分别是AccessSql Server。读者可以自行了解这两种数据库的优劣点,笔者不做过多说明。这两种数据库也是在做开发时最常用的。

C#访问数据库是通过ADO.NET实现的。ADO.NET 是一组向 .NET Framework 程序员公开数据访问服务的类。ADO.NET 为创建分布式数据共享应用程序提供了一组丰富的组件。它提供了对关系数据、XML 和应用程序数据的访问,因此是 .NET Framework 中不可缺少的一部分。ADO.NET 支持多种开发需求,包括创建由应用程序、工具、语言或 Internet 浏览器使用的前端数据库客户端和中间层业务对象。

MSFramework 3.5中提供了Linq to Sql技术,但本文不做探讨,感兴趣的朋友可以阅读《LINQ体验系列文章导航》。本文将以Sql Server为例,介绍最基本是数据库使用方法:数据库连接、数据库命令、Sql语句、适配器、DataSet等。如果你已经了解了这些内容,那么请关掉这篇文章,笔者对于浪费你的宝贵时间表示歉意 :

 

数据库连接

1、  引用命名控件System.Data, 并添加System.Data.SqlClient引用。

2、  获取连接字符串。这个字符串通常被放在App.config文件中;在Asp.NET程序里放在web.config文件中。你可以通过VS 2008 自动生成这个连接字符串。步骤如下:“数据”菜单项 > 添加数据源 > 选择“数据库”,下一步 > 点击“新建连接”> 在列表中选择“Microsoft Sql Server”,单击“继续”。这时会弹出一个“添加连接”的窗口,在这里选择Sql Server服务器,如果是本机,则填写(Local),或者点一个点即可。这里需要注意的是,如果你安装的是Express 2005版,需要填写 .\SqlExpress。接下来是选择登陆方式,笔者建议初学者使用Windows身份验证。然后选择数据库,选择完成数据库后即可点击“确定”按钮。这时回到了“选择数据库连接”窗口,点开折叠的连接字符串部分,这里面的字符串就是一个Sql Server连接字符串了。(Access也是这个步骤,自己试试吧。)

3、  使用这个字符串初始化一个数据库连接对象。Sql Server 连接类是SqlConnection,我们可以使用下面的代码实例化一个数据库连接对象:

SqlConnection sqlConn = new SqlConnection(connectionString);

connectionString 是上一步生成的连接字符串。如果不在构造函数中初始化连接字符串,也可以在先实例化一个对象,然后设置ConnectionString属性。代码如下:

SqlConnection sqlConn = new SqlConnection();

sqlConn.ConnectionString = connectionString;

 

数据库命令

1、  数据库命令在C#中使用类SqlCommand表示。SqlCommand类表示要对 SQL Server 数据库执行的一个 Transact-SQL 语句或存储过程。此类无法继承。

2、  实例化一个SqlCommand类,需要一个可用的数据库连接和一个可执行的Sql语句。代码如下:

SqlCommand sqlCmd = new SqlCommand(sqlText,, sqlConn);

sqlText为可执行的Sql语句,sqlConn为一个可用的数据库连接

也可以在实例化SqlCommand对象后,设置CommandText属性和Connection属性。相应的代码如下:

SqlCommand  sqlCmd = new SqlCommand();

sqlCmd.CommandText = sqlText;

sqlCmd.Connection = sqlConn;

 

Sql语句

如果你不了解Sql语句,那麻烦可就大了,赶快翻书吧,查查Sql语句该如何书写。如果想整点儿速成的东西,这里也只能给出几个简单的语句:

1、  Select语句:作用是从数据库中查询数据。如果你的数据库中有一个名为 books 的数据表,当要从books 中查询出所有数据时,你就可以这样写:

Select * From books;

如果只想从books中查询BookName(名称)和BookAuthor(作者)两个字段,可以这样写:

Select BookName, BookAuthor From books;

注:Sql语句是不区分大小写的。

如果你只想查询名称为《C#星夜拾遗》的书,则可以使用Where进行条件查询:

Select BookName, BookAuthor From books Where BookName = ‘C#星夜拾遗》’;

2、  Insert 语句:作用是向数据库中插入一条数据。例如有一本书名为《C#星夜拾遗》,作者为齐飞的书,你就可以使用下面的语句插入数据库:

Insert into books (BookName, BookAuthor) Values (‘C#星夜拾遗》’, ‘齐飞’);

3、  Update语句:作用是更新一条数据库中的数据,例如需要将《C#星夜拾遗》这本书的Price字段更新为39,那么Sql语句应该这样写:

Update books set Price=39 Where BookName=’C#星夜拾遗》’;

注意,这里的Where条件很关键,如果不加Where条件,则会将整个数据表中所有行的Price都更新为39

4、  Delete语句:作用是删除记录。下面来删除书名为《C#星夜拾遗》的记录:

Delete From books Where BookName=’C#星夜拾遗》’;

注意,这里的Where同样很关键,如果去掉,则会删除数据表中的所有行。

 

适配器和DataSet

相对与Sql Server的数据适配器是SqlDataAdapter,这个适配器的作用是执行一些辅助的工作,例如填充DataSet等。下面的语句将使用一个SqlDataAdapter填充一个DataSet

SqlDataAdapter da = new SqlDataAdapter();

da.SelectCommand = sqlCmd;

DataSet ds = new DataSet();

da.Fill(ds);

注意:在执行Sql语句时,都需要一个打开的数据库连接,也就是需要以编程的方式打开数据库连接,代码为 sqlConn.Open();当连接使用完成后,再显示的将数据库关闭,代码为:sqlConn.Close();但是这里为什么没有呢?因为SqlDataAdapter已经帮我们完成了这部分操作。

回过头来说一下DataSetDataSet ADO.NET 结构的主要组件,它是从数据源中检索到的数据在内存中的缓存。DataSet 由一组 DataTable 对象组成,您可使这些对象与 DataRelation 对象互相关联。您还可通过使用 UniqueConstraint ForeignKeyConstraint 对象在 DataSet 中实施数据完整性。

我们可以将DataSet看成是一个数据表的集合,当我们使用SqlDataAdapterDataSet进行数据填充后,DataSet将保存我们检索到的数据,方便我们使用。

下面假定数据表books 中存在一条BookName为《C#星夜拾遗》,BookAuthor为齐飞、Price 39的记录,我们的Select语句为:

Select BookName, BookAuthor,Price From books Where BookName = ‘C#星夜拾遗》’;

当使用上面的方法进行数据填充后,我们可以使用如下代码得到DataSet中的数据:

if (ds.Tables[0].Rows.Count > 0)

{

    foreach (DataRow dr in ds.Tables[0].Rows)

    {

        string strBookName = dr["BookName"].ToString();

        string strAuthor = dr["BookAuthor"].ToString();

        double dPrice = Convert.ToDouble(dr["Price"]);

    }

}

 

结束语

本文只对数据库的访问和简单Sql的使用进行了说明,初学者朋友可以尝试一下书中提到的例子,由于时间仓促,没有将代码整理为Demo,还望朋友们见谅。这些内容只是ADO.NET的皮毛,如果想深入了解,除了多练习之外,还要看看MSDN中对于ADO.NET的讲解,那才是一个完整的数据库访问教程。

 

 

 

posted @ 2010-05-15 22:01  拓荒者FF  阅读(625)  评论(0编辑  收藏  举报