快速学习-使用 spring 的 IoC 的实现账户的CRUD

第1章 案例:使用 spring 的 IoC 的实现账户的CRUD

1.1 需求和技术要求

1.1.1 需求

实现账户的 CRUD 操作

1.1.2 技术要求

使用 spring 的 IoC 实现对象的管理 使用 DBAssit 作为持久层解决方案 使用 c3p0 数据源

1.2 环境搭建

1.2.1 拷贝 jar 包

1.2.2 创建数据库和编写实体类

create table account(  id int primary key auto_increment,  name varchar(40),  money float  )character set utf8 collate utf8_general_ci;  insert into account(name,money) values('aaa',1000);  insert into account(name,money) values('bbb',1000);  insert into account(name,money) values('ccc',1000);
public class Account implements Serializable {        private Integer id;      private String name;      private Float money;        public Integer getId() {          return id;      }        public void setId(Integer id) {          this.id = id;      }        public String getName() {          return name;      }        public void setName(String name) {          this.name = name;      }        public Float getMoney() {          return money;      }        public void setMoney(Float money) {          this.money = money;      }        @Override      public String toString() {          return "Account{" +                  "id=" + id +                  ", name='" + name + ''' +                  ", money=" + money +                  '}';      }  }

1.2.3 编写持久层代码

public interface IAccountDao {        /**       * 查询所有       * @return       */      List<Account> findAllAccount();        /**       * 查询一个       * @return       */      Account findAccountById(Integer accountId);        /**       * 保存       * @param account       */      void saveAccount(Account account);        /**       * 更新       * @param account       */      void updateAccount(Account account);        /**       * 删除       * @param acccountId       */      void deleteAccount(Integer acccountId);  }
@Repository("accountDao")  public class AccountDaoImpl implements IAccountDao {        @Autowired      private QueryRunner runner;            @Override      public List<Account> findAllAccount() {          try{              return runner.query("select * from account",new BeanListHandler<Account>(Account.class));          }catch (Exception e) {              throw new RuntimeException(e);          }      }        @Override      public Account findAccountById(Integer accountId) {          try{              return runner.query("select * from account where id = ? ",new BeanHandler<Account>(Account.class),accountId);          }catch (Exception e) {              throw new RuntimeException(e);          }      }        @Override      public void saveAccount(Account account) {          try{              runner.update("insert into account(name,money)values(?,?)",account.getName(),account.getMoney());          }catch (Exception e) {              throw new RuntimeException(e);          }      }        @Override      public void updateAccount(Account account) {          try{              runner.update("update account set name=?,money=? where id=?",account.getName(),account.getMoney(),account.getId());          }catch (Exception e) {              throw new RuntimeException(e);          }      }        @Override      public void deleteAccount(Integer accountId) {          try{              runner.update("delete from account where id=?",accountId);          }catch (Exception e) {              throw new RuntimeException(e);          }      }  }

1.2.4 编写业务层代码

public interface IAccountService {        /**       * 查询所有       * @return       */      List<Account> findAllAccount();        /**       * 查询一个       * @return       */      Account findAccountById(Integer accountId);        /**       * 保存       * @param account       */      void saveAccount(Account account);        /**       * 更新       * @param account       */      void updateAccount(Account account);        /**       * 删除       * @param acccountId       */      void deleteAccount(Integer acccountId);      }
@Service("accountService")  public class AccountServiceImpl implements IAccountService{        @Autowired      private IAccountDao accountDao;        @Override      public List<Account> findAllAccount() {          return accountDao.findAllAccount();      }        @Override      public Account findAccountById(Integer accountId) {          return accountDao.findAccountById(accountId);      }        @Override      public void saveAccount(Account account) {          accountDao.saveAccount(account);      }        @Override      public void updateAccount(Account account) {          accountDao.updateAccount(account);      }        @Override      public void deleteAccount(Integer acccountId) {          accountDao.deleteAccount(acccountId);      }  }

1.2.5 创建并编写配置文件

<?xml version="1.0" encoding="UTF-8"?>  <beans      xmlns="http://www.springframework.org/schema/beans"      xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"   xsi:schemaLocation="http://www.springframework.org/schema/beans   http://www.springframework.org/schema/beans/spring-beans.xsd">  </beans>

1.3 配置步骤

1.3.1 配置对象

<?xml version="1.0" encoding="UTF-8"?>  <beans      xmlns="http://www.springframework.org/schema/beans"      xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"   xsi:schemaLocation="http://www.springframework.org/schema/beans   http://www.springframework.org/schema/beans/spring-beans.xsd">      <!-- 配置 service -->      <bean id="accountService"  class="com.itheima.service.impl.AccountServiceImpl">          <property name="accountDao" ref="accountDao"></property>      </bean>      <!-- 配置 dao -->      <bean id="accountDao" class="com.itheima.dao.impl.AccountDaoImpl">          <property name="dbAssit" ref="dbAssit"></property>      </bean>      <!-- 配置 dbAssit 此处我们只注入了数据源,表明每条语句独立事务-->      <bean id="dbAssit" class="com.itheima.dbassit.DBAssit">          <property name="dataSource" ref="dataSource"></property>      </bean>      <!-- 配置数据源 -->      <bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource">          <property name="driverClass" value="com.mysql.jdbc.Driver"></property>          <property name="jdbcUrl" value="jdbc:mysql:///spring_day02"></property>          <property name="user" value="root"></property>          <property name="password" value="1234"></property>      </bean>  </beans>

1.4 测试案例

1.4.1 测试类代码

@RunWith(SpringJUnit4ClassRunner.class)  @ContextConfiguration(locations = "classpath:bean.xml")  public class AccountServiceTest {        @Autowired      private  IAccountService as;        @Test      public void testFindAll() {          //3.执行方法          List<Account> accounts = as.findAllAccount();          for(Account account : accounts){              System.out.println(account);          }      }        @Test      public void testFindOne() {          //3.执行方法          Account account = as.findAccountById(1);          System.out.println(account);      }        @Test      public void testSave() {          Account account = new Account();          account.setName("test");          account.setMoney(12345f);          //3.执行方法          as.saveAccount(account);        }        @Test      public void testUpdate() {          //3.执行方法          Account account = as.findAccountById(4);          account.setMoney(23456f);          as.updateAccount(account);      }        @Test      public void testDelete() {          //3.执行方法          as.deleteAccount(4);      }  }

1.4.2 分析测试了中的问题

通过上面的测试类,我们可以看出,每个测试方法都重新获取了一次 spring 的核心容器,造成了不必要的重复代码,增加了我们开发的工作量。这种情况,在开发中应该避免发生。

有些同学可能想到了,我们把容器的获取定义到类中去。例如:

public class AccountServiceTest {  	private ApplicationContext ac = new ClassPathXmlApplicationContext("bean.xml");  	private IAccountService as = ac.getBean("accountService", IAccountService.class);  }

这种方式虽然能解决问题,但是扔需要我们自己写代码来获取容器。