开发者社区> 老朱教授> 正文

第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的讲解,那才是一个完整的数据库访问教程。




本文转自齐师傅博客园博客,原文链接:http://www.cnblogs.com/youring2/archive/2010/05/15/1736424.html,如需转载请自行联系原作者

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
删除 PostgresSql 数据库 报错:有 N 个其它会话正在使用数据库 的解决方案
遇到的问题 在PostgreSQL 9.2 及以上版本,执行下面的语句: postgres=# drop database dbtest; # 执行删除指定数据库的时候,报以下错误 ERROR: database "dbtest" is being accessed by other users DETAIL: There is 2 other session using the database. 或者使用 Navicat 等第三方数据库连接工具,删除指定数据库的时候报错,说明此时有两个客户端在连接此数据库,此时不能删除数据库。
150 0
SpringBoot使用数据库
这一篇简单介绍一下SpringBoot配置数据库的配置(依赖和application.properties),以下全是以本地数据库为例子,具体用户名密码地址都根据实际去修改。
1441 0
阿里云MySQL云数据库和Redis6.0数据库使用体验
阿里云MySQL云数据库和Redis6.0数据库使用体验
1901 0
阿里云服务器怎么设置密码?怎么停机?怎么重启服务器?
如果在创建实例时没有设置密码,或者密码丢失,您可以在控制台上重新设置实例的登录密码。本文仅描述如何在 ECS 管理控制台上修改实例登录密码。
18239 0
阿里云ECS云服务器初始化设置教程方法
阿里云ECS云服务器初始化是指将云服务器系统恢复到最初状态的过程,阿里云的服务器初始化是通过更换系统盘来实现的,是免费的,阿里云百科网分享服务器初始化教程: 服务器初始化教程方法 本文的服务器初始化是指将ECS云服务器系统恢复到最初状态,服务器中的数据也会被清空,所以初始化之前一定要先备份好。
13666 0
阿里云服务器如何登录?阿里云服务器的三种登录方法
购买阿里云ECS云服务器后如何登录?场景不同,阿里云优惠总结大概有三种登录方式: 登录到ECS云服务器控制台 在ECS云服务器控制台用户可以更改密码、更换系.
23610 0
使用数据库悲观锁实现不可重入的分布式锁
一、前言 在同一个jvm进程中时,可以使用JUC提供的一些锁来解决多个线程竞争同一个共享资源时候的线程安全问题,但是当多个不同机器上的不同jvm进程共同竞争同一个共享资源时候,juc包的锁就无能无力了,这时候就需要分布式锁了。
10876 0
阿里云ECS云服务器初始化设置教程方法
阿里云ECS云服务器初始化是指将云服务器系统恢复到最初状态的过程,阿里云的服务器初始化是通过更换系统盘来实现的,是免费的,阿里云百科网分享服务器初始化教程: 服务器初始化教程方法 本文的服务器初始化是指将ECS云服务器系统恢复到最初状态,服务器中的数据也会被清空,所以初始化之前一定要先备份好。
13830 0
+关注
3546
文章
0
问答
文章排行榜
最热
最新
相关电子书
更多
OceanBase 入门到实战教程
立即下载
阿里云图数据库GDB,加速开启“图智”未来.ppt
立即下载
实时数仓Hologres技术实战一本通2.0版(下)
立即下载