ToB企服应用市场:ToB评测及商务社交产业平台

标题: 六 在WEB中应用MyBatis(使用MVC架构模式) [打印本页]

作者: 科技颠覆者    时间: 2024-11-4 23:00
标题: 六 在WEB中应用MyBatis(使用MVC架构模式)
六、在WEB中应用MyBatis(使用MVC架构模式)

实现功能:

使用技能:

WEB应用的名称:

6.1 需求形貌


6.2 数据库表的计划和准备数据



6.3 实现步调

第一步:环境搭建













  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <web-app xmlns="https://jakarta.ee/xml/ns/jakartaee"
  3.          xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  4.          xsi:schemaLocation="https://jakarta.ee/xml/ns/jakartaee
  5.                       https://jakarta.ee/xml/ns/jakartaee/web-app_5_0.xsd"
  6.          version="5.0"
  7.          metadata-complete="true">
  8. </web-app>
复制代码

  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  3.          xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
  4.     <modelVersion>4.0.0</modelVersion>
  5.     <groupId>com.study</groupId>
  6.     <artifactId>mybatis-004-web</artifactId>
  7.     <version>1.0-SNAPSHOT</version>
  8.     <packaging>war</packaging>
  9.     <name>mybatis-004-web</name>
  10.     <url>http://localhost:8080/bank</url>
  11.     <properties>
  12.         <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
  13.         <maven.compiler.source>17</maven.compiler.source>
  14.         <maven.compiler.target>17</maven.compiler.target>
  15.     </properties>
  16.     <dependencies>
  17.         <!--mybatis依赖-->
  18.         <dependency>
  19.             <groupId>org.mybatis</groupId>
  20.             <artifactId>mybatis</artifactId>
  21.             <version>3.5.10</version>
  22.         </dependency>
  23.         <!--mysql驱动依赖-->
  24.         <dependency>
  25.             <groupId>mysql</groupId>
  26.             <artifactId>mysql-connector-java</artifactId>
  27.             <version>8.0.30</version>
  28.         </dependency>
  29.         <!--junit依赖-->
  30.         <dependency>
  31.             <groupId>junit</groupId>
  32.             <artifactId>junit</artifactId>
  33.             <version>4.13.2</version>
  34.             <scope>test</scope>
  35.         </dependency>
  36.         <!--logback依赖-->
  37.         <dependency>
  38.             <groupId>ch.qos.logback</groupId>
  39.             <artifactId>logback-classic</artifactId>
  40.             <version>1.2.11</version>
  41.         </dependency>
  42.         <!--servlet依赖-->
  43.         <dependency>
  44.             <groupId>jakarta.servlet</groupId>
  45.             <artifactId>jakarta.servlet-api</artifactId>
  46.             <version>5.0.0</version>
  47.             <scope>provided</scope>
  48.         </dependency>
  49.     </dependencies>
  50.     <build>
  51.         <finalName>mybatis-004-web</finalName>
  52.         <pluginManagement>
  53.             <plugins>
  54.                 <plugin>
  55.                     <artifactId>maven-clean-plugin</artifactId>
  56.                     <version>3.1.0</version>
  57.                 </plugin>
  58.                 <plugin>
  59.                     <artifactId>maven-resources-plugin</artifactId>
  60.                     <version>3.0.2</version>
  61.                 </plugin>
  62.                 <plugin>
  63.                     <artifactId>maven-compiler-plugin</artifactId>
  64.                     <version>3.8.0</version>
  65.                 </plugin>
  66.                 <plugin>
  67.                     <artifactId>maven-surefire-plugin</artifactId>
  68.                     <version>2.22.1</version>
  69.                 </plugin>
  70.                 <plugin>
  71.                     <artifactId>maven-war-plugin</artifactId>
  72.                     <version>3.2.2</version>
  73.                 </plugin>
  74.                 <plugin>
  75.                     <artifactId>maven-install-plugin</artifactId>
  76.                     <version>2.5.2</version>
  77.                 </plugin>
  78.                 <plugin>
  79.                     <artifactId>maven-deploy-plugin</artifactId>
  80.                     <version>2.8.2</version>
  81.                 </plugin>
  82.             </plugins>
  83.         </pluginManagement>
  84.     </build>
  85. </project>
复制代码

  1. jdbc.driver=com.mysql.cj.jdbc.Driver
  2. jdbc.url=jdbc:mysql://localhost:3306/study
  3. jdbc.username=root
  4. jdbc.password=root
复制代码
  1. <?xml version="1.0" encoding="UTF-8" ?>
  2. <!DOCTYPE configuration
  3.         PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
  4.         "http://mybatis.org/dtd/mybatis-3-config.dtd">
  5. <configuration>
  6.     <properties resource="jdbc.properties"/>
  7.     <environments default="dev">
  8.         <environment id="dev">
  9.             <transactionManager type="JDBC"/>
  10.             <dataSource type="POOLED">
  11.                 <property name="driver" value="${jdbc.driver}"/>
  12.                 <property name="url" value="${jdbc.url}"/>
  13.                 <property name="username" value="${jdbc.username}"/>
  14.                 <property name="password" value="${jdbc.password}"/>
  15.             </dataSource>
  16.         </environment>
  17.     </environments>
  18.     <mappers>
  19.         <!--一定要注意这里的路径哦!!!-->
  20.         <mapper resource="AccountMapper.xml"/>
  21.     </mappers>
  22. </configuration>
复制代码
  1. <?xml version="1.0" encoding="UTF-8" ?>
  2. <!DOCTYPE mapper
  3.         PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
  4.         "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
  5. <mapper namespace="account">
  6. </mapper>
复制代码
第二步:前端页面index.html

  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4.     <meta charset="UTF-8">
  5.     <title>银行账户转账</title>
  6. </head>
  7. <body>
  8. <!--/bank是应用的根,部署web应用到tomcat的时候一定要注意这个名字-->
  9. <form action="/bank/transfer" method="post">
  10.     转出账户:<input type="text" name="fromActno"/><br>
  11.     转入账户:<input type="text" name="toActno"/><br>
  12.     转账金额:<input type="text" name="money"/><br>
  13.     <input type="submit" value="转账"/>
  14. </form>
  15. </body>
  16. </html>
复制代码
第三步:创建pojo包、service包、dao包、web包、utils包


第四步:定义pojo类:Account

  1. package com.study.bank.pojo;
  2. /**
  3. * 银行账户类
  4. * @author sqnugy
  5. * @version 1.0
  6. * @since 1.0
  7. */
  8. public class Account {
  9.     private Long id;
  10.     private String actno;
  11.     private Double balance;
  12.     @Override
  13.     public String toString() {
  14.         return "Account{" +
  15.                 "id=" + id +
  16.                 ", actno='" + actno + '\'' +
  17.                 ", balance=" + balance +
  18.                 '}';
  19.     }
  20.     public Account() {
  21.     }
  22.     public Account(Long id, String actno, Double balance) {
  23.         this.id = id;
  24.         this.actno = actno;
  25.         this.balance = balance;
  26.     }
  27.     public Long getId() {
  28.         return id;
  29.     }
  30.     public void setId(Long id) {
  31.         this.id = id;
  32.     }
  33.     public String getActno() {
  34.         return actno;
  35.     }
  36.     public void setActno(String actno) {
  37.         this.actno = actno;
  38.     }
  39.     public Double getBalance() {
  40.         return balance;
  41.     }
  42.     public void setBalance(Double balance) {
  43.         this.balance = balance;
  44.     }
  45. }
复制代码
第五步:编写AccountDao接口,以及AccountDaoImpl实现类

分析dao中至少要提供几个方法,才华完成转账:

  1. package com.study.bank.dao;
  2. import com.study.bank.pojo.Account;
  3. /**
  4. * 账户数据访问对象
  5. * @author sqnugy
  6. * @version 1.0
  7. * @since 1.0
  8. */
  9. public interface AccountDao {
  10.     /**
  11.      * 根据账号获取账户信息
  12.      * @param actno 账号
  13.      * @return 账户信息
  14.      */
  15.     Account selectByActno(String actno);
  16.     /**
  17.      * 更新账户信息
  18.      * @param act 账户信息
  19.      * @return 1表示更新成功,其他值表示失败
  20.      */
  21.     int update(Account act);
  22. }
复制代码
  1. package com.study.bank.dao.impl;
  2. import com.study.bank.dao.AccountDao;
  3. import com.study.bank.pojo.Account;
  4. import com.study.bank.utils.SqlSessionUtil;
  5. import org.apache.ibatis.session.SqlSession;
  6. public class AccountDaoImpl implements AccountDao {
  7.     @Override
  8.     public Account selectByActno(String actno) {
  9.         SqlSession sqlSession = SqlSessionUtil.openSession();
  10.         Account act = (Account)sqlSession.selectOne("selectByActno", actno);
  11.         sqlSession.close();
  12.         return act;
  13.     }
  14.     @Override
  15.     public int update(Account act) {
  16.         SqlSession sqlSession = SqlSessionUtil.openSession();
  17.         int count = sqlSession.update("update", act);
  18.         sqlSession.commit();
  19.         sqlSession.close();
  20.         return count;
  21.     }
  22. }
复制代码
第六步:AccountDaoImpl中编写了mybatis代码,需要编写SQL映射文件了

  1. <?xml version="1.0" encoding="UTF-8" ?>
  2. <!DOCTYPE mapper
  3.         PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
  4.         "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
  5. <mapper namespace="account">
  6.     <select id="selectByActno" resultType="com.study.bank.pojo.Account">
  7.         select * from t_act where actno = #{actno}
  8.     </select>
  9.     <update id="update">
  10.         update t_act set balance = #{balance} where actno = #{actno}
  11.     </update>
  12. </mapper>
复制代码
第七步:编写AccountService接口以及AccountServiceImpl

  1. package com.study.bank.exception;
  2. /**
  3. * 余额不足异常
  4. * @author sqnugy
  5. * @version 1.0
  6. * @since 1.0
  7. */
  8. public class MoneyNotEnoughException extends Exception{
  9.     public MoneyNotEnoughException(){}
  10.     public MoneyNotEnoughException(String msg){ super(msg); }
  11. }
复制代码
  1. package com.study.bank.exception;
  2. /**
  3. * 应用异常
  4. * @author sqnugy
  5. * @version 1.0
  6. * @since 1.0
  7. */
  8. public class AppException extends Exception{
  9.     public AppException(){}
  10.     public AppException(String msg){ super(msg); }
  11. }
复制代码
  1. package com.study.bank.service;
  2. import com.study.bank.exception.AppException;
  3. import com.study.bank.exception.MoneyNotEnoughException;
  4. /**
  5. * 账户业务类。
  6. * @author sqnugy
  7. * @version 1.0
  8. * @since 1.0
  9. */
  10. public interface AccountService {
  11.     /**
  12.      * 银行账户转正
  13.      * @param fromActno 转出账户
  14.      * @param toActno 转入账户
  15.      * @param money 转账金额
  16.      * @throws MoneyNotEnoughException 余额不足异常
  17.      * @throws AppException App发生异常
  18.      */
  19.     void transfer(String fromActno, String toActno, double money) throws MoneyNotEnoughException, AppException;
  20. }
复制代码
  1. package com.study.bank.service.impl;
  2. import com.study.bank.dao.AccountDao;
  3. import com.study.bank.dao.impl.AccountDaoImpl;
  4. import com.study.bank.exception.AppException;
  5. import com.study.bank.exception.MoneyNotEnoughException;
  6. import com.study.bank.pojo.Account;
  7. import com.study.bank.service.AccountService;
  8. public class AccountServiceImpl implements AccountService {
  9.     private AccountDao accountDao = new AccountDaoImpl();
  10.     @Override
  11.     public void transfer(String fromActno, String toActno, double money) throws MoneyNotEnoughException, AppException {
  12.         // 查询转出账户的余额
  13.         Account fromAct = accountDao.selectByActno(fromActno);
  14.         if (fromAct.getBalance() < money) {
  15.             throw new MoneyNotEnoughException("对不起,您的余额不足。");
  16.         }
  17.         try {
  18.             // 程序如果执行到这里说明余额充足
  19.             // 修改账户余额
  20.             Account toAct = accountDao.selectByActno(toActno);
  21.             fromAct.setBalance(fromAct.getBalance() - money);
  22.             toAct.setBalance(toAct.getBalance() + money);
  23.             // 更新数据库
  24.             accountDao.update(fromAct);
  25.             accountDao.update(toAct);
  26.         } catch (Exception e) {
  27.             throw new AppException("转账失败,未知原因!");
  28.         }
  29.     }
  30. }
复制代码
第八步:编写AccountController

  1. package com.study.bank.web.controller;
  2. import com.study.bank.exception.AppException;
  3. import com.study.bank.exception.MoneyNotEnoughException;
  4. import com.study.bank.service.AccountService;
  5. import com.study.bank.service.impl.AccountServiceImpl;
  6. import javax.servlet.ServletException;
  7. import javax.servlet.http.HttpServlet;
  8. import javax.servlet.http.HttpServletRequest;
  9. import javax.servlet.http.HttpServletResponse;
  10. import java.io.IOException;
  11. import java.io.PrintWriter;
  12. /**
  13. * 账户控制器
  14. * @author sqnugy
  15. * @version 1.0
  16. * @since 1.0
  17. */
  18. @WebServlet("/transfer")
  19. public class AccountController extends HttpServlet {
  20.     private AccountService accountService = new AccountServiceImpl();
  21.     @Override
  22.     protected void doPost(HttpServletRequest request, HttpServletResponse response)
  23.             throws ServletException, IOException {
  24.         // 获取响应流
  25.         response.setContentType("text/html;charset=UTF-8");
  26.         PrintWriter out = response.getWriter();
  27.         // 获取账户信息
  28.         String fromActno = request.getParameter("fromActno");
  29.         String toActno = request.getParameter("toActno");
  30.         double money = Integer.parseInt(request.getParameter("money"));
  31.         // 调用业务方法完成转账
  32.         try {
  33.             accountService.transfer(fromActno, toActno, money);
  34.             out.print("<h1>转账成功!!!</h1>");
  35.         } catch (MoneyNotEnoughException e) {
  36.             out.print(e.getMessage());
  37.         } catch (AppException e) {
  38.             out.print(e.getMessage());
  39.         }
  40.     }
  41. }
复制代码
启动服务器,打开浏览器,输入地址:http://localhost:8080/bank,测试:



6.4 MyBatis对象作用域以及事务问题

6.4.1 MyBatis焦点对象的作用域

SqlSessionFactoryBuilder
这个类可以被实例化、使用和丢弃,一旦创建了 SqlSessionFactory,就不再需要它了。 因此 SqlSessionFactoryBuilder 实例的最佳作用域是方法作用域(也就是局部方法变量)。 你可以重用 SqlSessionFactoryBuilder 来创建多个 SqlSessionFactory 实例,但最好照旧不要一直保留着它,以保证所有的 XML 解析资源可以被开释给更重要的事情。
SqlSessionFactory
SqlSessionFactory 一旦被创建就应该在应用的运行期间一直存在,没有任何理由丢弃它或重新创建另一个实例。 使用 SqlSessionFactory 的最佳实践是在应用运行期间不要重复创建多次,多次重建 SqlSessionFactory 被视为一种代码“坏习惯”。因此 SqlSessionFactory 的最佳作用域是应用作用域。 有很多方法可以做到,最简朴的就是使用单例模式或者静态单例模式。
SqlSession
每个线程都应该有它本身的 SqlSession 实例。SqlSession 的实例不是线程安全的,因此是不能被共享的,以是它的最佳的作用域是哀求或方法作用域。 绝对不能将 SqlSession 实例的引用放在一个类的静态域,甚至一个类的实例变量也不可。 也绝不能将 SqlSession 实例的引用放在任何类型的托管作用域中,比如 Servlet 框架中的 HttpSession。 假如你现在正在使用一种 Web 框架,考虑将 SqlSession 放在一个和 HTTP 哀求相似的作用域中。 换句话说,每次收到 HTTP 哀求,就可以打开一个 SqlSession,返回一个响应后,就关闭它。 这个关闭操作很重要,为了确保每次都能执行关闭操作,你应该把这个关闭操作放到 finally 块中。 下面的示例就是一个确保 SqlSession 关闭的标准模式:
  1. try (SqlSession session = sqlSessionFactory.openSession()) {
  2.   // 你的应用逻辑代码
  3. }
复制代码
6.4.2 事务问题

在之前的转账业务中,更新了两个账户,我们需要保证它们的同时乐成或同时失败,这个时间就需要使用事务机制,在transfer方法开始执行时开启事务,直到两个更新都乐成之后,再提交事务,我们尝试将transfer方法举行如下修改:
  1. package com.study.bank.service.impl;
  2. import com.study.bank.dao.AccountDao;
  3. import com.study.bank.dao.impl.AccountDaoImpl;
  4. import com.study.bank.exception.AppException;
  5. import com.study.bank.exception.MoneyNotEnoughException;
  6. import com.study.bank.pojo.Account;
  7. import com.study.bank.service.AccountService;
  8. import com.study.bank.utils.SqlSessionUtil;
  9. import org.apache.ibatis.session.SqlSession;
  10. public class AccountServiceImpl implements AccountService {
  11.     private AccountDao accountDao = new AccountDaoImpl();
  12.     @Override
  13.     public void transfer(String fromActno, String toActno, double money) throws MoneyNotEnoughException, AppException {
  14.         // 查询转出账户的余额
  15.         Account fromAct = accountDao.selectByActno(fromActno);
  16.         if (fromAct.getBalance() < money) {
  17.             throw new MoneyNotEnoughException("对不起,您的余额不足。");
  18.         }
  19.         try {
  20.             // 程序如果执行到这里说明余额充足
  21.             // 修改账户余额
  22.             Account toAct = accountDao.selectByActno(toActno);
  23.             fromAct.setBalance(fromAct.getBalance() - money);
  24.             toAct.setBalance(toAct.getBalance() + money);
  25.             // 更新数据库(添加事务)
  26.             SqlSession sqlSession = SqlSessionUtil.openSession();
  27.             accountDao.update(fromAct);
  28.             // 模拟异常
  29.             String s = null;
  30.             s.toString();
  31.             accountDao.update(toAct);
  32.             sqlSession.commit();
  33.             sqlSession.close();
  34.         } catch (Exception e) {
  35.             throw new AppException("转账失败,未知原因!");
  36.         }
  37.     }
  38. }
复制代码
运行前注意看数据库表中当前的数据:

执行步伐:


再次查看数据库表中的数据:

傻眼了吧!!!事务出问题了,转账失败了,钱仍旧是少了1万。这是什么缘故原由呢?主要是因为service和dao中使用的SqlSession对象不是同一个。
怎么办?为了保证service和dao中使用的SqlSession对象是同一个,可以将SqlSession对象存放到ThreadLocal当中。修改SqlSessionUtil工具类:
  1. package com.study.bank.utils;
  2. import org.apache.ibatis.io.Resources;
  3. import org.apache.ibatis.session.SqlSession;
  4. import org.apache.ibatis.session.SqlSessionFactory;
  5. import org.apache.ibatis.session.SqlSessionFactoryBuilder;
  6. /**
  7. * MyBatis工具类
  8. *
  9. * @author sqnugy
  10. * @version 1.0
  11. * @since 1.0
  12. */
  13. public class SqlSessionUtil {
  14.     private static SqlSessionFactory sqlSessionFactory;
  15.     /**
  16.      * 类加载时初始化sqlSessionFactory对象
  17.      */
  18.     static {
  19.         try {
  20.             SqlSessionFactoryBuilder sqlSessionFactoryBuilder = new SqlSessionFactoryBuilder();
  21.             sqlSessionFactory = sqlSessionFactoryBuilder.build(Resources.getResourceAsStream("mybatis-config.xml"));
  22.         } catch (Exception e) {
  23.             e.printStackTrace();
  24.         }
  25.     }
  26.     private static ThreadLocal<SqlSession> local = new ThreadLocal<>();
  27.     /**
  28.      * 每调用一次openSession()可获取一个新的会话,该会话支持自动提交。
  29.      *
  30.      * @return 新的会话对象
  31.      */
  32.     public static SqlSession openSession() {
  33.         SqlSession sqlSession = local.get();
  34.         if (sqlSession == null) {
  35.             sqlSession = sqlSessionFactory.openSession();
  36.             local.set(sqlSession);
  37.         }
  38.         return sqlSession;
  39.     }
  40.     /**
  41.      * 关闭SqlSession对象
  42.      * @param sqlSession
  43.      */
  44.     public static void close(SqlSession sqlSession){
  45.         if (sqlSession != null) {
  46.             sqlSession.close();
  47.         }
  48.         local.remove();
  49.     }
  50. }
复制代码
修改dao中的方法:AccountDaoImpl中所有方法中的提交commit和关闭close代码全部删除。
  1. package com.study.bank.dao.impl;
  2. import com.study.bank.dao.AccountDao;
  3. import com.study.bank.pojo.Account;
  4. import com.study.bank.utils.SqlSessionUtil;
  5. import org.apache.ibatis.session.SqlSession;
  6. public class AccountDaoImpl implements AccountDao {
  7.     @Override
  8.     public Account selectByActno(String actno) {
  9.         SqlSession sqlSession = SqlSessionUtil.openSession();
  10.         Account act = (Account)sqlSession.selectOne("account.selectByActno", actno);
  11.         return act;
  12.     }
  13.     @Override
  14.     public int update(Account act) {
  15.         SqlSession sqlSession = SqlSessionUtil.openSession();
  16.         int count = sqlSession.update("account.update", act);
  17.         return count;
  18.     }
  19. }
复制代码
修改service中的方法:
  1. package com.study.bank.service.impl;
  2. import com.study.bank.dao.AccountDao;
  3. import com.study.bank.dao.impl.AccountDaoImpl;
  4. import com.study.bank.exception.AppException;
  5. import com.study.bank.exception.MoneyNotEnoughException;
  6. import com.study.bank.pojo.Account;
  7. import com.study.bank.service.AccountService;
  8. import com.study.bank.utils.SqlSessionUtil;
  9. import org.apache.ibatis.session.SqlSession;
  10. public class AccountServiceImpl implements AccountService {
  11.     private AccountDao accountDao = new AccountDaoImpl();
  12.     @Override
  13.     public void transfer(String fromActno, String toActno, double money) throws MoneyNotEnoughException, AppException {
  14.         // 查询转出账户的余额
  15.         Account fromAct = accountDao.selectByActno(fromActno);
  16.         if (fromAct.getBalance() < money) {
  17.             throw new MoneyNotEnoughException("对不起,您的余额不足。");
  18.         }
  19.         try {
  20.             // 程序如果执行到这里说明余额充足
  21.             // 修改账户余额
  22.             Account toAct = accountDao.selectByActno(toActno);
  23.             fromAct.setBalance(fromAct.getBalance() - money);
  24.             toAct.setBalance(toAct.getBalance() + money);
  25.             // 更新数据库(添加事务)
  26.             SqlSession sqlSession = SqlSessionUtil.openSession();
  27.             accountDao.update(fromAct);
  28.             // 模拟异常
  29.             String s = null;
  30.             s.toString();
  31.             accountDao.update(toAct);
  32.             sqlSession.commit();
  33.             SqlSessionUtil.close(sqlSession);  // 只修改了这一行代码。
  34.         } catch (Exception e) {
  35.             throw new AppException("转账失败,未知原因!");
  36.         }
  37.     }
  38. }
复制代码
当前数据库表中的数据:

再次运行步伐:


查看数据库表:没有问题。

再测试转账乐成:



假如余额不足呢:


账户的余额依然正常:

6.5 分析当出息序存在的问题

我们来看一下DaoImpl的代码
  1. package com.study.bank.dao.impl;
  2. import com.study.bank.dao.AccountDao;
  3. import com.study.bank.pojo.Account;
  4. import com.study.bank.utils.SqlSessionUtil;
  5. import org.apache.ibatis.session.SqlSession;
  6. public class AccountDaoImpl implements AccountDao {
  7.     @Override
  8.     public Account selectByActno(String actno) {
  9.         SqlSession sqlSession = SqlSessionUtil.openSession();
  10.         Account act = (Account)sqlSession.selectOne("account.selectByActno", actno);
  11.         return act;
  12.     }
  13.     @Override
  14.     public int update(Account act) {
  15.         SqlSession sqlSession = SqlSessionUtil.openSession();
  16.         int count = sqlSession.update("account.update", act);
  17.         return count;
  18.     }
  19. }
复制代码
我们不难发现,这个dao实现类中的方法代码很固定,基本上就是一行代码,通过SqlSession对象调用insert、delete、update、select等方法,这个类中的方法没有任何业务逻辑,既然是这样,这个类我们能不能动态的天生,以后可以不写这个类吗?答案:可以。

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。




欢迎光临 ToB企服应用市场:ToB评测及商务社交产业平台 (https://dis.qidao123.com/) Powered by Discuz! X3.4