IBatis.Net学习笔记三--两种常用的DAO
2007-09-19 09:35
441 查看
在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的数据库操作。
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
- IBatis .NET 开发学习笔记——简要介绍
- iBATIS.NET 学习笔记(七)
- iBATIS.NET 学习笔记(一)
- iBatis.net 学习笔记
- .Net学习笔记7-.Net基础2 常用类库
- iBATIS.NET 学习笔记(二)
- IBatis.Net学习笔记五--常用的查询方式
- 关于Ibatis.net ,将List<T> 作为参数的学习笔记
- iBATIS.NET 学习笔记(五)
- .net学习笔记----WebConfig常用配置节点介绍
- IBatis.net学习笔记_基础配置
- .NET学习笔记:文件和注册表操作
- android 开发零起步学习笔记(十一):界面切换+几种常用界面切换效果
- 学习.net笔记(2)
- 学习.net笔记(3)
- Linux运维学习笔记之二:常用命令1
- .net环境下ckeditor与ckfinder学习笔记
- [Python] Python学习笔记之常用模块总结[持续更新...]
- 步步为营 .NET 代码重构学习笔记 六