在前面的一篇文章《Visual C#中轻松浏览数据库记录》中 我们介绍了用Visual C#如何把数据表中的字段值绑定到文本框的属性上和如何 *** 作数据记录指针 随意浏览数据表中的记录 本文就接着上一篇的内容 来介绍用Visual C#如何来修改和删除数据记录
一 程序设计和运行的环境设置 ( )视窗 服务器版 ( )Microsoft Access Data Component 以上版本 ( MADC ) ( )本文程序使用的数据库的介绍
为了方便起见 在选用数据库方面选用了本地数据库Access 当然你也可以选用其他类型的数据库 只需要更改文章后面的程序源代码中数据库的引擎 并更改对应的代码就可以了 本程序中使用的数据库名称为sample mdb 在此数据库中有一张数据表books 此数据表的结构如下 字段名称 字段类型 代表意思 Bookid 数字 序号 booktitle 文本书籍名称 bookauthor 文本书籍作者 bookprice 数字 价格 bookstock 数字书架号
二 程序设计难点和应该注意的问题 在程序设计中的重点和难点就是如何用Visual C#删除记录和如何修改记录 下面就这二个问题进行必要的论述 ( )如何用Visual C#正确删除数据表中的记录
在用Visual C#删除记录的时候要注意的是 必须从二个方面彻底删除记录 即从数据库和用Visual C#编程时产生的一个DataSet对象中彻底删除 在程序设计的时候 如果只是删除了DataSet对象中的记录信息 这种删除是一种伪删除 这是因为当他退出程序 又重新运行程序 会发现 那个要删除的记录依然还存在 这是因为DataSet对象只是对数据表的一个镜像 并不是真正的记录本身 但如果只是从数据库中删除记录 因为我们此时程序用到的数据集合是从DataSet对象中读取的 子DataSet对象中依然保存此条记录的镜像 所以就会发现 我们根本没有删除掉记录 但实际上已经删除了 此时只有退出程序 重新运行 才会发现记录已经删除了 本文使用的方法是删除以上二个方面的记录或记录镜像信息 当然你也可以使用其他的方法 譬如 首先从数据库中删除记录 然后重新建立数据连接 重新创建一个新的DataSet对象 这种方法虽然也可以达到相同目的 但显然相对繁杂些 所以本文采用的是第一种方法 直接删除 在程序中具体的实现语句如下 //连接到一个数据库 string strCon = Provider = Microsoft Jet OLEDB ; Data Source = sample mdb ; OleDbConnection myConn = new OleDbConnection ( strCon ) ; myConn Open ( ) ; string strDele = DELETE FROM books WHERE bookid= + t_bookid Text ; OleDbCommand myCommand = new OleDbCommand ( strDele myConn ) ; //从数据库中删除指定记录 myCommand ExecuteNonQuery ( ) ; //从DataSet中删除指定记录信息 myDataSet Tables [ books ] Rows [ myBind Position ] Delete ( ) ; myDataSet Tables [ books ] AcceptChanges ( ) ; myConn Close ( ) ;
( )用Visual C#来修改数据表中的记录 在用Visual C#修改记录和删除记录 在程序设计中大致差不多 具体的实现方式也是通过SQL语句调用来实现的 下面就是在程序中修改记录的具体语句 //连接到一个数据库 string strCon = Provider = Microsoft Jet OLEDB ; Data Source = sample mdb ; OleDbConnection myConn = new OleDbConnection ( strCon ) ; myConn Open ( ) ;
//从数据库中修改指定记录 string strUpdt = UPDATE books SET booktitle = + t_booktitle Text + bookauthor = + t_bookauthor Text + bookprice = + t_bookprice Text + bookstock = + t_bookstock Text + WHERE bookid = + t_bookid Text ;
OleDbCommand myCommand = new OleDbCommand ( strUpdt myConn ) ; myCommand ExecuteNonQuery ( ) ; myConn Close ( ) ;
( )在了解了如何用Visual C#删除和修改记录以后 结合《Visual C#中轻松浏览数据库记录》一文的内容 就可以得到用Visual C#完成删除和修改数据记录的比较完整程序代码 以下是本文中介绍程序的运行后的程序界面
点击小图放大 本文中程序运行后的界面三 用Visual C#实现删除和修改数据库记录的完整源程序代码 using System ; using System Drawing ; using System ComponentModel ; using System Windows Forms ; using System Data OleDb ; using System Data ; public class DataEdit : Form { private System ComponentModel Container ponents ; private Button delete ; private Button update ; private Button lastrec ; private Button nextrec ; private Button previousrec ; private Button firstrec ; private TextBox t_bookstock ; private TextBox t_bookprice ; private TextBox t_bookauthor ; private TextBox t_booktitle ; private TextBox t_bookid ; private Label l_bookstock ; private Label l_bookprice ; private Label l_bookauthor ; private Label l_booktitle ; private Label l_bookid ; private Label label ; private System Data DataSet myDataSet ; private BindingManagerBase myBind ; private bool isBound = false ; //定义此变量 是判断组件是否已经绑定数据表中的字段
public DataEdit ( ) { // 对窗体中所需要的内容进行初始化 InitializeComponent ( ) ; //连接到一个数据库 GetConnected ( ) ; } //清除程序中用到的所有资源 public override void Dispose ( ) { base Dispose ( ) ; ponents Dispose ( ) ; } public void GetConnected ( ) { try{ //创建一个 OleDbConnection对象 string strCon = Provider = Microsoft Jet OLEDB ; Data Source = sample mdb ; OleDbConnection myConn = new OleDbConnection ( strCon ) ; string strCom = SELECT FROM books ; //创建一个 DataSet对象 myDataSet = new DataSet ( ) ; myConn Open ( ) ; OleDbDataAdapter myCommand = new OleDbDataAdapter ( strCom myConn ) ; myCommand Fill ( myDataSet books ) ; myConn Close ( ) ; //判断数据字段是否绑定到 TextBoxes if ( !isBound ) { //以下是为显示数据记录而把数据表的某个字段绑定在不同的绑定到文本框 Text 属性上 t_bookid DataBindings Add ( Text myDataSet books bookid ) ; t_booktitle DataBindings Add ( Text myDataSet books booktitle ) ; t_bookauthor DataBindings Add ( Text myDataSet books bookauthor ) ; t_bookprice DataBindings Add ( Text myDataSet books bookprice ) ; t_bookstock DataBindings Add ( Text myDataSet books bookstock ) ; //设定 BindingManagerBase //把对象DataSet和 books 数据表绑定到此myBind对象 myBind = this BindingContext [ myDataSet books ] ; isBound = true ; } } catch ( Exception e ) { MessageBox Show ( 连接数据库发生错误为 + e ToString ( ) 错误! ) ; } } public static void Main ( ) { Application Run ( new DataEdit ( ) ) ; } private void InitializeComponent ( ) { this ponents = new System ComponentModel Container ( ) ; this t_bookid = new TextBox ( ) ; this previousrec = new Button ( ) ; this l_bookauthor = new Label ( ) ; this delete = new Button ( ) ; this t_booktitle = new TextBox ( ) ; this t_bookauthor = new TextBox ( ) ; this t_bookprice = new TextBox ( ) ; this l_bookprice = new Label ( ) ; this t_bookstock = new TextBox ( ) ; this l_bookstock = new Label ( ) ; this l_booktitle = new Label ( ) ; this update = new Button ( ) ; this nextrec = new Button ( ) ; this lastrec = new Button ( ) ; this firstrec = new Button ( ) ; this label = new Label ( ) ; this l_bookid = new Label ( ) ; t_bookid Location = new System Drawing Point ( ) ; t_bookid Size = new System Drawing Size ( ) ;
t_booktitle Location = new System Drawing Point ( ) ; t_booktitle Size = new System Drawing Size ( ) ;
t_bookauthor Location = new System Drawing Point ( ) ; t_bookauthor Size = new System Drawing Size ( ) ;
t_bookprice Location = new System Drawing Point ( ) ; t_bookprice Size = new System Drawing Size ( ) ;
t_bookstock Location = new System Drawing Point ( ) ; t_bookstock Size = new System Drawing Size ( ) ; //以下是设定在程序中使用到的Label属性 l_bookid Location = new System Drawing Point ( ) ; l_bookid Text = 序 号 ; l_bookid Size = new System Drawing Size ( ) ; l_bookid Font = new System Drawing Font ( 宋体 f ) ; l_bookid TextAlign = System Drawing ContentAlignment MiddleCenter ; l_booktitle Location = new System Drawing Point ( ) ; l_booktitle Text = 书 名 ; l_booktitle Size = new System Drawing Size ( ) ; l_booktitle Font = new System Drawing Font ( 宋体 f ) ; l_booktitle TextAlign = System Drawing ContentAlignment MiddleCenter ; l_bookauthor Location = new System Drawing Point ( ) ; l_bookauthor Text = 作 者 ; l_bookauthor Size = new System Drawing Size ( ) ; l_bookauthor Font = new System Drawing Font ( 宋体 f ) ; l_bookauthor TextAlign = System Drawing ContentAlignment MiddleCenter ; l_bookprice Location = new System Drawing Point ( ) ; l_bookprice Text = 价 格 ; l_bookprice Size = new System Drawing Size ( ) ; l_bookprice Font = new System Drawing Font ( 宋体 f ) ; l_bookprice TextAlign = System Drawing ContentAlignment MiddleCenter ;
l_bookstock Location = new System Drawing Point ( ) ; l_bookstock Text = 书 架 号 ; l_bookstock Size = new System Drawing Size ( ) ; l_bookstock Font = new System Drawing Font ( 宋体 f ) ; l_bookstock TextAlign = System Drawing ContentAlignment MiddleCenter ;
//以下设定程序中用到的功能按钮的属性及对应的事件 delete Location = new System Drawing Point ( ) ; delete ForeColor = System Drawing Color Black ; delete Size = new System Drawing Size ( ) ; delete Font = new System Drawing Font ( 宋体 f ) ; delete Text = 删除记录 ; delete Click += new System EventHandler ( GoDelete ) ;
update Location = new System Drawing Point ( ) ; update ForeColor = System Drawing Color Black ; update Size = new System Drawing Size ( ) ; update Font = new System Drawing Font ( 宋体 f ) ; update Text = 修改记录 ; update Click += new System EventHandler ( GoUpdate ) ;
firstrec Location = new System Drawing Point ( ) ; firstrec ForeColor = System Drawing Color Black ; firstrec Size = new System Drawing Size ( ) ; firstrec Font = new System Drawing Font ( 宋体 f ) ; firstrec Text = 首记录 ; firstrec Click += new System EventHandler ( GoFirst ) ;
previousrec Location = new System Drawing Point ( ) ; previousrec ForeColor = System Drawing Color Black ; previousrec Size = new System Drawing Size ( ) ; previousrec Font = new System Drawing Font ( 宋体 f ) ; previousrec Text = 上一条 ; previousrec Click += new System EventHandler ( GoPrevious ) ;
nextrec Location = new System Drawing Point ( ) ; nextrec ForeColor = System Drawing Color Black ; nextrec Size = new System Drawing Size ( ) ; nextrec Font = new System Drawing Font ( 宋体 f ) ; nextrec Text = 下一条 ; nextrec Click += new System EventHandler ( GoNext ) ;
lastrec Location = new System Drawing Point ( ) ; lastrec ForeColor = System Drawing Color Black ; lastrec Size = new System Drawing Size ( ) ; lastrec Font = new System Drawing Font ( 宋体 f ) ; lastrec Text = 尾记录 ; lastrec Click += new System EventHandler ( GoLast ) ;
label Location = new System Drawing Point ( ) ; label Text = 用Visual C#来修改和删除数据库中的记录 ; label Size = new System Drawing Size ( ) ; label ForeColor = System Drawing SystemColors Desktop ; label Font = new System Drawing Font ( 宋体 f ) ; //设定程序的主窗体的属性 this Text = 用Visual C#来修改和删除数据库中的记录! ; this AutoScaleBaseSize = new System Drawing Size ( ) ; this FormBorderStyle = FormBorderStyle FixedSingle ; this ClientSize = new System Drawing Size ( ) ; //在主窗体中加入组件 this Controls Add ( delete ) ; this Controls Add ( update ) ; this Controls Add ( lastrec ) ; this Controls Add ( nextrec ) ; this Controls Add ( previousrec ) ; this Controls Add ( firstrec ) ; this Controls Add ( t_bookstock ) ; this Controls Add ( t_bookprice ) ; this Controls Add ( t_bookauthor ) ; this Controls Add ( t_booktitle ) ; this Controls Add ( t_bookid ) ; this Controls Add ( l_bookstock ) ; this Controls Add ( l_bookprice ) ; this Controls Add ( l_bookauthor ) ; this Controls Add ( l_booktitle ) ; this Controls Add ( l_bookid ) ; this Controls Add ( label ) ;
} // 删除记录 对应的事件 protected void GoDelete ( object sender System EventArgs e ) { try{ //连接到一个数据库 string strCon = Provider = Microsoft Jet OLEDB ; Data Source = sample mdb ; OleDbConnection myConn = new OleDbConnection ( strCon ) ; myConn Open ( ) ; string strDele = DELETE FROM books WHERE bookid= + t_bookid Text ; OleDbCommand myCommand = new OleDbCommand ( strDele myConn ) ; //从数据库中删除指定记录 myCommand ExecuteNonQuery ( ) ; //从DataSet中删除指定记录 myDataSet Tables [ books ] Rows [ myBind Position ] Delete ( ) ; myDataSet Tables [ books ] AcceptChanges ( ) ; myConn Close ( ) ; } catch ( Exception ed ) { MessageBox Show ( 删除记录错误信息 + ed ToString ( ) 错误! ) ; } } // 修改记录 按钮对应的事件 protected void GoUpdate ( object sender System EventArgs e ) { int i = myBind Position ; try{ //连接到一个数据库 string strCon = Provider = Microsoft Jet OLEDB ; Data Source = sample mdb ; OleDbConnection myConn = new OleDbConnection ( strCon ) ; myConn Open ( ) ;
//从数据库中修改指定记录 string strUpdt = UPDATE books SET booktitle = + t_booktitle Text + bookauthor = + t_bookauthor Text + bookprice = + t_bookprice Text + bookstock = + t_bookstock Text + WHERE bookid = + t_bookid Text ;
OleDbCommand myCommand = new OleDbCommand ( strUpdt myConn ) ; myCommand ExecuteNonQuery ( ) ; myConn Close ( ) ; } catch ( Exception ed ) { MessageBox Show ( 修改指定记录错误 + ed ToString ( ) 错误! ) ; } myBind Position = i ; } // 尾记录 按钮对应的事件 protected void GoLast ( object sender System EventArgs e ) { myBind Position = myBind Count ; } // 下一条 按钮对应的事件 protected void GoNext ( object sender System EventArgs e ) { if ( myBind Position == myBind Count ) MessageBox Show ( 已经到尾记录! ) ; else myBind Position += ; } // 上一条 按钮对应的事件 protected void GoPrevious ( object sender System EventArgs e ) { if ( myBind Position == ) MessageBox Show ( 已经到首记录! ) ; else myBind Position = ; } // 首记录 按钮对应的事件 protected void GoFirst ( object sender System EventArgs e ) { myBind Position = ; } } 四 编译源程序代码 生成执行文件 得到了Data cs源程序代码以后 经过下面编译命令编译成功后 即可得到执行文件data exe csc /t:winexe /r:system windows forms dll /r:system data dll data cs
lishixinzhi/Article/program/net/201311/15222
1DataSet 是DataTable的集合,通过dataSet1Tables[index] 方式得到DataTable
2DataSet 及DataTable均存在与内存
3DataSet中的DataTable可以只有一个,也可以有多个,多个之间可以有关系也可以没有关系相互独立;
4DataTable可以通过dataSet1TablesAdd加入到DataSet中,但此DataTable必须通过copy的方式加入,如:
DataTable dt1=new DataTable();
DataSet ds=new DataSet();
dsTablesAdd(dt1);//错误
dsTablesAdd(dt1Copy());//正确
5SqlDataAdapter可以填充DataSet也可以填充DataTable,根据实际需要,如sql查询的是返回多个记录集则用DataSet,单个记录集用DataSet和DataTable均可,只是通过dataSet1Tables[0]转DataTable。
6DataTable可以设置pk,DataSet中的Table可以设置relation
如果 你是要写个什么软件的话,建议还是先写个数据库类,包括数据库连接,数据库一系列 *** 作方法都写好,然后直接用就是了,你这样,每涉及到一次数据库,就要重新写连接,和 *** 作,太麻烦了。
下面是实现对数据库 *** 作的类,仅供参考。
class DBhelper
{
string sqlconn;
SqlConnection conn;
public DBhelper()
{
sqlconn = SystemConfigurationConfigurationManagerAppSettings["sqlconn"];
conn = new SqlConnection(sqlconn);
}
public DBhelper(string sqlconn)
{
thissqlconn = sqlconn;
conn = new SqlConnection(sqlconn);
}
//检查数据库是否打开
public void CheakOpen()
{
if (connState != SystemDataConnectionStateOpen)
{
connOpen();
}
}
//检查数据库是否关闭
public void CheakClose()
{
if (connState != SystemDataConnectionStateClosed)
{
connClose();
}
}
//执行sql命令
public bool ExcuteNonQuery(string sql)
{
bool flag = false;
try
{
CheakOpen();
SqlCommand cmd = new SqlCommand(sql, conn);
cmdExecuteNonQuery();
flag = true;
}
catch (Exception)
{
flag = false;
}
CheakClose();
return flag;
}
public int ExcuteScaler(string sql)
{
int value=-1;
try
{
CheakOpen();
SqlCommand cmd = new SqlCommand(sql, conn);
value=intParse(cmdExecuteScalar()ToString());
return value;
}
catch (Exception)
{
value = -1;
}
CheakClose();
return value;
}
public SqlDataReader ExcuteReader(string sql)
{
CheakOpen();
SqlCommand cmd = new SqlCommand(sql, conn);
SqlDataReader sdr = cmdExecuteReader();
return sdr;
}
public DataSet GetDataSet(string sql,string tableName)
{
SqlDataAdapter sda = new SqlDataAdapter(sql, conn);
DataSet ds = new DataSet();
sdaFill(ds,tableName);
return ds;
}
}
}
ADO NET是Net FrameWork SDK中用以 *** 作数据库的类库的总称 而DataSet类则是ADO NET中最核心的成员之一 也是各种开发基于 Net平台程序语言开发数据库应用程序最常接触的类 之所以DataSet类在ADO NET中具有特殊的地位 是因为DataSet在ADO NET实现从数据库抽取数据中起到关键作用 在从数据库完成数据抽取后 DataSet就是数据的存放地 它是各种数据源中的数据在计算机内存中映射成的缓存 所以有时说DataSet可以看成是一个数据容器 同时它在客户端实现读取 更新数据库等过程中起到中间部件的作用(DataReader只能检索数据库中的数据)
各种 Net平台开发语言开发数据库应用程序 一般并不直接对数据库 *** 作(直接在程序中调用存储过程等除外) 而是先完成数据连接和通过数据适配器填充DataSet对象 然后客户端再通过读取DataSet来获得需要的数据 同样更新数据库中数据 也是首先更新DataSet 然后再通过DataSet来更新数据库中对应的数据的 可见了解 掌握ADO NET 首先必须了解 掌握DataSet DataSet主要有三个特性
独立性 DataSet独立于各种数据源 微软公司在推出DataSet时就考虑到各种数据源的多样性 复杂性 在 Net中 无论什么类型数据源 它都会提供一致的关系编程模型 而这就是DataSet
离线(断开)和连接 DataSet既可以以离线方式 也可以以实时连接来 *** 作数据库中的数据 这一点有点像ADO中的RecordSet
DataSet对象是一个可以用XML形式表示的数据视图 是一种数据关系视图
一 DataSet对象的结构模型及和RecordSet的比较
虽说ADO NET是 ADO在 Net平台下得后继版本 但二者的区别是很大的 突出表现在ADO中的RecordSet对象和ADO NET中的DataSet对象 RecordSet其实也是非常灵活的一个对象 微软公司推出它也是煞费苦心 如 RecordSet可以离线 *** 作数据库 性能优良 效率较高等等这些都让当时的程序员为之一振 RecordSet虽然已经很复杂 但DataSet却比RecordSet复杂的多 我们知道每一DataSet往往是一个或多个DataTable 对象的集合 这些对象由数据行和数据列以及主键 外键 约束和有关DataTable对象中数据的关系信息组成 而RecordSet只能存放单张数据表 虽然这张数据表可以由几张数据表JOIN生成 所以有些时候说 RecordSet更类似于DataSet中的DataTable DataSet对象的结构模型如图 所示
图 DataSet对象的结构模型图通过图 可见在DataSet对象结构还是非常复杂的 在DataSet对象的下一层中是DataTableCollection对象 DataRelationCollection对象和ExtendedProperties对象 上文已经说过 每一个DataSet对象是由若干个DataTable对象组成 DataTableCollection就是管理DataSet中的所有DataTable对象 表示DataSet中两个DataTable对象之间的父/子关系是DataRelation对象 它使一个DataTable 中的行与另一个DataTable中的行相关联 这种关联类似于关系数据库中数据表之间的主键列和外键列之间的关联 DataRelationCollection对象就是管理DataSet中所有DataTable之间的DataRelation关系的 在DataSet中DataSet DataTable和DataColumn都具有ExtendedProperties属性 ExtendedProperties其实是一个属性集(PropertyCollection) 用以存放各种自定义数据 如生成数据集的SELECT语句等
二.使用DataSet
DataSet其实就是数据集 上文已经说过DataSet是把数据库中的数据映射到内存缓存中的所构成的数据容器 对于任何数据源 它都提供一致的关系编程模型 在DataSet中既定义了数据表的约束关系以及数据表之间的关系 还可以对数据表中的数据进行排序等 DataSet使用方法一般有三种
把数据库中的数据通过DataAdapter对象填充DataSet
通过DataAdapter对象 *** 作DataSet实现更新数据库
把XML数据流或文本加载到DataSet
下面就来详细探讨以上DataSet使用方法的具体实现 使用语言是C#
把数据库中的数据通过DataAdapter对象填充DataSet
掌握DataSet使用方法必须掌握ADO NET另外一个核心常用成员 数据提供者(Data Provider) 数据提供者(也称为托管提供者Managed Provider)是一个类集合 在 Net FrameWork SDK 中数据提供者分为二种 The SQL Server NET Data Provider和The OLE DB NET Data Provider 而到了 Net FrameWork SDK 时 ADO NET中又增加了The ODBC NET Data Provider和 The Oracle NET Data Provider二个数据提供者 The SQL Server NET Data Provider的 *** 作数据库对象只限于Sql Server 及以上版本 Oracle NET Data Provider的 *** 作数据库对象只限于Oracle 及以上版本 而The OLE DB NET Data Provider和The ODBC NET Data Provider可 *** 作的数据库类型就相对多了许多 只要它们在本地分别提供Ole Db提供程序和ODBC提供程序
在这些数据提供者中都有一个DataAdapter类 如 OLE DB NET Framework 数据提供者中是 OleDbDataAdapter类 The SQL Server NET Framework 数据提供者中是SqlDataAdapter类 The ODBC NET Framework 数据提供者中是OdbcDataAdapter类 通过这些DataAdapter就能够实现从数据库中检索数据并填充 DataSet 中的表
DataAdapter填充DataSet的过程分为二步 首先通过DataAdapter的SelectCommand属性从数据库中检索出需要的数据 SelectCommand其实是一个Command对象 然后再通过DataAdapter的Fill方法把检索来的数据填充 DataSet 代码清单 就是以Microsoft SQL Server 中的Northwind数据库为对象 C#使用The SQL Server NET Data Provider中的SqlDataAdapter填充DataSet的具体实现方法
代码清单
SqlConnection sqlConnection = new SqlConnection ( Data Source=localhost;Integrated Security=SSPI ;Initial Catalog=Northwind ) ;//创建数据连接SqlCommand selectCMD = new SqlCommand ( SELECT CustomerID CompanyName FROMCustomers sqlConnection ) ;//创建并初始化SqlCommand对象SqlDataAdapter sqlDataAdapter = new SqlDataAdapter ( ) ;custDA SelectCommand = selectCMD ;sqlConnection Open ( ) ;//创建SqlDataAdapter对象 并根据SelectCommand属性检索数据DataSet dsDataSet = new DataSet ( ) ;sqlDataAdapter Fill ( dsDataSet Customers ) ;//使用SqlDataAdapter的Fill方法填充DataSetsqlConnection Close ( ) ;//关闭数据连接
对于其他数据提供者的DataAdapter 具体的实现检索数据库中的数据并填充DataSet的实现方法类似于以上方法
通过DataAdapter对象 *** 作DataSet实现更新数据库
DataAdapter是通过其Update方法实现以DataSet中数据来更新数据库的 当DataSet实例中包含数据发生更改后 此时调用Update方法 DataAdapter 将分析已作出的更改并执行相应的命令(INSERT UPDATE 或 DELETE) 并以此命令来更新数据库中的数据 如果DataSet中的DataTable是映射到单个数据库表或从单个数据库表生成 则可以利用 CommandBuilder 对象自动生成 DataAdapter 的 DeleteCommand InsertCommand 和 UpdateCommand 使用DataAdapter对象 *** 作DataSet实现更新数据库具体的实现方法 只需把下面的代码清单 添加到代码清单 之后 二者合并即可实现删除Customers数据表中第一行数据
代码清单
SqlCommandBuilder sqlCommandBuilder = new SqlCommandBuilder(sqlDataAdapter ) ;//以sqlDataAdapter 为参数来初始化SqlCommandBuilder实例dsDataSet Tables[ Customers ] Rows[ ] Delete ( ) ;//删除DataSet中删除数据表Customers中第一行数据sqlDataAdapter Update ( dsDataSet Customers ) ;//调用Update方法 以DataSet中的数据更新从数据库dsDataSet Tables[ Customers ] AcceptChanges ( ) ;
由于不了解DataSet结构和与数据库关系 很多初学者往往只是更新了DataSet中的数据 就认为数据库中的数据也随之更新 所以当打开数据库浏览时发现并没有更新数据 都会比较疑惑 通过上面的介绍 疑惑应当能够消除了
XML和DataSet
DataSet中的数据可以从XML数据流或文档创建 并且 Net Framework可以控制加载XML数据流或文档中那些数据以及如何创建DataSet的关系结构 加载XML数据流和文档到DataSet中是可使用DataSet对象的ReadXml方法(注意 ReadXml来加载非常大的文件 则性能会有所下降) ReadXml 方法将从文件 流或 XmlReader 中进行读取 并将 XML 的源以及可选的 XmlReadMode 参数用作参数 该ReadXml方法读取 XML 流或文档的内容并将数据加载到 DataSet 中 根据所指定的XmlReadMode和关系架构是否已存在 它还将创建DataSet的关系架构
三.DataSet和数据绑定(DataBinding)
数据绑定是数据绑定是绑定技术中使用最频繁 也是最为重要的技术 也可以说是各种 Net开发语言开发数据库应用程序最需要掌握的基本的知识之一 数据绑定之所以很重要 是因为在 Net FrameWork SDK中并没有提供数据库开发的相关组件 即如 DbTextBox DbLabel等用于数据库开发的常用组件在 Net FrameWork SDK中都没有 而数据绑定技术则能够把TextBox组件 改造 成DbTextBox组件 把Label组件 改造 成DbLabel组件等等 所有这些都与DataSet有直接关系
数据绑定分成二类 简单型数据绑定和复杂型数据绑定 适用于简单型数据绑定组件一般有Lable TextBox等 适用于复杂性数据绑定的组件一般有DataGrid ListBox ComboBox等 其实简单型数据绑定和复杂性数据绑定并没有明确的区分 只是在组件进行数据绑定时 一些结构复杂一点的组件在数据绑定时 *** 作步骤相近 而另外一些结构简单一点的组件在数据绑定时也比较类似 于是也就产生了二个类别 以下就结合TextBox组件和DataGrid组件分别探讨DataSet在实现简单型数据绑定和复杂性数据绑定作用和具体实现方法
简单型数据绑定
简单型数据绑定一般使用这些组件中的DataBindings属性的Add方法把DataSet中某一个DataTable中的某一行和组件的某个属性绑定起来 从而达到显示数据的效果 TextBox组件的数据绑定具体实现方法是在代码清单 后 再添加代码清单 中的代码 代码清单 中的代码是把DataSet中的Customers 数据表中的 CustomerID 的数据和TextBox的Text属性绑定起来 这样DbTextBox就产生了 其他适用于简单型数据绑定组件数据绑定的方法类似与此 *** 作
代码清单
textBox DataBindings Add ( Text dsDataSet Customers CustomerID ) ;
复杂性数据绑定
复杂性数据绑定一般是设定组件的DataSource属性和DisplayMember属性来完成数据绑定的 DataSource属性值一般设定为要绑定的DataSet DisplayMember属性值一般设定为要绑定的数据表或数据表中的某一列 DataGrid组件的数据绑定的一般实现方法是在代码清单 后 再添加代码清单 中的代码 代码清单 的功能是把DataSet中的Customers 数据表和DataGrid绑定起来 其他适用于复杂性数据绑定的组件实现数据绑定的方法类似此 *** 作
代码清单
dataGrid DataSource = dsDataSet ;dataGrid DataMember = Customers ;
四.总结
lishixinzhi/Article/program/net/201311/14485
以上就是关于用Visual C#来修改和删除数据库记录全部的内容,包括:用Visual C#来修改和删除数据库记录、C#里的DataSet到底是干什么用的,怎么用哪位高手帮我讲解讲解,谢谢啦!、visual studio2017使用c#删除SQL数据库里的一行等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)