资讯

精准传达 • 有效沟通

从品牌网站建设到网络营销策划,从策略到执行的一站式服务

怎么浅谈IBATIS.net中两大常用的DAO

这篇文章给大家介绍怎么浅谈IBATIS.net中两大常用的DAO,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。

创新互联-专业网站定制、快速模板网站建设、高性价比岚皋网站开发、企业建站全套包干低至880元,成熟完善的模板库,直接使用。一站式岚皋网站制作公司更省心,省钱,快速模板网站建设找我们,业务覆盖岚皋地区。费用合理售后完善,十年实体公司更值得信赖。

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

1、常规方式

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

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

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

相对应的配置文件如下:

﹤context id="SimpleDao" default="true"﹥      ﹤properties resource="../../database.config"/﹥            ﹤!-- ==== SqlClient configuration (default provider) =========    --﹥      ﹤database﹥          ﹤!-- Optional ( default ) --﹥          ﹤provider name="sqlServer1.1"/﹥          ﹤dataSource name="iBatisNet" connectionString="data source=${datasource};database=${database};user id=${userid};password=${password};connection reset=false;connection lifetime=5; min pool size=1; max pool size=50"/﹥      ﹤/database﹥            ﹤daoFactory﹥          ﹤dao interface="IBatisNet.DataAccess.Test.Dao.Interfaces.IAccountDao, IBatisNet.DataAccess.Test" implementation="IBatisNet.DataAccess.Test.Dao.Implementations.Ado.AccountDao, IBatisNet.DataAccess.Test"/﹥      ﹤/daoFactory﹥  ﹤/context﹥

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

2、配置方式

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

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

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

相对应的配置文件如下:

﹤context id="SqlMapDao"﹥      ﹤properties resource="../../database.config"/﹥      ﹤!-- ==== SqlClient configuration =========    --﹥      ﹤database﹥          ﹤dataSource name="iBatisNet" connectionString="data source=${datasource};database=${database};user id=${userid};password=${password};connection reset=false;connection lifetime=5; min pool size=1; max pool size=50"/﹥      ﹤/database﹥                    ﹤daoSessionHandler id="SqlMap"﹥          ﹤!--             --﹥          ﹤property name="resource" value="SqlMap_MSSQL_SqlClient.config"/﹥           ﹤!-- ﹤property name="url" value="E:\Projet\iBatis\trunk\cs\mapper\IBatisNet.DataAccess.Test\bin\Debug\SqlMap_MSSQL_SqlClient.config"/﹥          --﹥          ﹤!--           ﹤property name="embedded" value="bin.Debug.SqlMap_MSSQL_SqlClient.config, IBatisNet.DataAccess.Test"/﹥           --﹥      ﹤/daoSessionHandler﹥            ﹤daoFactory﹥          ﹤dao interface="IBatisNet.DataAccess.Test.Dao.Interfaces.IAccountDao, IBatisNet.DataAccess.Test" implementation="IBatisNet.DataAccess.Test.Dao.Implementations.DataMapper.AccountDao, IBatisNet.DataAccess.Test"/﹥      ﹤/daoFactory﹥  ﹤/context﹥

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

﹤select id="GetAccountsDynamic" resultMap="account-result"  parameterClass="Hashtable" ﹥      select top $MaximumAllowed$ * from Accounts      ﹤dynamic prepend="where"﹥              ﹤isParameterPresent﹥              ﹤isNotEmpty prepend="and" property="FirstName" ﹥                      Account_FirstName LIKE '%$FirstName$%'              ﹤/isNotEmpty﹥              ﹤isNotEmpty prepend="and" property="LastName" ﹥                      Account_LastName LIKE '%$LastName$%'              ﹤/isNotEmpty﹥              ﹤isNotEmpty prepend="and" property="EmailAddress"  ﹥                      Account_Email LIKE '%$EmailAddress$%'              ﹤/isNotEmpty﹥              ﹤/isParameterPresent﹥          ﹤/dynamic﹥          order by Account_LastName  ﹤/select﹥

3、使用Hibernet方式

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

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

关于怎么浅谈IBATIS.net中两大常用的DAO就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。


新闻标题:怎么浅谈IBATIS.net中两大常用的DAO
文章来源:http://www.cdkjz.cn/article/jjepop.html
多年建站经验

多一份参考,总有益处

联系快上网,免费获得专属《策划方案》及报价

咨询相关问题或预约面谈,可以通过以下方式与我们联系

大客户专线   成都:13518219792   座机:028-86922220