1 

2 

3 

传统dao开发实现CRUD

3.1    传统dao开发实现crud

使用 Mybatis 开发 Dao,通常有两个方法,即原始 Dao开发方式和 Mapper 接口代理开发方式。而现在主流的开发方式是接口代理开发方式,这种方式总体上更加简便。

本次课来了解一下传统dao开发方式:编写dao接口的实现类。

3.2    开发步骤、核心代码和配置

1.        创建项目,导包,导入日志配置文件

2.        创建实体类

3.        创建dao接口

public List<Users> findAllUsers();

    List<Users> findAllUsers();

    Users findById(intid);

    void insertUser(Users users);

    void updateUser(Users users);

    void deleteUser(intid);

配置开发环境,配置别名,配置sql映射文件注入

4.        配置核心配置文件

5.        创建dao接口的实现类

publicclass UserDaoImpl implements IUsersDao{

    private SqlSessionFactory factory;

    public UserDaoImpl(SqlSessionFactory factory) {

       this.factory = factory;

    }

    //查询所有用户

    @Override

    public List<Users> findAllUsers() {

       SqlSession sqlsession = factory.openSession();

       //参数值为:映射文件中的namespace属性值+select标签的id值

       List<Users> users = sqlsession.selectList("com.hebi.dao.IUsersDao.findAllUsers");

       sqlsession.close();

       returnusers;

    }

    //根据id查询用户

    @Override

    public Users findById(intid) {

       SqlSession sqlsession = factory.openSession();

       //参数值为:映射文件中的namespace属性值+select标签的id值

       Users users = sqlsession.selectOne("com.hebi.dao.IUsersDao.findById",id);

       sqlsession.close();

       returnusers;

    }

    //添加用户

    @Override

    publicvoid insertUser(Users users) {

       SqlSession sqlsession = factory.openSession();

       //参数值为:映射文件中的namespace属性值+select标签的id值

        sqlsession.insert("com.hebi.dao.IUsersDao.insertUser",users);

       sqlsession.commit();

       sqlsession.close();

    }

    //修改用户

    @Override

    publicvoid updateUser(Users users) {

       SqlSession sqlsession = factory.openSession();

       //参数值为:映射文件中的namespace属性值+select标签的id值

        sqlsession.update("com.hebi.dao.IUsersDao.updateUser",users);

       sqlsession.commit();

       sqlsession.close();

    }

    //删除用户

    @Override

    publicvoid deleteUser(intid) {

       SqlSession sqlsession = factory.openSession();

       //参数值为:映射文件中的namespace属性值+select标签的id值

       sqlsession.delete("com.hebi.dao.IUsersDao.deleteUser",id);

       sqlsession.commit();

       sqlsession.close();

    }  

}

6.        配置映射配置文件

配置namespace和select,  insert   update   delete标签

7.        编写测试类进行测试

publicclass Test01 {

    InputStream in;

    SqlSessionFactory factory;

    IUsersDao userDao;

@Before//测试方法执行前执行

    publicvoid init() throws IOException {

       //1)读取核心配置文件

       in = Resources.getResourceAsStream("mybatis-config.xml");

       //2)创建sqlSessionFactory

       factory = new SqlSessionFactoryBuilder().build(in);

       //3)创建userDao对象

       userDao = new UserDaoImpl(factory);

    }

    @After//测试方法执行后执行

    publicvoid destory() throws IOException {

       in.close();

    }

    //测试查询所有用户

    @Test

    publicvoid testAllUser() throws IOException {

       //调用dao实现类中的方法

       List<Users> users = userDao.findAllUsers();

       for(Users u:users) {

           System.out.println(u);

       }      

    }

    //测试根据id查询用户

    @Test

    publicvoid testFindById() throws IOException {

       //调用dao实现类中的方法

       Users user = userDao.findById(2);          

       System.out.println(user);

    }

    //测试添加用户

    @Test

    publicvoid testInsertUser() throws IOException {

       Users users = new Users();

       users.setUserName("天空");

       users.setAge(16);

       userDao.insertUser(users);

       System.out.println(users);

    }

    //测试修改用户

    @Test

    publicvoid testUpdateUser() {

       Users users = new Users();

       users.setUserName("tiank");

       users.setAge(18);

       users.setId(18);

       userDao.updateUser(users);

    }

    //测试删除用户

    @Test

    publicvoid testDeleteUser() {     

       userDao.deleteUser(23);

    }  

}

Mybatis框架-CRUD的更多相关文章

  1. MyBatis之CRUD

    1 mybatis框架介绍 1.1回顾jdbc操作数据库的过程 1.2 mybatis开发步骤 A.提供一个SqlMapperConfig.xml(src目录下),该文件主要配置数据库连接,事务,二级 ...

  2. MyBatis框架

    MyBatis是支持普通SQL查询,存储过程和高级映射的优秀持久层框架.MyBatis消除了几乎所有的JDBC代码和参数的手工设置以及对结果集的检索封装.MyBatis可以使用简单的xml或者注解用于 ...

  3. 深入理解MyBatis框架的的配置信息

    面对一个框架,最重要的不是说回用其代码就可以了,我们需要了解其思想,这样才能更快更好的掌握这个框架.而对于一个框架,最重要的就是其配置文件的作用及功能了.下面,我就来谈一谈我今天遇到的这个MyBati ...

  4. SSM(Spring + Springmvc + Mybatis)框架面试题

    JAVA SSM框架基础面试题https://blog.csdn.net/qq_39031310/article/details/83050192 SSM(Spring + Springmvc + M ...

  5. MyBatis框架入门之(二)

    在本篇文章中,没有对细节进行处理的很好,有很多晓得细节的遗漏,本文只是一个简单的快速的入门 MyBatis的快速入门 导入MyBatis框架jar包 配置文件 SqlSessionFactoryBui ...

  6. 初识Mybatis框架

    mybatis框架  主要是对数据库进行操作的 编写sql语句 使我们对数据库的crud操作更加简洁方便!! 1.使用mybatis框架 进行第一个项目 查询数据库 并返回数据 :(简单) (1)搭建 ...

  7. MyBatis框架的使用及源码分析(二) 配置篇 SqlSessionFactoryBuilder,XMLConfigBuilder

    在 <MyBatis框架中Mapper映射配置的使用及原理解析(一) 配置与使用> 的demo中看到了SessionFactory的创建过程: SqlSessionFactory sess ...

  8. Mybatis框架-1

    1.Mybatis框架: Mybatis是一个半自动的对象关系映射(ORM),实现结果集的自动封装,sql写到配置文件中: Mybatis使用的是DTD约束. 2.Mybatis模块调用: 3.Sql ...

  9. ssm(spring、springmvc、mybatis)框架整合

    第一次接触这3大框架,打算一个一个慢慢学,参照网上资料搭建了一个ssm项目,作为新手吃亏在jar包的导入上,比如jdbc DataSource配置的时候由于导入的jar包不兼容或者缺包导致项目无法正常 ...

随机推荐

  1. web自动化之alert弹窗操作

    from selenium import webdriver from selenium.webdriver.support.wait import WebDriverWait from seleni ...

  2. Java集合(八)哈希表及哈希函数的实现方式

    Java集合(八)哈希表及哈希函数的实现方式 一.哈希表 非哈希表的特点:关键字在表中的位置和它之间不存在一个确定的关系,查找的过程为给定值一次和各个关键字进行比较,查找的效率取决于和给定值进行比较的 ...

  3. SDL初识

    1.SDL是什么? SDL(Security Development Lifecycle)安全开发生命周期.是微软提出的从安全角度指导软件开发的管理模式,在软件开发的生命周期中尽可能地发现安全隐患,降 ...

  4. Jenkins漏洞利用复现

    一.未授权访问 访问url: http://172.16.20.134:8080/script 命令执行 println "ls -al".execute().text 也可以利用 ...

  5. 关于URL优化的一些经验

    URL在搜索结果列表中时显示内容之一.设计网站结构时需要对目录及文件命名系统做事先规划.总的原则是首先从用户体验出发,URL应该清晰友好.方便记忆,然后才考虑URL对排名的影响.具体可以考虑以下几个方 ...

  6. Java实现 蓝桥杯VIP 算法提高 特殊的质数肋骨

    算法提高 特殊的质数肋骨 时间限制:1.0s 内存限制:256.0MB 问题描述 农民约翰母牛总是产生最好的肋骨.你能通过农民约翰和美国农业部标记在每根肋骨上的数字认出它们.农民约翰确定他卖给买方的是 ...

  7. 第四届蓝桥杯JavaB组国(决)赛真题

    解题代码部分来自网友,如果有不对的地方,欢迎各位大佬评论 题目1.猜灯谜 题目描述 A 村的元宵节灯会上有一迷题: 请猜谜 * 请猜谜 = 请边赏灯边猜 小明想,一定是每个汉字代表一个数字,不同的汉字 ...

  8. 第八届蓝桥杯JavaC组省赛真题

    解题代码部分来自网友,如果有不对的地方,欢迎各位大佬评论 题目1.外星日历 题目描述 某星系深处发现了文明遗迹. 他们的计数也是用十进制. 他们的文明也有日历.日历只有天数,没有年.月的概念. 有趣的 ...

  9. Java实现第九届蓝桥杯倍数问题

    倍数问题 题目描述 [题目描述] 众所周知,小葱同学擅长计算,尤其擅长计算一个数是否是另外一个数的倍数.但小葱只擅长两个数的情况,当有很多个数之后就会比较苦恼.现在小葱给了你 n 个数,希望你从这 n ...

  10. java实现第七届蓝桥杯有奖竞猜

    有奖竞猜 题目描述 小明很喜欢猜谜语. 最近,他被邀请参加了X星球的猜谜活动. 每位选手开始的时候都被发给777个电子币. 规则是:猜对了,手里的电子币数目翻倍, 猜错了,扣除555个电子币, 扣完为 ...