Visual C# 数据库编程实战(详细)

发布时间:2024-10-11

Visual C# 数据库编程实战(详细)

实战

实战实战

实战Visual C#

##

#数据库编程

数据库编程数据库编程

数据库编程(

((

(上

上上

上)

))

http://www.77cn.com.cn 3/29/2003 C#CN

[编者的话:]关于数据库编程,微软提供了一个统一的数据对象访问模型,在Visual

Studio6.0中称为ADO,在.NET中则统一为http://www.77cn.com.cn,掌握http://www.77cn.com.cn就等于掌握了数据

库编程的核心,因此有必要首先复习一下以前发表的《http://www.77cn.com.cn完全攻略》。 针对数据库编程始终是程序设计语言的一个重要方面的内容,也是一个难点。数据

库编程的内容十分丰富,但最为基本编程的也就是那么几点,譬如:连接数据库、得到

需要的数据和针对数据记录的浏览、删除、修改、插入等操作。其中又以后面针对数据

Visual C# 数据库编程实战(详细)

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

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

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

(1).视窗2000服务器版

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

(3)http://www.77cn.com.cn FrameWork SDK Beta 2

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

是本地数据库Access 2000,另外一个是远程数据库Sql Server 2000。其中本地数据库

名称为"db.mdb",在其中定义了一张数据表"person","person"表的数据结构如下表:

字段名称 字段类型 字段意思

id 数字 序号

xm 文本 姓名

xb 文本 性别

nl 文本 年龄

zip 文本 邮政编码

远程数据库Sql Server 2000的数据库服务器名称为"Server1",数据库名称为 "Data1",登陆的ID为"sa",口令为空,在数据库也定义了一张"person"表,数据结构

如上表。

二.如何浏览数据:

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

Visual C# 数据库编程实战(详细)

WinForm组件的某个属性上,这样程序员就可以根据以WinForm组件的来定制数据显示

的形式,并且此时的WinForm组件显示内容就可以随着记录指针的变化而改变。至此可

见,浏览数据记录的关键就是如何改变记录指针。要实现这种操作,就要使用到

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

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

定的组件保持同步。在BindingManagerBase类中定义了一个属性"Position",通过这个xm.Text + "' , xb = '"

+ t_xb.Text + "' , nl = " 鯏D \ 属性就可以改变BindingManagerBase对象中的数据指针。创建BindingManagerBase对

象必须要使用到BindingContext类,其实每一个由Control类中继承而得到的对象,都

有单一的BindingContext对象,在大多数创建窗体中实现数据绑定组件的 BindingManagerBase对象是使用Form类的BindingContext来得到。下列代码是以

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

//创建一个 OleDbConnection

string strCon = " Provider = Microsoft.Jet.OLEDB.4.0 ; Data Source = db.mdb" ; OleDbConnection myConn = new OleDbConnection ( strCon ) ;

string strCom = " SELECT * FROM person " ;

file://创建一个 DataSet

Visual C# 数据库编程实战(详细)

myDataSet = new DataSet ( ) ;

myConn.Open ( ) ;

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

OleDbDataAdapter myCommand = new OleDbDataAdapter ( strCom , myConn ) ; file://把Dataset绑定books数据表

myCommand.Fill ( myDataSet , "person" ) ;

file://关闭此OleDbConnection

myConn.Close ( ) ;

myBind = this.BindingContext [ 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 ) ;

myConn.Open ( ) ;

string strCom = " SELECT * FROM person " ;

file://创建一个 DataSet

myDataSet = new DataSet ( ) ;

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

OleDbDataAdapter myCommand = new OleDbDataAdapter ( strCom , myConn ) ; file://把Dataset绑定person数据表

myCommand.Fill ( myDataSet , " person " ) ;

file://关闭此OleDbConnection

Visual C# 数据库编程实战(详细)

myConn.Close ( ) ;

myBind = this.BindingContext [ myDataSet , "person" ] ;

得到了是同一数据源的BindingManagerBase对象,通过改变此对象的"Position"

属性值,这样绑定数据的组件显示的数据就随之变化,从而实现导航数据记录。 , xb = '"

+ t_xb.Text + "' , nl = " 鯏D \ < I > .导航按钮"上一条"实现方法: protected void GoPrevious ( object sender , System.EventArgs e )

{

if ( myBind.Position == 0 )

MessageBox.Show ( "已经到了第一条记录!" , "信息提示!" , MessageBoxButtons.OK ,

http://www.77cn.com.cnrmation ) ;

else

myBind.Position -= 1 ;

}

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

protected void GoNext ( object sender , System.EventArgs e )

{

if ( myBind.Position == myBind.Count -1 )

MessageBox.Show ( "已经到了最后一条记录!", "信息提示!" , MessageBoxButtons.OK ,

http://www.77cn.com.cnrmation ) ;

else

myBind.Position += 1 ;

}

Visual C# 数据库编程实战(详细)

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

protected void GoLast ( object sender , System.EventArgs e )

{

myBind.Position = myBind.Count - 1 ;

}

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

protected void GoFirst ( object sender , System.EventArgs e )

{

myBind.Position = 0 ;

}

注释:"Count"是BindingManagerBase对象的另外一个重要的属性,是数据集记录

的总数。 实战

实战实战

实战Visual C#

##

#数据库编程

数据库编程数据库编程

数据库编程(

((

(中

中中

中)

))

http://www.77cn.com.cn 3/29/2003 C#CN

Visual C# 数据库编程实战(详细)

三.实现删除记录: </P><P> 在对数据记录进行操作的时候,有二点必须十分清晰:

</P><P> 其一:在对数据记录进行操作的时候,我想有一些程序员一定有这样一个

疑惑,当对数据库服务器请求数据集的时候,就会产生"DataSet"对象,用以管理数据集,

这样如果这些对数据库服务器的请求非常多,同样也就会产生很多的"DataSet"对象,达ind.Position += 1 ; 到一定时候必然会使得数据库服务器崩溃。这种想法是自然的,但和实际并不相符,因

为"DataSet"对象并不是在服务器端产生的,而是在客户端产生的。所以面对众多的数据

请求的时候对数据库服务器的影响并不十分太大。 </P><P> 其二:记得在用Delphi

编写三层数据模型的时候的,每一次对数据库的修改其实只是对第二层产生的数据集的

修改,要真正修改数据库,还必须调用一个另外的方法。在用http://www.77cn.com.cn处理数据库的

时候,虽然处理的直接对象是数据库,但此时"DataSet"对象中的内容并没有随之改变,

而绑定的数据组件显示的数据又来源于"DataSet"对象,这样就会产生一个错觉,就是修

改了的记录并没有修改掉,删除的记录并没有删除掉。所以对数据记录进行操作的时候,

在修改数据库后,还要对"DataSet"对象进行必要的修改,这样才能保证"DataSet"对象和

Visual C# 数据库编程实战(详细)

数据库内容一致、同步。下面代码是删除当前绑定组件显示的记录的程序代码,此代码

是以Access 2000数据库为模板的: </P><P>protected void Delete_record ( object sender ,

System.EventArgs e )

{

DialogResult r = MessageBox.Show ( "是否删除当前记录!" , "删除当前记录!" , MessageBoxButtons.YesNo , MessageBoxIcon.Question ) ;

int ss = ( int ) r ;

if ( ss == 6 ) // 按动"确定"按钮

{

try{

file://连接到一个数据库

string strCon = " Provider = Microsoft.Jet.OLEDB.4.0 ; Data Source = db.mdb " ; OleDbConnection myConn = new OleDbConnection ( strCon ) ;

myConn.Open ( ) ;

string strDele = "DELETE FROM person WHERE id= " + t_id.Text ;

OleDbCommand myCommand = new OleDbCommand ( strDele , myConn ) ; file://从数据库中删除指定记录

myCommand.ExecuteNonQuery ( ) ;

file://从DataSet中删除指定记录

myDataSet.Tables [ "person" ] . Rows [ myBind.Position ] . Delete ( ) ;

myDataSet.Tables [ "person" ] . AcceptChanges ( ) ;

myConn.Close ( ) ;

}

catch ( Exception ed )

Visual C# 数据库编程实战(详细)

{

MessageBox.Show ( "删除记录错误信息: " + ed.ToString ( ) , "错误!" ) ; }

}

} </P><P> 下面代码是删除当前绑定组件显示的记录的程序代码,此代码是以Sql

Server 2000数据库为模板的,二者的区别仅仅在于数据链接: </P><P>protected void

Delete_record ( object sender , System.EventArgs e )

{

DialogResult r = MessageBox.Show ( "是否删除当前记录!" , "删除当前记录!" , MessageBoxButtons.YesNo , MessageBoxIcon.Question ) ;

int ss = ( int ) r ; int ) r ; if ( ss == 6 ) // 按动"确定"按钮

{

try{

// 设定数据连接字符串,意思是打开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 ) ;

myConn.Open ( ) ;

string strDele = "DELETE FROM person WHERE id= " + t_id.Text ;

OleDbCommand myCommand = new OleDbCommand ( strDele , myConn ) ; file://从数据库中删除指定记录

Visual C# 数据库编程实战(详细)

myCommand.ExecuteNonQuery ( ) ;

file://从DataSet中删除指定记录

myDataSet.Tables [ "person" ] . Rows [ myBind.Position ] . Delete ( ) ;

myDataSet.Tables [ "person" ] . AcceptChanges ( ) ;

myConn.Close ( ) ;

}

catch ( Exception ed )

{

MessageBox.Show ( "删除记录错误信息: " + ed.ToString ( ) , "错误!" ) ; }

}

} </P><P> 在这二段代码中,在更改数据库的同时也对"DatsSet"对象进行了必要的修

改。

下图是程序中对数据记录进行删除操作的运行界面: </P><P>

四.插入数据记录: </P><P> 对数据库进行插入记录操作和删除记录操作基本

的思路是一致的,就是通过http://www.77cn.com.cn首先插入数据记录到数据库,然后对"DataSet"对

象进行必要的修改。下列代码就是以Access 2000数据库为模型修改当前记录的代码:

</P><P>protected void Update_record ( object sender , System.EventArgs e ) {

int i = myBind.Position ;

try{

file://连接到一个数据库

Visual C# 数据库编程实战(详细)

string strCon = " Provider = Microsoft.Jet.OLEDB.4.0 ; Data Source = db.mdb " ; OleDbConnection myConn = new OleDbConnection ( strCon ) ;

myConn.Open ( ) ;

myDataSet.Tables [ "person" ] . Rows [ myBind.Position ] . BeginEdit ( ) ; file://从数据库中修改指定记录

string strUpdt = " UPDATE person SET xm = '"

+ t_xm.Text + "' , xb = '"

+ t_xb.Text + "' , nl = "

+ t_nl.Text + " , zip = "

+ t_books.Text + " WHERE id = " + t_id.Text ; 显示的记录的程序代码,此代码是以Sql

Server 鯏w \ OleDbCommand myCommand = new OleDbCommand ( strUpdt , myConn ) ;

myCommand.ExecuteNonQuery ( ) ;

myDataSet.Tables [ "person" ] . Rows [ myBind.Position ] . EndEdit ( ) ; myDataSet.Tables [ "person" ] . AcceptChanges ( ) ;

myConn.Close ( ) ;

}

catch ( Exception ed )

{

MessageBox.Show ( "修改指定记录错误: " + ed.ToString ( ) , "错误!" ) ; }

myBind.Position = i ;

} </P><P> 由于对Sql Server 2000数据记录修改操作和Access 2000数据记录修改操

作的差异只在于不同的数据链接,具体的代码可以参考"删除数据记录"中的代

Visual C# 数据库编程实战(详细)

码,在这

里就不提供了。 实战

实战实战

实战Visual C#

##

#数据库编程

数据库编程数据库编程

数据库编程(

((

(下

下下

下)

))

http://www.77cn.com.cn 3/29/2003 C#CN

五.插入数据记录:

和前面二种操作在思路是一致的,就是通过http://www.77cn.com.cn首先插入数据记录到数据库,

然后对"DataSet"对象进行必要的修改。下列代码就是以Access 2000数据库为模型插入

一条数据记录的代码

protected void Insert_record ( object sender , System.EventArgs e )

{

try

{

Visual C# 数据库编程实战(详细)

file://判断所有字段是否添完,添完则执行,反之弹出提示

if ( t_id.Text != "" && t_xm.Text != "" && t_xb.Text != "" && t_nl.Text != "" && t_books.Text != "" )

{

string myConn1 = " Provider = Microsoft.Jet.OLEDB.4.0 ; Data Source = db.mdb" ; OleDbConnection myConn = new OleDbConnection ( myConn1 ) ;

myConn.Open ( ) ;

string strInsert = " INSERT INTO person ( id , xm , xb , nl , zip ) VALUES ( " ; strInsert += t_id.Text + ", '" ;

strInsert += t_xm.Text + "', '" ;

strInsert += t_xb.Text + "', " ;

strInsert += t_nl.Text + ", " ;

strInsert += t_books.Text + ")" ;

OleDbCommand inst = new OleDbCommand ( strInsert , myConn ) ;

inst.ExecuteNonQuery ( ) ;

myConn.Close ( ) ;

+ t_xm.Text + "' , xb = '"

+ t_xb.Text + "' , nl = " 1鯏f+\ myDataSet.Tables [ "person" ] . Rows

[ myBind.Position ] . BeginEdit ( ) ;

myDataSet.Tables [ "person" ] . Rows [ myBind.Position ] . EndEdit ( ) ; myDataSet.Tables [ "person" ] . AcceptChanges ( ) ;

}

else

{

MessageBox.Show ( "必须填满所有字段值!" , "错误!" ) ;

}

Visual C# 数据库编程实战(详细)

}

catch ( Exception ed )

{

MessageBox.Show ( "保存数据记录发生 " + ed.ToString ( ) , "错误!" ) ; }

}

同样对Sql Server 2000数据库进行插入记录操作和Access 2000数据库插入记录

操作的差异也只在于不同的数据链接,具体的代码可以参考"删除数据记录"中的代码,

在这里就不提供了。

六.Visual C#数据库编程的完成源代码和程序运行的主界面:

掌握了上面要点,编写一个完整的数据库编程的程序就显得非常容易了,下面是

Visual C#进行数据库编程的完整代码(Data01.cs),此代码是以Access 2000数据库

为模型设计的,具体如下:

using System ;

using System.Drawing ;

using http://www.77cn.com.cnponentModel ;

using System.Windows.Forms ;

using System.Data.OleDb ;

using System.Data ;

public class Data : Form

{

private http://www.77cn.com.cnponentModel.Container components = null ;

Visual C# 数据库编程实战(详细)

private Button lastrec ;

private Button nextrec ;

private Button previousrec ;

private Button firstrec ;

private TextBox t_books ;

private TextBox t_nl ;

private ComboBox t_xb ;

private TextBox t_xm ;

private TextBox t_id ;

private Label l_books ;

private Label l_nl ; 庑┒允菘夥衿鞯那肭蠓浅6啵簿 _\ private Label l_xb ;

private Label l_xm ;

private Label l_id ;

private Label label1 ;

private DataSet myDataSet ;

private Button button1 ;

private Button button2 ;

private Button button3 ;

private Button button4 ;

private BindingManagerBase myBind ;

public Data ( )

{

file://连接到一个数据库

GetConnected ( ) ;

// 对窗体中所需要的内容进行初始化 N鯏

Visual C# 数据库编程实战(详细)

InitializeComponent ( ) ;

}

file://清除在程序中使用过的资源

protected override void Dispose( bool disposing )

{

if( disposing )

{

if ( components != null )

{

components.Dispose ( ) ;

}

}

base.Dispose( disposing ) ;

}

public static void Main ( )

{

Application.Run ( new Data ( ) ) ;

}

public void GetConnected ( )

{

try

{

file://创建一个 OleDbConnection

string strCon = " Provider = Microsoft.Jet.OLEDB.4.0 ; Data Source = db.mdb" ; OleDbConnection myConn = new OleDbConnection ( strCon ) ;

string strCom = " SELECT * FROM person " ;

Visual C# 数据库编程实战(详细).doc 将本文的Word文档下载到电脑

    精彩图片

    热门精选

    大家正在看

    × 游客快捷下载通道(下载后可以自由复制和排版)

    限时特价:7 元/份 原价:20元

    支付方式:

    开通VIP包月会员 特价:29元/月

    注:下载文档有可能“只有目录或者内容不全”等情况,请下载之前注意辨别,如果您已付费且无法下载或内容有问题,请联系我们协助你处理。
    微信:fanwen365 QQ:370150219