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();
}
}
}
;
}
查看全文
相关阅读:
git常用操作
Spring学习(5):DI的配置
007.python学习课程(元组)
006.python学习课程(列表)
004.python学习课程(循环语句)
005.python学习课程(字符串)
003.python学习课程(条件语句)
002.python学习课程(输入、赋值、计算)
001.python学习课程(环境搭建、变量、数据类型、输出)
asterisk 目录
原文地址:https://www.cnblogs.com/flaaash/p/1011122.html
最新文章
骨骼动画 cocos2d-x + cocoStudio <cocos2d-x : version 2.2.0>
3.4 常用的两种 layer 层 3.7 字体与文本
516.最长回文子序列
1143.最长公共子序列
go语言int类型最大值
746使用最小花费爬楼梯
linux调度策略CFS
链表快排
并查集
二分查找
热门文章
Go语言集合
快排
多线程原理篇(1)-JMM内存模型
实现分布式锁技术:Redisson
MySql读写分离实现
使用DFA算法,实现敏感词过滤
SSO流程
Memcached服务器上实现多个实例(约约问题排查)
线程学习笔记(一)
Dubbo问题处理集合
Copyright © 2011-2022 走看看