iBATIS中添加DAO的配置浅析

开发 后端
iBATIS中添加DAO支持的配置是如何进行的呢?我们通过五大步骤向你介绍具体的情况。

iBATIS中添加DAO的配置是如何的呢,之前我们介绍iBATIS的基本配置,那么我们现在来说下添加DAO的操作,首先让我们配置XML文件开始:

iBATIS中添加DAO的配置一.

添加配置文件dao.xml

  1. ﹤?xml version="1.0" encoding="UTF-8"?﹥  
  2. ﹤!DOCTYPE daoConfig PUBLIC "-//ibatis.apache.org//DTD DAO Configuration 2.0//EN" "http://ibatis.apache.org/dtd/dao-2.dtd"﹥  
  3. ﹤daoConfig﹥  
  4.     ﹤context﹥  
  5.         ﹤transactionManager type="SQLMAP"﹥  
  6.             ﹤property name="SqlMapConfigResource" 
  7.                       value="yidishui/daoIbatisImpl/sql/SqlMapConfig.xml"/﹥  
  8.         ﹤/transactionManager﹥  
  9.         ﹤dao interface="yidishui.dao.PersonDao"  implementation="yidishui.daoIbatisImpl.PersonDaoImpl2"/﹥  
  10.     ﹤/context﹥  
  11. ﹤/daoConfig﹥ 

iBATIS中添加DAO的配置二.

添加DaoConfig类

  1. package yidishui;  
  2.  
  3. import com.ibatis.dao.client.DaoManager;  
  4. import com.ibatis.dao.client.DaoManagerBuilder;  
  5. import com.ibatis.common.resources.Resources;  
  6.  
  7. import java.io.Reader;  
  8. import java.util.Properties;  
  9.  
  10. public class DaoConfig {  
  11.     private static final String resource = "yidishui/dao.xml";  
  12.     private static final DaoManager daoManager;  
  13.  
  14.     static {  
  15.         daoManager = newDaoManager(null);  
  16.     }  
  17.  
  18.     public static DaoManager getDaoManager() {  
  19.         return daoManager;  
  20.     }  
  21.  
  22.     public static DaoManager newDaoManager(Properties props) {  
  23.         try {  
  24.             Reader reader = Resources.getResourceAsReader(resource);  
  25.             return DaoManagerBuilder.buildDaoManager(reader, props);  
  26.         } catch (Exception e) {  
  27.             throw new RuntimeException("Could not initialize DaoConfig.  Cause: " + e, e);  
  28.         }  
  29.     }  

iBATIS中添加DAO的配置三.

修改Dao实现,添加类PersonDaoImpl2

  1. package yidishui.daoIbatisImpl;  
  2.  
  3. import yidishui.dao.PersonDao;  
  4. import yidishui.domain.Person;  
  5.  
  6. import java.util.List;  
  7. import java.sql.SQLException;  
  8.  
  9. import com.ibatis.dao.client.template.SqlMapDaoTemplate;  
  10. import com.ibatis.dao.client.DaoManager;  
  11.  
  12. public class PersonDaoImpl2 extends SqlMapDaoTemplate implements PersonDao {  
  13.     public PersonDaoImpl2(DaoManager daoManager) {  
  14.         super(daoManager);  
  15.     }  
  16.  
  17.     public void insertPerson(Person person) throws SQLException {  
  18.         insert("insertPerson", person);  
  19.     }  
  20.  
  21.     public void updatePerson(Person person) throws SQLException {  
  22.         update("updatePerson", person);  
  23.     }  
  24.  
  25.     public Person getPersonById(int personId) throws SQLException {  
  26.         return (Person) queryForObject("getPersonById", personId);  
  27.     }  
  28.  
  29.     public void deletePerson(int personId) throws SQLException {  
  30.         delete("deletePerson", personId);  
  31.     }  
  32.  
  33.     public List allPersonList() throws SQLException {  
  34.         return queryForList("allPersonList"null);  
  35.     }  

iBATIS中添加DAO的配置四,

测试PersonDaoImpl2Test(正确行验证)

  1. package yidishui.daoIbatisImpl;  
  2. import junit.framework.*;  
  3. import yidishui.daoIbatisImpl.PersonDaoImpl;  
  4. import yidishui.domain.Person;  
  5. import yidishui.dao.PersonDao;  
  6. import yidishui.DaoConfig;  
  7.  
  8. import java.sql.SQLException;  
  9. import java.util.List;  
  10.  
  11. import com.ibatis.dao.client.DaoManager;  
  12.  
  13. public class PersonDaoImpl2Test extends TestCase {  
  14.  
  15.     DaoManager daoManager;  
  16.  
  17.     protected void setUp() throws Exception {  
  18.         daoManager = DaoConfig.getDaoManager();  
  19.     }  
  20.  
  21.     public void testInsertPerson() {  
  22.         PersonDao personDao = (PersonDao) daoManager.getDao(PersonDao.class);  
  23.  
  24.         Person person = new Person();  
  25.         person.setPersonName("yidishui");  
  26.         person.setPersonEmail("yidishui1570@gamil.com");  
  27.         person.setPersonAge(100);  
  28.  
  29.         try {  
  30.             personDao.insertPerson(person);  
  31.         } catch (SQLException e) {  
  32.             e.printStackTrace();  //To change body of catch statement use File | Settings | File Templates.  
  33.         }  
  34.  
  35.     }  
  36.  
  37.     public void testUpdatePerson() throws Exception {  
  38.         PersonDao personDao = (PersonDao) daoManager.getDao(PersonDao.class);  
  39.         Person person = new Person();  
  40.         person.setPersonId(1);  
  41.         person.setPersonName("caotao");  
  42.         person.setPersonEmail("caotao1570@gamil.com");  
  43.         person.setPersonAge(1100);  
  44.         personDao.updatePerson(person);  
  45.  
  46.     }  
  47.  
  48.     public void testDeletePerson() throws Exception {  
  49.         PersonDao personDao = (PersonDao) daoManager.getDao(PersonDao.class);  
  50.         personDao.deletePerson(1);  
  51.     }  
  52.  
  53.     public void testAllPersonList() throws Exception {  
  54.         PersonDao personDao = (PersonDao) daoManager.getDao(PersonDao.class);  
  55.         List list = personDao.allPersonList();  
  56.         assertTrue("list size is 0", list.size() ﹥ 0);  
  57.         for (int i = 0; i ﹤ list.size(); i++) {  
  58.             Person person = (Person) list.get(i);  
  59.             System.out.println(person.getPersonName());  
  60.         }  
  61.     }  
  62.  

iBATIS中添加DAO的配置五.

运行测试

测试成功ok完成

iBATIS中添加DAO支持的配置及测试就向你介绍到这里,希望对你有所了解.

【编辑推荐】

  1. iBATIS DAO事务浅析
  2. iBATIS使用$和#的一些理解
  3. iBATIS分页的一些理解
  4. iBATIS应用之SQLMap API编程浅析
  5. 动态Mapped Statement在iBATIS中应用
责任编辑:仲衡 来源: BlogJava
相关推荐

2009-07-20 18:00:16

iBATIS DAO事

2009-07-16 09:14:26

iBATIS DAO

2009-07-17 14:20:31

ibatis Dao

2009-07-20 14:56:18

iBATIS.NET动态选择DAO

2009-07-21 11:12:00

iBATIS配置

2009-07-22 15:01:01

iBATIS SQLM

2009-07-22 09:44:05

iBATIS Para

2009-07-16 17:01:32

ibatis dao

2009-07-17 16:49:18

iBATIS XML配

2009-07-22 16:27:24

iBATIS配置类iBATIS操作类

2009-07-21 17:39:50

iBATIS的多对多映

2009-07-16 16:27:33

ibatis DAO

2009-07-21 13:08:08

iBATIS DAO

2009-07-22 11:11:39

iBATIS分页实例ObjectDataS

2009-07-17 10:59:59

iBATIS接口

2009-07-20 09:27:42

IBATIS.netDAO

2009-07-22 13:32:43

iBATIS DAO

2009-07-15 17:58:07

iBATIS 动态映射

2009-07-22 10:42:59

iBATIS Cach

2009-07-16 10:23:30

iBATIS工作原理
点赞
收藏

51CTO技术栈公众号