拼吾爱程序人生

首页 » 数据库编程 » SQL » IBatis.Net使用方法之二:两种常用的DAO
cobra - 2008-1-26 14:47:00
文/firstyi  出处/博客园

在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的数据库操作。

 您可能对 [SQL] 的这些文章也感兴趣:

IBatis.Net使用方法之四:常用的查询方式
删除数据库中重复数据的几个方法
口令中包含@导致无法连接数据库的解决方法
PIVOT 用法详解
将表数据生成SQL脚本的存储过程
提高SQL执行效率的几点建议
XML、T-SQL 和 CLR 携手开创数据库编程新天地
select用存储过程返回的表
NHibernate之旅(17):探索NHibernate中使用存储过程(下)
SQL语言快速入门之二
1
查看完整版本: IBatis.Net使用方法之二:两种常用的DAO
Modify by pin5i DZNT_ExpandPackage 2.1.3237 2007-2008 pin5i.com
  Total Unique Visitors: