| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 604 人关注过本帖
标题:访问数据库的一些知识
取消只看楼主 加入收藏
s718539339
Rank: 2
等 级:论坛游民
帖 子:28
专家分:21
注 册:2012-2-13
结帖率:0
收藏
 问题点数:0 回复次数:0 
访问数据库的一些知识
一、基础应用
话不多说,代码为证。以Access数据库为例:
DataManager dm = new OleDbManager(@"x:\data.mdb");
dm.Open();
dm.Exec("any SQL Command");//执行SQL语句,返回受响应的行数

以SQL Server数据库为例:
DataManager dm = new SQLManager("serverIP", "database", "uid", "pwd");
dm.Open();
DataTable dt = dm.Select("select * from table1");//将查询结果导入DataTable中

如果您指示想简单高效的访问数据库,实现上述代码,您需要下载Icyplayer.Data开源库
地址:http://

二、高级应用
我们发现上面两段代码执行后都得到了一个数据管理器DataManager dm,无论是Access还是SqlServer,从而为数据库迁移提供了极大方便。
于是我们使用上述的dm对象,实现数据库的异步更新:
DataUpdater updater = dm.AllocateDataUpdater();
DataTable dt = updater.SelectWithUpdate("select * from table1");
//此处可以任意修改DataTable dt,增加、修改、删除行等。
updater.Update(dt);

上面三句则实现了数据库的异步更新。

如果不是Access数据库也不是SqlServer数据库,如何连接?
以自定义的连接字符串为例(MySQL):
DataManager dm = new OleDbManager();
dm.ConnString = "Driver={mySQL};Server=localhost;Option=16834;Database=myDataBase;";
dm.OpenByConnString()
这样我们还是可以得到一个通用的DataManager dm;进行各种操作。

如果这些功能已经满足了您的要求,或者需要了解更多功能,请下载Icyplayer开源库,参考附带的开发帮助
地址:http://

三、原理
上述代码看起来很简洁,然而微软的东西向来以繁琐著称,相信接触过Win32API的朋友们都有深刻感触,于是我们不得不把很多功能进行封装,以便更方便的使用。下面是Icyplayer.Data的原理:
1、通用的数据库操作
DataManager类封装了一组抽象方法(更像一个接口),OleDbManager和SQLManager类则继承DataManager并实现了这些方法,于是通过DataManager的对象来访问不同数据库,只需修改连接代码,而其他访问代码都无需修改。

2、异步更新
我们需要两个对象:
//OleDbDataAdapter用来承载sql语句的执行结果,它可以把结果导出到DataTable或DataSet中
System.Data.OleDb.OleDbDataAdapter _dap;
//OleDbCommandBuilder必须关联一个OleDbDataAdapter,可以根据OleDbDataAdapter的查询结果自动生成更新sql语句
System.Data.OleDb.OleDbCommandBuilder _cmdb;
首先建立数据库连接:
System.Data.OleDb.OleDbConnection _conn;
_conn = new OleDbConnection();
_conn.ConnectionString = SQL_ConnectString;
_conn.Open();
然后,使_cmdb关联到_dap,并执行SQLCmd语句,把结果填充到dt中
DataTable dt = new DataTable();
_dap = new OleDbDataAdapter(SQLCmd, dataManager._conn);
_cmdb = new OleDbCommandBuilder(_dap);
_dap.Fill(dt);
此时,我们就可以修改dt中的内容
最后,提交更新
_dap.Update(dt);

这就是让.net 帮我们自动生成sql语句的过程,简单吧~
如果您有兴趣,可以下载Icyplayer类库的全部源代码
svn地址:http://www.

对c#很感兴趣的朋友不妨来QQ群交流下
.NET技术交流群:34634356


[ 本帖最后由 s718539339 于 2012-2-20 16:34 编辑 ]
搜索更多相关主题的帖子: 数据库 database 知识 
2012-02-20 16:31
快速回复:访问数据库的一些知识
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.035395 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved