zoukankan
html css js c++ java
DataAdapter数据集DataSet和数据库的同步(1):DataRowVersion,Mapping
/**/
/*
--===------------------------------------------===---
DataAdapter的数据映射:表和列映射
许明会 2007年12月22日 22:18:09
DataSet包含DataTable类型的集合Tables。
每个DataTable又包含DataRow类型的Rows集合,包含DataColumn类型的Columns集合,还有表间关系的Relations集合。
DataTable dataTable = dataSet.Tables[0];
DataRow dataRow = dataSet.Tables[0].Rows[0];
取得表0的0行0列值:
object columnValue = dataSet.Tables[0].Rows[0][0];
//--===------------------------------------------===---
DataRowVersion的变化:
DataRow的BeginEdit方法调用后,Current,Proposed值可用。
DataRow的CancelEdit方法调用后,Proposed值被删除。
DataRow的EndEdit方法调用后,Proposed值变成Current值。
DataRow的AcceptChanges调用后,Original值修改为Current值。
DataRow的RejectChanges调用后,Proposed值被丢弃,版本变成Current。
DataTable的AcceptChanges调用后,Original值改为Current值。
//--===------------------------------------------===---
数据适配器DataAdapter的方法:
1.Fill:把数据从数据源加载到数据集DataSet中。
2.Update:把数据从数据集加载到数据源中。
//--===------------------------------------------===---
Fill方法:
1.Fill(DataSet)
2.Fill(DataTable)
3.Fill(DataSet,tableName);
4.Fill(DataTable,DataReader):用指定的DataReader填充数据表
★默认情况下,调用DataAdapter的Fill方法时,除了会填充DataSet之外,还会自动调用DataSet.AcceptChanges,调用后所有的行状态都不是“新改变的”,此时Original和Current的值是一样的。
★如果希望从多个数据源填充一个DataSet,再将其写回另外一个数据存储,这时要把DataAdapter的属性AcceptChangesDuringFill设置为false,以便让结果行表现为新添加的行。
Update方法:
1.Update(DataSet):根据指定的数据集中的数据表更新数据源
2.Update(DataTable):根据指定的数据表更新数据源
3.Update(dataRows):根据指定的数据行数组更新数据源
当调用Update方法时,DataAdapter将分析已作出的更改并执行相应的命令(Insert,Update,Delete). 当DataAdapter遇到DataRow的更改时,他将使用InsertCommand, UpdateCommand, DeleteCommand来处理更爱. 如此就可以通过在设计时制定命令语法并在可能时通过使用存储过程来尽量提高Ado.net应用程序的性能. 在调用Update命令前,保证用于更改数据的3个Command存在,否则将引发异常.
--===------------------------------------------===---
*/
using
System;
using
System.Data;
using
System.Data.SqlClient;
namespace
xumh
{
public
class
runMyApp
{
static
void
Main()
{
SqlConnection cn
=
new
SqlConnection(
@"
server=.; database=northwind; integrated security=true
"
);
SqlDataAdapter da
=
new
SqlDataAdapter(
"
select firstname,lastname,title from employees
"
,cn);
DataSet dsEmployees
=
new
DataSet();
try
{
cn.Open();
//
数据映射,TableMapping.Add 的参数1,要和DbAdapter.Fill 的参数2一致;或者Add方法参数1设为"Table",Fill方法参数2省略。
da.TableMappings.Add(
"
Employees
"
,
"
员工表
"
);
da.TableMappings[
0
].ColumnMappings.Add(
"
firstname
"
,
"
姓
"
);
da.TableMappings[
0
].ColumnMappings.Add(
"
lastname
"
,
"
名
"
);
da.TableMappings[
0
].ColumnMappings.Add(
"
title
"
,
"
职位
"
);
da.Fill(dsEmployees,
"
Employees
"
);
//
Employees和上面表映射对应,不能省略
//
输出数据:ColumnMappings集合实现Field名称映射;将ColumnMappings对象添加到TableMappings对象;将TableMappings对象挂到DbDataAdapter。
foreach
(DataRow row
in
dsEmployees.Tables[
0
].Rows)
Console.WriteLine(
"
{0}\t{1}\t{2}
"
,row[
"
姓
"
],row[
"
名
"
],row[
"
职位
"
]);
}
catch
(Exception ex)
{
Console.WriteLine(ex.Message);
}
finally
{
cn.Close();
}
}
}
;
}
查看全文
相关阅读:
【分布式】Zookeeper会话
【分布式】Zookeeper客户端
【分布式】Zookeeper序列化及通信协议
【分布式】Zookeeper系统模型
【分布式】Zookeeper在大型分布式系统中的应用
【分布式】Zookeeper应用场景
【分布式】Zookeeper使用--开源客户端
【分布式】Zookeeper使用--Java API
【分布式】Zookeeper使用--命令行
【杂文】从实习到校招到工作
原文地址:https://www.cnblogs.com/flaaash/p/1011122.html
最新文章
今日头条的核心架构解析
高并发性能调试经验分享
Linux服务器文件删除空间未释放的问题
Nginx状态码499
Nginx 切片模块、断点续传
Linux服务器下nginx的安全配置
【Scala】Scala之String
【Zookeeper】源码分析之Watcher机制(二)之WatchManager
【Zookeeper】源码分析之Watcher机制(一)
【Zookeeper】源码分析之持久化(三)之FileTxnSnapLog
热门文章
【Zookeeper】源码分析之持久化(二)之FileSnap
【Zookeeper】源码分析之持久化(一)之FileTxnLog
【Zookeeper】源码分析之序列化
【杂文】2016年度总结
【目录】Zookeeper目录
【分布式】Zookeeper数据与存储
【分布式】Zookeeper请求处理
【分布式】Zookeeper的服务器角色
【分布式】Zookeeper的Leader选举
【分布式】Zookeeper服务端启动
Copyright © 2011-2022 走看看