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

mybatis学习笔记(4)-开发dao方法

本文讲解SqlSession,并对两种方法(原始dao开发和mapper代理开发)分别做简单展示...
  • h3243212
  • h3243212
  • 2016年02月27日 20:36
  • 2609

Chrome学习笔记(三):UI组件,皮肤引擎

原创文章,转载请注明:转载自Soul Apogee 本文链接地址:Chrome学习笔记(三):UI组件,皮肤引擎 —— 控件库 这篇文章是接着上篇文章继续聊的,Chrome的代码实在太多,每一...
  • wanfengnianhua
  • wanfengnianhua
  • 2017年04月25日 18:56
  • 251

超全的css新手学习笔记

适合新手的css学习笔记,超级全面
  • qq_34477549
  • qq_34477549
  • 2016年10月11日 10:27
  • 1644

Dubbo框架学习笔记(三)

Dubbo源码地址:https://github.com/alibaba/dubbo Dubbo开发指南:http://dubbo.io/Developer+Guide-zh.htm Dubbo服务...
  • koalacoco
  • koalacoco
  • 2017年04月03日 20:46
  • 217

跟初学者学习IbatisNet第一篇

写在前面的话:我自己也是一个初学者,写这个专题只是为了对学过知识的巩固,如果有什么不对的地方,欢迎大家指正……………………     第一篇就简单介绍一下什么是IbatisNet,然后写一个简单的De...
  • dyllove98
  • dyllove98
  • 2013年07月27日 20:41
  • 2991

≪统计学习精要(The Elements of Statistical Learning)≫课堂笔记(三)

照例文章第一段跑题,先附上个段子(转载的哦~): I hate CS people. They don't know linear algebra but want to teach pro...
  • xiebaochun
  • xiebaochun
  • 2014年06月29日 10:02
  • 3682

Deep Learning(深度学习)学习笔记整理系列之(四)

Deep Learning(深度学习)学习笔记整理系列 zouxy09@qq.com http://blog.csdn.net/zouxy09 作者:Zouxy version 1.0 201...
  • zouxy09
  • zouxy09
  • 2013年04月09日 00:46
  • 270698

Deep Learning(深度学习) 学习笔记(三)

前言:昨天看到微博上分享的深度学习视频,为上海复旦大学吴立德教授深度学习课程,一共六课时,视频地址点击打开链接。在此我结合其他资料,写点个人的学习笔记进行记录。 第三,四课:稀疏编码 本课吴老师...
  • hellonlp
  • hellonlp
  • 2014年01月18日 10:38
  • 5094

MyBatis association的两种形式——MyBatis学习笔记之四

一、嵌套的resultMap       这种方法本质上就是上篇博文介绍的方法,只是把教师实体映射从association元素中提取出来,用一个resultMap元素表示。然后association...
  • u014196852
  • u014196852
  • 2014年04月02日 10:35
  • 972

Scala学习笔记1 - 基础

本文档针对scala 2.10.x,由于scala目前发展迅速,因此可能会和其他版本的不同。 ===概述          scala是一门以java虚拟机(JVM)为目标运行环境并将面向对象和函...
  • guohecang
  • guohecang
  • 2016年08月04日 11:47
  • 721
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:IBatis.Net学习笔记三--两种常用的DAO
举报原因:
原因补充:

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