详解Visual C#数据库编程

2016-02-19 13:47 1 1 收藏

有一种朋友不在生活里,却在生命力;有一种陪伴不在身边,却在心间。图老师即在大家的生活中又在身边。这么贴心的服务你感受到了吗?话不多说下面就和大家分享详解Visual C#数据库编程吧。

【 tulaoshi.com - 编程语言 】

  本文就来着重探讨一下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          文本            年龄

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com/bianchengyuyan/)

  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 = Microsoft.Jet.OLEDB.4.0 ; Data Source = db.mdb" ;
  OleDbConnection myConn = new OleDbConnection ( strCon ) ;
  string strCom = " SELECT * FROM person " ;
  file://创建一个 DataSet
  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
  myConn.Close ( ) ;
  myBind = this.BindingContext [ myDataSet , "person" ] ;

  得到了是同一数据源的BindingManagerBase对象,通过改变此对象的"Position"属性值,这样绑定数据的组件显示的数据就随之变化,从而实现导航数据记录。

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

以下是引用片段:
  protected void GoPrevious ( object sender , System.EventArgs e )
  {
  if ( myBind.Position == 0 )
  MessageBox.Show ( "已经到了第一条记录!" , "信息提示!" , MessageBoxButtons.OK , MessageBoxIcon.Information ) ;
  else
  myBind.Position -= 1 ;
  }

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

以下是引用片段:
  protected void GoNext ( object sender , System.EventArgs e )
  {
  if ( myBind.Position == myBind.Count -1 )
  MessageBox.Show ( "已经到了最后一条记录!", "信息提示!" , MessageBoxButtons.OK , MessageBoxIcon.Information ) ;
  else
  myBind.Position += 1 ;
  }

   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 ;
  }

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com/bianchengyuyan/)

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

  三.实现删除记录:

  在对数据记录进行操作的时候,有二点必须十分清晰:

  其一:在对数据记录进行操作的时候,我想有一些程序员一定有这样一个疑惑,当对数据库服务器请求数据集的时候,就会产生"DataSet"对象,用以管理数据集,这样如果这些对数据库服务器的请求非常多,同样也就会产生很多的"DataSet"对象,达到一定时候必然会使得数据库服务器崩溃。这种想法是自然的,但和实际并不相符,因为"DataSet"对象并不是在服务器端产生的,而是在客户端产生的。所以面对众多的数据请求的时候对数据库服务器的影响并不十分太大。

  其二:记得在用Delphi编写三层数据模型的时候的,每一次对数据库的修改其实只是对第二层产生的数据集的修改,要真正修改数据库,还必须调用一个另外的方法。在用ADO.NET处理数据库的时候,虽然处理的直接对象是数据库,但此时"DataSet"对象中的内容并没有随之改变,而绑定的数据组件显示的数据又

  本文就来着重探讨一下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          文本            年龄

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com/bianchengyuyan/)

  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 = Microsoft.Jet.OLEDB.4.0 ; Data Source = db.mdb" ;
  OleDbConnection myConn = new OleDbConnection ( strCon ) ;
  string strCom = " SELECT * FROM person " ;
  file://创建一个 DataSet
  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
  myConn.Close ( ) ;
  myBind = this.BindingContext [ myDataSet , "person" ] ;

  得到了是同一数据源的BindingManagerBase对象,通过改变此对象的"Position"属性值,这样绑定数据的组件显示的数据就随之变化,从而实现导航数据记录。

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

以下是引用片段:
  protected void GoPrevious ( object sender , System.EventArgs e )
  {
  if ( myBind.Position == 0 )
  MessageBox.Show ( "已经到了第一条记录!" , "信息提示!" , MessageBoxButtons.OK , MessageBoxIcon.Information ) ;
  else
  myBind.Position -= 1 ;
  }

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

来源:https://www.tulaoshi.com/n/20160219/1605213.html

延伸阅读
什么是数据库事务 数据库事务是指作为单个逻辑工作单元执行的一系列操作。 牐犐柘胪上购物的一次交易,其付款过程至少包括以下几步数据库操作: 更新客户所购商品的库存信息 保存客户付款信息--可能包括与银行系统的交互 生成订单并且保存到数据库中 更新用户相关信息,例如购物数量等等 牐犝常的...
最近这个项目中用到是ACCESS的数据库,开始没有使用密码进行连接: String connectionString = "Provider=Microsoft.Jet.OleDb.4.0;Data Source="; connectionString += @"c:datadbdb.mdb"; OleDbConnection con = new OleDbConnection(connectionString); con.Open(); 是没有任何问题。 为了要使数据库安全一点,不能被用户直接打开编辑,...
程序的活动是通过语句(statement)来表达的。C#支持几种不同的语句,许多语句是以嵌入语句的形式定义的。 块(block)允许在只能使用单个语句的上下文中编写多个语句。块由一个括在大括号{}内的语句列表组成。 声明语句(declaration statement)用于声明局部变量和常量。 表达式语句(expression statement)用于运算表达...
前一篇《Visual C#.Net网络程序开发之Socket》中说到:支持Http、Tcp和Udp的类组成了TCP/IP三层模型(请求响应层、应用协议层、传输层)的中间层-应用协议层,该层的类比位于最底层的Socket类提供了更高层次的抽象,它们封装 TCP 和 UDP 套接字的创建,不需要处理连接的细节,这使得我们在编写套接字级别的协议时,可以更多地尝试使用 TCPCli...
命名空间提供了一种组织相关类和其他类型的方式。与文件或组件不同,命名空间是一种逻辑组合,而不是物理组合。在C#文件中定义类时,可以把它包括在命名空间定义中。以后,在定义另一个类,在另一个文件中执行相关操作时,就可以在同一个命名空间中包含它,创建一个逻辑组合,告诉使用类的其他开发人员这两个类是如何相关的以及如何使用它们: n...

经验教程

721

收藏

74
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部