日期:2014-05-20  浏览次数:20801 次

散分+分享:访问任何数据库,都是这么简单,只需三句话
一、基础应用
话不多说,代码为证。以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://files.cnblogs.com/icyplayer/Icyplayer.rar

二、高级应用
我们发现上面两段代码执行后都得到了一个数据管理器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://files.cnblogs.com/icyplayer/Icyplayer.rar

三、原理
上述代码看起来很简洁,然而微软的东西向来以繁琐著称,相信接触过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.svnhost.cn/Project/Detail-2011.shtml


------解决方案--------------------

------解决方案--------------------
大汗~~~
------解决方案--------------------
up,接分
------解决方案--------------------
呵呵
up
------解决方案--------------------
学习了
------解决方案--------------------
study
------解决方案--------------------
why?

我就一句话搞定..... 增删改(包括批量,存储过程);
------解决方案--------------------
up
------解决方案--------------------
感谢LZ 学习:)
------解决方案--------------------
学习间接分
------解决方案--------------------
Up~

------解决方案--------------------
谢谢LZ
------解决方案--------------------
面向数据库设计...汗~!快速开发...
------解决方案--------------------
不错,学习