IBatis.Net学习笔记三--两种常用的DAO

转载 2007年09月19日 09:35:00
在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的数据库操作。 

相关文章推荐

ado.net学习笔记(1)常用代码

Ado.net 学习笔记     常见的  返回语句   ExecuteNonQuery返回值是执行的影响行数 SqlCommand的ExecuteScalar方法用于执行查询,并返回查询...

ASP.NET常用信息保持状态学习笔记一

2012-05-08 19:57 1、ViewState:ViewState是ASP.NET中.aspx特有的,通过HTTP报文传递,所有服务器端控件的值都会自动保存在ViewState   中...
  • YunanWu
  • YunanWu
  • 2012年11月16日 19:51
  • 540

ASP.NET常用信息保持状态学习笔记二

2012-05-11 22:06   3、Session          Session数据保存在服务器端中。每个客户端的相关session都独立存储,因为SessionId以coo...
  • YunanWu
  • YunanWu
  • 2012年11月16日 19:59
  • 530

Asp.net控件开发学习笔记(三)-控件开发基础

原文:http://www.cnblogs.com/CareySon/archive/2009/10/02/1577402.html封装     在asp.net中,控件被分为两类.用户控件和自定义服...

C Sharp与.net学习笔记(三)

先简单了解一下C#下插件框架。插件一般就是定义了某个特定接口的并被动态加载的动态库。应用程序启动后,可以查找(比如某个特定目录)、动态加载、识别(某个特定接口)、使用插件(调用接口函数等)。 现在....

ADO.NET学习笔记(三)

(1)登陆窗体的登陆过程验证: using System; using System.Windows.Forms; using System.Data.SqlClient; namespace...

Quartz.NET(作业调度框架) 学习笔记(三)【Cron 表达式】

有这么几个问题? 1,  每天的2点到6点之间每15分钟对服务器上某个文件夹进行搜索 2,  每周的周5的8点45分对数据库进行备份 3,  每月的最后一天8点创建销售报表 4,  我要在,每...

VB.net学习笔记(三)调试

1、下断点 就是在代码左侧处点一下鼠标,代码执行到此处,就会断下来 2、显示立即值 断后,鼠标指向变量时会显示值。 同时会有一个小窗体,可点图钉,让其固定显示 ...

iBATIS.net常用的查询方式浅析

iBATIS.net常用的查询方式浅析(转)
  • cpcpc
  • cpcpc
  • 2011年01月09日 22:31
  • 417
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:IBatis.Net学习笔记三--两种常用的DAO
举报原因:
原因补充:

(最多只允许输入30个字)