天天看點

IBatis.Net學習筆記三--兩種常用的DAO

在IBatis中我們可以靈活的選擇DAO類型,也就是可以在底層選用不同的資料庫操作方式。有正常方式、配置檔案的方式、Hibernet的方式等:

1、正常方式

和我們之前的ADO.NET開發較為類似,都是将sql語句寫在cs代碼中進行調用:

首先通過配置檔案初始化:

IBatis.Net學習筆記三--兩種常用的DAO

            DomDaoManagerBuilder builder = new DomDaoManagerBuilder();

IBatis.Net學習筆記三--兩種常用的DAO

            builder.Configure("dao" + "_" + ConfigurationManager.AppSettings["database"] + "_"

IBatis.Net學習筆記三--兩種常用的DAO

                + ConfigurationManager.AppSettings["providerType"] + ".config");

IBatis.Net學習筆記三--兩種常用的DAO

            daoManager = DaoManager.GetInstance("SimpleDao");        

IBatis.Net學習筆記三--兩種常用的DAO

相對應的配置檔案如下:

IBatis.Net學習筆記三--兩種常用的DAO

    <context id="SimpleDao" default="true">

IBatis.Net學習筆記三--兩種常用的DAO

        <properties resource="../../database.config"/>

IBatis.Net學習筆記三--兩種常用的DAO
IBatis.Net學習筆記三--兩種常用的DAO

        <!-- ==== SqlClient configuration (default provider) =========    -->

IBatis.Net學習筆記三--兩種常用的DAO

        <database>

IBatis.Net學習筆記三--兩種常用的DAO

            <!-- Optional ( default ) -->

IBatis.Net學習筆記三--兩種常用的DAO

            <provider name="sqlServer1.1"/>

IBatis.Net學習筆記三--兩種常用的DAO

            <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"/>

IBatis.Net學習筆記三--兩種常用的DAO

        </database>

IBatis.Net學習筆記三--兩種常用的DAO
IBatis.Net學習筆記三--兩種常用的DAO

        <daoFactory>

IBatis.Net學習筆記三--兩種常用的DAO

            <dao interface="IBatisNet.DataAccess.Test.Dao.Interfaces.IAccountDao, IBatisNet.DataAccess.Test" implementation="IBatisNet.DataAccess.Test.Dao.Implementations.Ado.AccountDao, IBatisNet.DataAccess.Test"/>

IBatis.Net學習筆記三--兩種常用的DAO

        </daoFactory>

IBatis.Net學習筆記三--兩種常用的DAO

    </context>

然後在對應的,比如AccountDao中寫具體的查詢sql等

2、配置方式

将sql語句放在配置檔案中,書寫和修改較靈活,這也是比較常用的方式

IBatis.Net學習筆記三--兩種常用的DAO
IBatis.Net學習筆記三--兩種常用的DAO
IBatis.Net學習筆記三--兩種常用的DAO
IBatis.Net學習筆記三--兩種常用的DAO

            daoManager = DaoManager.GetInstance("SqlMapDao");        

IBatis.Net學習筆記三--兩種常用的DAO

    <context id="SqlMapDao">

IBatis.Net學習筆記三--兩種常用的DAO
IBatis.Net學習筆記三--兩種常用的DAO

        <!-- ==== SqlClient configuration =========    -->

IBatis.Net學習筆記三--兩種常用的DAO
IBatis.Net學習筆記三--兩種常用的DAO
IBatis.Net學習筆記三--兩種常用的DAO

        </database>        

IBatis.Net學習筆記三--兩種常用的DAO
IBatis.Net學習筆記三--兩種常用的DAO

        <daoSessionHandler id="SqlMap">

IBatis.Net學習筆記三--兩種常用的DAO

            <!--             -->

IBatis.Net學習筆記三--兩種常用的DAO

            <property name="resource" value="SqlMap_MSSQL_SqlClient.config"/>

IBatis.Net學習筆記三--兩種常用的DAO
IBatis.Net學習筆記三--兩種常用的DAO

            <!-- <property name="url" value="E:\Projet\iBatis\trunk\cs\mapper\IBatisNet.DataAccess.Test\bin\Debug\SqlMap_MSSQL_SqlClient.config"/>

IBatis.Net學習筆記三--兩種常用的DAO

            -->

IBatis.Net學習筆記三--兩種常用的DAO

            <!-- 

IBatis.Net學習筆記三--兩種常用的DAO

            <property name="embedded" value="bin.Debug.SqlMap_MSSQL_SqlClient.config, IBatisNet.DataAccess.Test"/> 

IBatis.Net學習筆記三--兩種常用的DAO
IBatis.Net學習筆記三--兩種常用的DAO

        </daoSessionHandler>

IBatis.Net學習筆記三--兩種常用的DAO
IBatis.Net學習筆記三--兩種常用的DAO
IBatis.Net學習筆記三--兩種常用的DAO

            <dao interface="IBatisNet.DataAccess.Test.Dao.Interfaces.IAccountDao, IBatisNet.DataAccess.Test" implementation="IBatisNet.DataAccess.Test.Dao.Implementations.DataMapper.AccountDao, IBatisNet.DataAccess.Test"/>

IBatis.Net學習筆記三--兩種常用的DAO
IBatis.Net學習筆記三--兩種常用的DAO

然後可以将每一張表的sql語句單獨放在一個配置檔案中,比如:

IBatis.Net學習筆記三--兩種常用的DAO

        <select id="GetAccountsDynamic" resultMap="account-result" parameterClass="Hashtable" >

IBatis.Net學習筆記三--兩種常用的DAO

            select top $MaximumAllowed$ * from Accounts

IBatis.Net學習筆記三--兩種常用的DAO

            <dynamic prepend="where">

IBatis.Net學習筆記三--兩種常用的DAO

                    <isParameterPresent>

IBatis.Net學習筆記三--兩種常用的DAO

                    <isNotEmpty prepend="and" property="FirstName" >

IBatis.Net學習筆記三--兩種常用的DAO

                            Account_FirstName LIKE '%$FirstName$%'

IBatis.Net學習筆記三--兩種常用的DAO

                    </isNotEmpty>

IBatis.Net學習筆記三--兩種常用的DAO

                    <isNotEmpty prepend="and" property="LastName" >

IBatis.Net學習筆記三--兩種常用的DAO

                            Account_LastName LIKE '%$LastName$%'

IBatis.Net學習筆記三--兩種常用的DAO
IBatis.Net學習筆記三--兩種常用的DAO

                    <isNotEmpty prepend="and" property="EmailAddress"  >

IBatis.Net學習筆記三--兩種常用的DAO

                            Account_Email LIKE '%$EmailAddress$%'

IBatis.Net學習筆記三--兩種常用的DAO
IBatis.Net學習筆記三--兩種常用的DAO

                    </isParameterPresent>

IBatis.Net學習筆記三--兩種常用的DAO

                </dynamic>

IBatis.Net學習筆記三--兩種常用的DAO

                order by Account_LastName

IBatis.Net學習筆記三--兩種常用的DAO

        </select>

3、使用Hibernet方式

也就是使用Hibernet的資料庫操作。

    本文轉自永春部落格園部落格,原文連結:http://www.cnblogs.com/firstyi/archive/2007/08/17/859772.html,如需轉載請自行聯系原作者