目录


SqlSession 是线程不安全的

SqlSession线程不安全 的;

对于它,我们建议在方法体内部使用;这样,即使多个线程同时访问了,每个线程都占用一片自己的内存,因此 ,sqlsession 对象就在不同的内存区域内,因此,就可以避免掉线程冲突的问题 ;


原始 dao 开发方法

原始 dao 层开发,需要我们写 接口实现类

  1. 接口

    package xin.ijava.dao;
    
    import xin.ijava.pojo.User;
    
    /**
    * @author An
    */
    public interface UserDao { /**
    * 添加用户
    * @param user 封装好的用户信息
    * @throws Exception
    */
    public void insertUser(User user) throws Exception ; /**
    * 删除用户 根据 id
    * @param id 用户 id
    * @throws Exception
    */
    public void deleteUserById(int id ) throws Exception ; /**
    * 更新用户
    * @param user 封装新信息的用户对象
    * @throws Exception
    */
    public void updateUser(User user) throws Exception ; /**
    * 查找用户
    * @param id 用户id
    * @return 用户对象
    * @throws Exception
    */
    public User findUserById(int id) throws Exception ; }
  2. 实现类

    package xin.ijava.dao;
    
    import org.apache.ibatis.session.SqlSession;
    import org.apache.ibatis.session.SqlSessionFactory;
    import xin.ijava.pojo.User; /**
    * @author An
    */
    public class UserDaoImpl implements UserDao{ /**
    * 注入sqlSessionFactory 工厂
    */
    private SqlSessionFactory factory ; public UserDaoImpl(SqlSessionFactory factory){
    this.factory = factory ;
    } @Override
    public void insertUser(User user) throws Exception {
    SqlSession sqlSession = factory.openSession() ;
    sqlSession.insert("test.insertUser",user) ;
    sqlSession.close();
    } @Override
    public void deleteUserById(int id) throws Exception {
    SqlSession sqlSession = factory.openSession() ;
    sqlSession.delete("test.deleteUserById",id) ;
    sqlSession.close();
    } @Override
    public void updateUser(User user) throws Exception {
    SqlSession sqlSession = factory.openSession() ;
    sqlSession.update("test.updateUserById",user) ;
    sqlSession.close();
    } @Override
    public User findUserById(int id) throws Exception {
    SqlSession sqlSession = factory.openSession() ;
    User user = sqlSession.selectOne("test.findUserById",id) ;
    sqlSession.close();
    return user;
    }
    }

  3. 总结

    1、上面的实现类代码中,可以看出,代码中存在着大量的模板代码,我们重复的写着这些代码;

    2、硬编码问题,我们把 statementid 硬编码到了代码中 ;

    3、参数是 object 类型,导致传任何类型的数据进去,都不会报错,即使传的数据类型根本不是映射关系中要求的类型,也不会得到报错,导致编译期间不会提示错误,直到运行期才能知道错哪了 ;


Mapper 代理方法

程序员只需要写出 mapper 接口(相当于 dao 接口)即可,无须写出实现类 ;

mapper 的开发规范:

  1. mapper.xmlnamespace 等于 mapper 接口地址

    <mapper namespace="xin.ijava.dao.UserMapper">
  2. mapper.java 接口中的方法名和 mapper.xml 中的 statementid 一致 ;

  3. mapper.java 接口中的方法输入参数类型和 mapper.xml 中的 statementparameterType 指定的类型一致 ;
  4. mapper.java 接口中的方法返回值类型和 mapper.xml 中的 statementresultType 指定的类型一致 ;

以上操作完成以后,就可以利用 mybatis 生成代理对象 ;

@Test
public void test2() throws Exception {
SqlSession sqlSession = factory.openSession() ;
// 获取代理对象,参数写上类的全路径名
UserMapper userMapper = sqlSession.getMapper(xin.ijava.dao.UserMapper.class) ;
// 利用代理对象,操作
User user = userMapper.findUserById(1) ;
System.out.println(user);
}

关于代理对象

代理对象是怎么知道具体调用什么方法的呢?

在构建代理对象的时候,会去查询 xxxMapper,xml 映射关系,根据标签名,就可以知道是调用什么方法了;标签名有: <select> 、<delete> 、<update> 、<insert>

根据接口方法名字,也就是 标签的 id 值,查询标签的名字,从而知道调用什么方法 ;

其中 select 方法,有点不同;因为有2中,selectOneselectList ;

代理对象,是根据接口的返回值来,判断调用哪一个的 ,假如接口的方法,返回单个 pojo 对象,则调用 selectOne,返回集合类型,则调用 selectList

最新文章

  1. JDK历史版本下载
  2. light oj 1047 - Neighbor House 动态规划
  3. jquery动态刷新select的值,后台传过来List&lt;T&gt;,前台解析后填充到select的option中
  4. lua中string.find()函数作用于汉字字符串
  5. Opencv step by step - ROI
  6. 在Copy-Item中集成认证信息以拷贝文件
  7. java连接数据库URL
  8. 【转】eclipse集成开发工具的插件安装
  9. iOS频繁打开相册崩溃: ALAssetsLibrary error - “Too many contexts. No space in contextList.”
  10. iOS开发之字典数据建立模型步骤
  11. gcc -L -l的使用
  12. C函数调用与栈--代码真相
  13. ASP.NET管线与应用程序生命周期
  14. Codeforces Round #271 (Div. 2) E题 Pillars(线段树维护DP)
  15. struts2框架概述
  16. Maven pom.xml中的元素modules、parent、properties以及import
  17. 《http权威指南》读书笔记15
  18. HashMap的resize方法中尾部遍历出现死循环问题 Tail Traversing (多线程)
  19. WPF窗体の投影效果
  20. Eclipse经常使用快捷键

热门文章

  1. nodejs基础(管道、流)实现:复制、压缩、加密、解压,解密,写入文件
  2. 3-2新建Photoshop图像
  3. Selenium高亮显示定位到的元素
  4. 非旋treap
  5. HDU 1069 Monkey and Banana ——(DP)
  6. Git生成本机SSH Key并添加到GitHub中
  7. vgg16 感受野计算
  8. iTerm2 + oh my zsh +agnoster
  9. oracle OPEN FOR [USING] 语句
  10. kotlin中匿名对象