2024年3月31日发(作者:)

关于数据库编程,微软提供了一个统一的数据对象访问模型,在Visual Studio6.0中称为ADO,在.NET

中则统一为,掌握就等于掌握了数据库编程的核心。针对数据库编程始终是程序设计语言

的一个重要方面的内容,也是一个难点。数据库编程的内容十分丰富,但最为基本编程的也就是那么几点,

譬如:连接数据库、得到需要的数据和针对数据记录的浏览、删除、修改、插入等操作。其中又以后面针

对数据记录的数据操作为重点。本文就来着重探讨一下Visual C#数据库基本编程,即:如何浏览记录、

修改记录、删除记录和插入记录。

一.程序设计和运行的环境设置:

(1).视窗2000服务器版

(2).Microsoft Data Acess Component 2.6 以上版本 ( MDAC 2.6 )

(3)..Net FrameWork SDK Beta 2

为了更清楚的说明问题,在数据库的选用上,采用了当前比较典型的数据库,一个是本地数据库Access

2000,另外一个是远程数据库Sql Server 2000。其中本地数据库名称为"",在其中定义了一张数

据表"person","person"表的数据结构如下表:

字段名称

id

xm

< xb

nl

zip

字段类型

数字

文本

文本

文本

文本

字段意思

序号

姓名

性别

年龄

邮政编码

远程数据库Sql Server 2000的数据库服务器名称为"Server1",数据库名称为"Data1",登陆的ID为

"sa",口令为空,在数据库也定义了一张"person"表,数据结构如上表。

二.如何浏览数据:

在《Visual C#的数据绑定》中,已经了解了如何把数据集中的某些字段绑定到WinForm组件的某个属

性上,这样程序员就可以根据以WinForm组件的来定制数据显示的形式,并且此时的WinForm组件显示内

容就可以随着记录指针的变化而改变。至此可见,浏览数据记录的关键就是如何改变记录指针。要实现这

种操作,就要使用到BindingManagerBase类,此类的主要作用是管理对于那些实现了对同一个数据源进行

绑定的对象。说的具体些,就是能够使得Windows窗体上的已经对同一数据源进行数据绑定的组件保持同

步。在BindingManagerBase类中定义了一个属性"Position",通过这个属性就可以改变

BindingManagerBase对象中的数据指针。创建BindingManagerBase对象必须要使用到BindingContext类,

其实每一个由Control类中继承而得到的对象,都有单一的BindingContext对象,在大多数创建窗体中实

现数据绑定组件的BindingManagerBase对象是使用Form类的BindingContext来得到。下列代码是以

Access 2000数据库为模型,创建的一个名称为"myBind"的BindingManagerBase对象。

//创建一个 OleDbConnection

string strCon = " Provider = .4.0 ; Data Source = " ;

OleDbConnection myConn = new OleDbConnection ( strCon ) ;

string strCom = " SELECT * FROM person " ;

file://创建一个 DataSet

myDataSet = new DataSet ( ) ;

( ) ;

file://用 OleDbDataAdapter 得到一个数据集

OleDbDataAdapter myCommand = new OleDbDataAdapter ( strCom , myConn ) ;

file://把Dataset绑定books数据表

( myDataSet , "person" ) ;

file://关闭此OleDbConnection

( ) ;

myBind = gContext [ myDataSet , "person" ] ;

下列代码是以Sql Server 2000数据库为模型,创建一个名称为"myBind"的BindingManagerBase对象。

//设定数据连接字符串,此字符串的意思是打开Sql server数据库,

//服务器名称为server1,数据库为data1

string strCon = "Provider = SQLOLEDB.1 ; Persist Security Info = False ;

User ID = sa ; Initial Catalog = data1 ; Data Source = server1 " ;

OleDbConnection myConn = new OleDbConnection ( strCon ) ;

( ) ;

string strCom = " SELECT * FROM person " ;

file://创建一个 DataSet

myDataSet = new DataSet ( ) ;

file://用 OleDbDataAdapter 得到一个数据集

OleDbDataAdapter myCommand = new OleDbDataAdapter ( strCom , myConn ) ;

file://把Dataset绑定person数据表

( myDataSet , " person " ) ;

file://关闭此OleDbConnection

( ) ;

myBind = gContext [ myDataSet , "person" ] ;

到了是同一数据源的BindingManagerBase对象,通过改变此对象的"Position"属性值,这样绑定数据的组

件显示的数据就随之变化,从而实现导航数据记录。

< I > .导航按钮"上一条"实现方法:

protected void GoPrevious ( object sender , rgs e )

{

if ( on == 0 )

( "已经到了第一条记录!" , "信息提示!" ,

, ation

) ;

else

on -= 1 ;

}<

< II > . 导航按钮"下一条"实现方法:

protected void GoNext ( object sender , rgs e )

{

if ( on == -1 )

( "已经到了最后一条记录!", "信息提示!" ,

, ation

) ;

else

on += 1 ;

}

< III > . 导航按钮"至尾"实现方法:

protected void GoLast ( object sender , rgs e )

{

on = - 1 ;

}

< IV > . 导航按钮"至首"实现方法:

protected void GoFirst ( object sender , rgs e )

{

on = 0 ;

}