科技行者

行者学院 转型私董会 科技行者专题报道 网红大战科技行者

知识库

知识库 安全导航

至顶网软件频道基础软件详解Visual C#数据库编程

详解Visual C#数据库编程

  • 扫一扫
    分享文章到微信

  • 扫一扫
    关注官方公众号
    至顶头条

本文就来着重探讨一下Visual C#数据库基本编程,即:如何浏览记录、修改记录、删除记录和插入记录。

作者:佚名 来源:论坛整理 2007年11月11日

关键字:

  • 评论
  • 分享微博
  • 分享邮件
以下是引用片段:
  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 ;
  }

  注释:"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 ) // 按动"确定"按钮
  {
  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 )
  {
  MessageBox.Show ( "删除记录错误信息: " + ed.ToString ( ) , "错误!" ) ;
  }
  }
  }

查看本文来源

    • 评论
    • 分享微博
    • 分享邮件
    邮件订阅

    如果您非常迫切的想了解IT领域最新产品与技术信息,那么订阅至顶网技术邮件将是您的最佳途径之一。

    重磅专题
    往期文章
    最新文章