IBATIS.net中两大常用的DAO浅谈
创始人
2024-04-17 21:10:50
0

在iBATIS.中我们可以灵活的选择DAO类型,也就是可以在底层选用不同的数据库操作方式。有常规方式、配置文件的方式、Hibernet的方式等:

1、常规方式

和我们之前的ADO.net开发较为类似,都是将sql语句写在cs代码中进行调用:

首先通过配置文件初始化:

  1. DomDaoManagerBuilder builder = new DomDaoManagerBuilder();  
  2. builder.Configure("dao" + "_" + ConfigurationManager.AppSettings["database"] + "_"  
  3.     + ConfigurationManager.AppSettings["providerType"] + ".config");  
  4. daoManager = DaoManager.GetInstance("SimpleDao");   

相对应的配置文件如下:

  1. ﹤context id="SimpleDao" default="true"﹥  
  2.     ﹤properties resource="../../database.config"/﹥  
  3.       
  4.     ﹤!-- ==== SqlClient configuration (default provider) =========    --﹥  
  5.     ﹤database﹥  
  6.         ﹤!-- Optional ( default ) --﹥  
  7.         ﹤provider name="sqlServer1.1"/﹥  
  8.         ﹤dataSource name="iBatisNet" connectionString="data 
  9. source=${datasource};database=${database};user id=${userid};password=${password};
  10. connection reset=false;connection lifetime=5; min pool size=1; max pool size=50"/﹥  
  11.     ﹤/database﹥  
  12.       
  13.     ﹤daoFactory﹥  
  14.         ﹤dao interface="IBatisNet.DataAccess.Test.Dao.
  15. Interfaces.IAccountDao, IBatisNet.DataAccess.Test" implementation="IBatisNet.
  16. DataAccess.Test.Dao.Implementations.Ado.AccountDao, IBatisNet.DataAccess.Test"/﹥  
  17.     ﹤/daoFactory﹥  
  18. ﹤/context﹥ 

然后在对应的,比如AccountDao中写具体的查询sql等

2、配置方式

将sql语句放在配置文件中,书写和修改较灵活,这也是比较常用的方式

首先通过配置文件初始化:

  1. DomDaoManagerBuilder builder = new DomDaoManagerBuilder();  
  2. builder.Configure("dao" + "_" + ConfigurationManager.AppSettings["database"] + "_"  
  3.     + ConfigurationManager.AppSettings["providerType"] + ".config");  
  4. daoManager = DaoManager.GetInstance("SqlMapDao");  

相对应的配置文件如下:

  1. ﹤context id="SqlMapDao"﹥  
  2.     ﹤properties resource="../../database.config"/﹥  
  3.     ﹤!-- ==== SqlClient configuration =========    --﹥  
  4.     ﹤database﹥  
  5.         ﹤dataSource name="iBatisNet" connectionString="data source=${datasource};
  6. database=${database};user id=${userid};password=${password};connection 
  7. reset=false;connection lifetime=5; min pool size=1; max pool size=50"/﹥  
  8.     ﹤/database﹥          
  9.       
  10.     ﹤daoSessionHandler id="SqlMap"﹥  
  11.         ﹤!--             --﹥  
  12.         ﹤property name="resource" value="SqlMap_MSSQL_SqlClient.config"/﹥  
  13.  
  14.         ﹤!-- ﹤property name="url" value="
  15. E:\Projet\iBatis\trunk\cs\mapper\IBatisNet.
  16. DataAccess.Test\bin\Debug\SqlMap_MSSQL_SqlClient.config"/﹥  
  17.         --﹥  
  18.         ﹤!--   
  19.         ﹤property name="embedded" value="bin.
  20. Debug.SqlMap_MSSQL_SqlClient.config, IBatisNet.DataAccess.Test"/﹥   
  21.         --﹥  
  22.     ﹤/daoSessionHandler﹥  
  23.       
  24.     ﹤daoFactory﹥  
  25.         ﹤dao interface="IBatisNet.DataAccess.
  26. Test.Dao.Interfaces.IAccountDao, IBatisNet.DataAccess.
  27. Test" implementation="IBatisNet.DataAccess.Test.Dao.Implementations.
  28. DataMapper.AccountDao, IBatisNet.DataAccess.Test"/﹥  
  29.     ﹤/daoFactory﹥  
  30. ﹤/context﹥ 

然后可以将每一张表的sql语句单独放在一个配置文件中,比如:

  1. ﹤select id="GetAccountsDynamic" resultMap="account-result"  parameterClass="Hashtable" ﹥  
  2.     select top $MaximumAllowed$ * from Accounts  
  3.     ﹤dynamic prepend="where"﹥  
  4.             ﹤isParameterPresent﹥  
  5.             ﹤isNotEmpty prepend="and" property="FirstName" ﹥  
  6.                     Account_FirstName LIKE '%$FirstName$%'  
  7.             ﹤/isNotEmpty﹥  
  8.             ﹤isNotEmpty prepend="and" property="LastName" ﹥  
  9.                     Account_LastName LIKE '%$LastName$%'  
  10.             ﹤/isNotEmpty﹥  
  11.             ﹤isNotEmpty prepend="and" property="EmailAddress"  ﹥  
  12.                     Account_Email LIKE '%$EmailAddress$%'  
  13.             ﹤/isNotEmpty﹥  
  14.             ﹤/isParameterPresent﹥  
  15.         ﹤/dynamic﹥  
  16.         order by Account_LastName  
  17. ﹤/select﹥ 

3、使用Hibernet方式

也就是使用Hibernet的数据库操作。

那么IBATIS.net中DAO的介绍就到这里,是不是对常用DAO有所了解了呢?

【编辑推荐】

  1. Oracle下iBATIS XML配置浅析
  2. iBATIS缓存cacheModel属性浅析
  3. Spring iBATIS整合实例演示
  4. iBATIS Spring Struts2整合实例浅析
  5. iBATIS.Net应用之下载、编译、运行NPetShop

相关内容

热门资讯

如何允许远程连接到MySQL数... [[277004]]【51CTO.com快译】默认情况下,MySQL服务器仅侦听来自localhos...
如何利用交换机和端口设置来管理... 在网络管理中,总是有些人让管理员头疼。下面我们就将介绍一下一个网管员利用交换机以及端口设置等来进行D...
施耐德电气数据中心整体解决方案... 近日,全球能效管理专家施耐德电气正式启动大型体验活动“能效中国行——2012卡车巡展”,作为该活动的...
20个非常棒的扁平设计免费资源 Apple设备的平面图标PSD免费平板UI 平板UI套件24平图标Freen平板UI套件PSD径向平...
德国电信门户网站可实时显示全球... 德国电信周三推出一个门户网站,直观地实时提供其安装在全球各地的传感器网络检测到的网络攻击状况。该网站...
为啥国人偏爱 Mybatis,... 关于 SQL 和 ORM 的争论,永远都不会终止,我也一直在思考这个问题。昨天又跟群里的小伙伴进行...
《非诚勿扰》红人闫凤娇被曝厕所... 【51CTO.com 综合消息360安全专家提醒说,“闫凤娇”、“非诚勿扰”已经被黑客盯上成为了“木...
2012年第四季度互联网状况报... [[71653]]  北京时间4月25日消息,据国外媒体报道,全球知名的云平台公司Akamai Te...