我理解的spring&ibatis

Spring与Ibatis整合实践
本文介绍了Spring与Ibatis框架的整合过程,包括配置文件设置、代码实现及启动程序的方法。通过具体实例演示了如何使用这两个框架进行数据库操作。

一、spring&ibatis是什么

spring和ibatis是两个框架,那么框架又是神马呢,框架就是用来简化编程的工具,只要按照框架所设定的规则去编程,可以极大的提高程序开发效率。

spring和ibatis就是两个简化数据库操作的框架。

二、如何才能让spring&ibatis为我所用呢

第一步:相关配置文件

1、sqlmap-config.xml,这里面描述了两种重要信息

  • 数据库表与类的映射关系
      • <typeAlias alias="User" type="org.jd.domain.User" />
    • 数据库操作方法与sql映射关系
      • <select id="getUsers" resultClass="User">
        select u.id as id, u.name as name, u.password as password
        from User u
        </select>

2、spring-config.xml,这里面主要包含三种重要的信息

  •    连接数据库的相关信息,比如驱动,用户名,密码,jdbc 链接

<bean id="mySqlDataSource" class="org.apache.commons.dbcp.BasicDataSource">
        <property name="driverClassName" value="com.mysql.jdbc.Driver" />
        <property name="url" value="jdbc:mysql://localhost:3306/test?useUnicode=true&amp;characterEncoding=utf-8" />
        <property name="username" value="root" />
        <property name="password" value="" />
    </bean>

  • 数据库映射模板,数据库

<bean id="sqlMapClient" class="org.springframework.orm.ibatis.SqlMapClientFactoryBean">
    <property name="configLocation" value="classpath:sqlmap-config.xml" />
</bean>
<bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
    <property name="dataSource">
        <ref local="mySqlDataSource" />
    </property>
</bean>

  • 数据库操作对象

<bean id="testDao" class="org.jd.impl.TestDaoImpl">
    <property name="dataSource" ref="mySqlDataSource"></property>
    <property name="sqlMapClient" ref="sqlMapClient"></property>
</bean>

第二步:代码实现

这里以数据库一张User表作为例子来实现数据读取操作

  1. domain中实现数据表对应的类
    • User

      public class User {

          private int id;
          private String name;
          private String password;

      //此处省略set和get方法

      }

  2. dao类
    • TestDaoImpl

      public class TestDaoImpl extends BaseDao {

          public List<User> getUsers(){
              return queryForList("testSqlMap.getUsers");
          }
         
          public User getUserByName(String name){
              return (User)queryForObject("testSqlMap.getUserByName", name);
          }
      }

  3. dataService类
    • DataServiceImpl

      public class DataServiceImpl {

          private TestDaoImpl testDao;

          /**
           * @return the testDao
           */
          public TestDaoImpl getTestDao() {
              return testDao;
          }

          /**
           * @param testDao the testDao to set
           */
          public void setTestDao(TestDaoImpl testDao) {
              this.testDao = testDao;
          }
         
          public List<User> getUsers(){
              return this.testDao.getUsers();
          }
         
      }

第三步:启动程序

ApplicationContext context = new ClassPathXmlApplicationContext(new String[] { "spring-config.xml" });
DataServiceImpl dataService = (DataServiceImpl)context.getBean("dataService");
List<User> users = dataService.getUsers();
for(User user : users){
    System.out.println(user.getName()+"  "+user.getPassword());
}

例子程序下载地址:http://pan.baidu.com/s/1kTt4ejX

转载于:https://my.oschina.net/shiw019/blog/194199

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值