




已阅读5页,还剩11页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
实战Visual C#数据库编程编者的话:关于数据库编程,微软提供了一个统一的数据对象访问模型,在Visual Studio6.0中称为ADO,在.NET中则统一为ADO.NET,掌握ADO.NET就等于掌握了数据库编程的核心,因此有必要首先复习一下以前发表的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。其中本地数据库名称为db.mdb,在其中定义了一张数据表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对象。/创建一个 OleDbConnectionstring strCon = Provider = Microsoft.Jet.OLEDB.4.0 ; Data Source = db.mdb ;OleDbConnection myConn = new OleDbConnection ( strCon ) ;string strCom = SELECT * FROM person ;file:/创建一个 DataSetmyDataSet = new DataSet ( ) ;myConn.Open ( ) ;file:/用 OleDbDataAdapter 得到一个数据集OleDbDataAdapter myCommand = new OleDbDataAdapter ( strCom , myConn ) ;file:/把Dataset绑定books数据表myCommand.Fill ( myDataSet , person ) ;file:/关闭此OleDbConnectionmyConn.Close ( ) ;myBind = this.BindingContext myDataSet , person ;下列代码是以Sql Server 2000数据库为模型,创建一个名称为myBind的BindingManagerBase对象。/ 设定数据连接字符串,此字符串的意思是打开Sql server数据库,服务器名称为server1,数据库为data1string 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:/创建一个 DataSetmyDataSet = new DataSet ( ) ;file:/用 OleDbDataAdapter 得到一个数据集OleDbDataAdapter myCommand = new OleDbDataAdapter ( strCom , myConn ) ;file:/把Dataset绑定person数据表myCommand.Fill ( myDataSet , person ) ;file:/关闭此OleDbConnectionmyConn.Close ( ) ;myBind = this.BindingContext myDataSet , person ;得到了是同一数据源的BindingManagerBase对象,通过改变此对象的Position属性值,这样绑定数据的组件显示的数据就随之变化,从而实现导航数据记录。 .导航按钮上一条实现方法:protected void GoPrevious ( object sender , System.EventArgs e )if ( myBind.Position = 0 ) MessageBox.Show ( 已经到了第一条记录! , 信息提示! , MessageBoxButtons.OK , MessageBoxIcon.Information ) ;elsemyBind.Position -= 1 ; . 导航按钮下一条实现方法:protected void GoNext ( object sender , System.EventArgs e )if ( myBind.Position = myBind.Count -1 )MessageBox.Show ( 已经到了最后一条记录!, 信息提示! , MessageBoxButtons.OK , MessageBoxIcon.Information ) ;elsemyBind.Position += 1 ; . 导航按钮至尾实现方法:protected void GoLast ( object sender , System.EventArgs e )myBind.Position = myBind.Count - 1 ; . 导航按钮至首实现方法:protected void GoFirst ( object sender , System.EventArgs e )myBind.Position = 0 ;注释:Count是BindingManagerBase对象的另外一个重要的属性,是数据集记录的总数。三实现删除记录:在对数据记录进行操作的时候,有二点必须十分清晰:其一:在对数据记录进行操作的时候,我想有一些程序员一定有这样一个疑惑,当对数据库服务器请求数据集的时候,就会产生DataSet对象,用以管理数据集,这样如果这些对数据库服务器的请求非常多,同样也就会产生很多的DataSet对象,达到一定时候必然会使得数据库服务器崩溃。这种想法是自然的,但和实际并不相符,因为DataSet对象并不是在服务器端产生的,而是在客户端产生的。所以面对众多的数据请求的时候对数据库服务器的影响并不十分太大。其二:记得在用Delphi编写三层数据模型的时候的,每一次对数据库的修改其实只是对第二层产生的数据集的修改,要真正修改数据库,还必须调用一个另外的方法。在用ADO.NET处理数据库的时候,虽然处理的直接对象是数据库,但此时DataSet对象中的内容并没有随之改变,而绑定的数据组件显示的数据又来源于DataSet对象,这样就会产生一个错觉,就是修改了的记录并没有修改掉,删除的记录并没有删除掉。所以对数据记录进行操作的时候,在修改数据库后,还要对DataSet对象进行必要的修改,这样才能保证DataSet对象和数据库内容一致、同步。下面代码是删除当前绑定组件显示的记录的程序代码,此代码是以Access 2000数据库为模板的:protected void Delete_record ( object sender , System.EventArgs e ) DialogResult r = MessageBox.Show ( 是否删除当前记录! , 删除当前记录! , MessageBoxButtons.YesNo , MessageBoxIcon.Question ) ;int ss = ( int ) r ; if ( ss = 6 ) / 按动确定按钮 tryfile:/连接到一个数据库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 )MessageBox.Show ( 删除记录错误信息: + ed.ToString ( ) , 错误! ) ; 下面代码是删除当前绑定组件显示的记录的程序代码,此代码是以Sql Server 2000数据库为模板的,二者的区别仅仅在于数据链接: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/ 设定数据连接字符串,意思是打开Sql server数据库,服务器名称为server1,数据库为data1string 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:/从数据库中删除指定记录myCommand.ExecuteNonQuery ( ) ;file:/从DataSet中删除指定记录myDataSet.Tables person . Rows myBind.Position . Delete ( ) ;myDataSet.Tables person . AcceptChanges ( ) ;myConn.Close ( ) ;catch ( Exception ed )MessageBox.Show ( 删除记录错误信息: + ed.ToString ( ) , 错误! ) ; 在这二段代码中,在更改数据库的同时也对DatsSet对象进行了必要的修改。下图是程序中对数据记录进行删除操作的运行界面:图01:删除记录 四插入数据记录:对数据库进行插入记录操作和删除记录操作基本的思路是一致的,就是通过ADO.NET首先插入数据记录到数据库,然后对DataSet对象进行必要的修改。下列代码就是以Access 2000数据库为模型修改当前记录的代码:protected void Update_record ( object sender , System.EventArgs e )int i = myBind.Position ;tryfile:/连接到一个数据库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 ;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 ;由于对Sql Server 2000数据记录修改操作和Access 2000数据记录修改操作的差异只在于不同的数据链接,具体的代码可以参考删除数据记录中的代码,在这里就不提供了。五插入数据记录:和前面二种操作在思路是一致的,就是通过ADO.NET首先插入数据记录到数据库,然后对DataSet对象进行必要的修改。下列代码就是以Access 2000数据库为模型插入一条数据记录的代码protected void Insert_record ( object sender , System.EventArgs e )tryfile:/判断所有字段是否添完,添完则执行,反之弹出提示 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 ( ) ;myDataSet.Tables person . Rows myBind.Position . BeginEdit ( ) ;myDataSet.Tables person . Rows myBind.Position . EndEdit ( ) ;myDataSet.Tables person . AcceptChanges ( ) ;elseMessageBox.Show ( 必须填满所有字段值! , 错误! ) ;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 System.ComponentModel ;using System.Windows.Forms ;using System.Data.OleDb ;using System.Data ;public class Data : Form private System.ComponentModel.Container components = null ;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 ;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 ( ) ; / 对窗体中所需要的内容进行初始化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 ( )tryfile:/创建一个 OleDbConnectionstring strCon = Provider = Microsoft.Jet.OLEDB.4.0 ; Data Source = db.mdb ;OleDbConnection myConn = new OleDbConnection ( strCon ) ;string strCom = SELECT * FROM person ;file:/创建一个 DataSetmyDataSet = new DataSet ( ) ;myConn.Open ( ) ;file:/用 OleDbDataAdapter 得到一个数据集OleDbDataAdapter myCommand = new OleDbDataAdapter ( strCom , myConn ) ;file:/把Dataset绑定books数据表myCommand.Fill ( myDataSet , person ) ;file:/关闭此OleDbConnectionmyConn.Close ( ) ;catch ( Exception e )MessageBox.Show ( 连接错误! + e.ToString ( ) , 错误 ) ; private void InitializeComponent ( )file:/添加控件,略this.Name = Data ;this.Text = Visual C的数据库编程! ;this.ResumeLayout(false) ;myBind = this.BindingContext myDataSet , person ;protected void New_record ( object sender , System.EventArgs e )t_id.Text = ( myBind.Count + 1 ).ToString ( ) ;t_xm.Text = ;t_xb.Text = ;t_nl.Text = ;t_books.Text = ;protected void Insert_record ( object sender , System.EventArgs e )tryfile:/判断所有字段是否添完,添完则执行,反之弹出提示 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 ( ) ;myDataSet.Tables person . Rows myBind.Position . BeginEdit ( ) ;myDataSet.Tables person . Rows myBind.Position . EndEdit ( ) ;myDataSet.Tables person . AcceptChanges ( ) ;elseMessageBox.Show ( 必须填满所有字段值! , 错误! ) ;catch ( Exception ed )MessageBox.Show ( 保存数据记录发生 + ed.ToString ( ) , 错误! ) ; protected void Update_record ( object sender , System.EventArgs e )int i = myBind.Position ;tryfile:/连接到一个数据库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 ;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 ;protected void Delete_record ( object sender , System.EventArgs e ) DialogResult r = MessageBox.Show ( 是否删除当前记录! , 删除当前记录! , MessageBoxButtons.YesNo , MessageBoxIcon.Question ) ;int ss = ( int ) r ; if ( ss = 6 ) / 按动确定按钮 tryfile:/连接到一个数据库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.Ta
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025中秋之夜作文(11篇)
- 1.2-认识数字孪生
- 公交公司庆八一活动方案
- 公交服务整治活动方案
- 《有机物的结构特性:高中生物有机化学教案》
- 倒霉的一天400字(14篇)
- 公司聘用在职员工证明书(8篇)
- 公共安全大讨论活动方案
- 公关公司策划方案
- 公务员遴选之活动方案
- 2023年国开大学期末考复习题-02312-财务管理
- 三维激光扫描仪应用项目方案
- 广州市轻工技师学院工作人员招聘考试真题2022
- 耕地占补平衡动态监管系统培训讲解
- 2022-2023学年英语(下)外国语八年级期末考试卷含答案
- 电大可编程控制器应用实训 形考任务2
- 实验设计与数据处理
- 语C圈洗白手册
- 2023年全国初中数学竞赛试题及答案
- 《活板》同步练习及答案
- 生物药剂学与药物动力学(山西医科大学)知到章节答案智慧树2023年
评论
0/150
提交评论