Mybatis框架-CRUD
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的更多相关文章
- MyBatis之CRUD
1 mybatis框架介绍 1.1回顾jdbc操作数据库的过程 1.2 mybatis开发步骤 A.提供一个SqlMapperConfig.xml(src目录下),该文件主要配置数据库连接,事务,二级 ...
- MyBatis框架
MyBatis是支持普通SQL查询,存储过程和高级映射的优秀持久层框架.MyBatis消除了几乎所有的JDBC代码和参数的手工设置以及对结果集的检索封装.MyBatis可以使用简单的xml或者注解用于 ...
- 深入理解MyBatis框架的的配置信息
面对一个框架,最重要的不是说回用其代码就可以了,我们需要了解其思想,这样才能更快更好的掌握这个框架.而对于一个框架,最重要的就是其配置文件的作用及功能了.下面,我就来谈一谈我今天遇到的这个MyBati ...
- SSM(Spring + Springmvc + Mybatis)框架面试题
JAVA SSM框架基础面试题https://blog.csdn.net/qq_39031310/article/details/83050192 SSM(Spring + Springmvc + M ...
- MyBatis框架入门之(二)
在本篇文章中,没有对细节进行处理的很好,有很多晓得细节的遗漏,本文只是一个简单的快速的入门 MyBatis的快速入门 导入MyBatis框架jar包 配置文件 SqlSessionFactoryBui ...
- 初识Mybatis框架
mybatis框架 主要是对数据库进行操作的 编写sql语句 使我们对数据库的crud操作更加简洁方便!! 1.使用mybatis框架 进行第一个项目 查询数据库 并返回数据 :(简单) (1)搭建 ...
- MyBatis框架的使用及源码分析(二) 配置篇 SqlSessionFactoryBuilder,XMLConfigBuilder
在 <MyBatis框架中Mapper映射配置的使用及原理解析(一) 配置与使用> 的demo中看到了SessionFactory的创建过程: SqlSessionFactory sess ...
- Mybatis框架-1
1.Mybatis框架: Mybatis是一个半自动的对象关系映射(ORM),实现结果集的自动封装,sql写到配置文件中: Mybatis使用的是DTD约束. 2.Mybatis模块调用: 3.Sql ...
- ssm(spring、springmvc、mybatis)框架整合
第一次接触这3大框架,打算一个一个慢慢学,参照网上资料搭建了一个ssm项目,作为新手吃亏在jar包的导入上,比如jdbc DataSource配置的时候由于导入的jar包不兼容或者缺包导致项目无法正常 ...
随机推荐
- 0512String类
String类 2. String类 2.1 字符串类型概述 又爱又恨!!! 爱: 字符串基本上就是数据的保存,传输,处理非常重要的一种手段. 恨: 解析过程非常烦人,需要掌握熟记很多方法,同时需要有 ...
- SA-N26接口和EPS fallback
SA-N26接口和EPS fallback 1 什么是N26接口 如下图,N26(23.501)接口为4G核心网和5G核心网之间的接口,即MME和AMF的接口,用于4G和5G的互操作 2 SA(5GC ...
- Maven系列(二) -- 将开源库上传到maven仓库私服
前言 之前简单说了下Maven的搭建,现在跟大家说一下如何将自己的aar传到我们新搭建的maven仓库里面,接下来我们就从最基本的新建一个library开始讲述整个流程,话不多说,让我们把愉快的开始吧 ...
- Life In Changsha College- 第四次冲刺
第四次冲刺任务 整体功能实现. 用户故事 用户打开“生活在长大”的界面,选择登录 已注册过则输入用户名和密码直接登录 未注册用户则可选择注册功能,注册成功后登录 登录成功则弹出提示框 进行留言 系统结 ...
- 华容道题解 NOIP2013 思路题!
第一次发紫题题解,居然在发布前太激动,把刚写好的还没发布的题解一个Ctrl+A和Backspace全删了.(所以这是二稿) luogu题目传送门 前置: 做本题一定要有的一些思想: 1.从简思想: 模 ...
- 这个Maven依赖的问题,你敢说你没遇到过
Maven 依赖没处理好的话经常会导致发生一些问题,非常烦.今天给大家分享一个依赖相关的问题,说不定你之前就遇到过. 问题背景 有个 ES 搜索的项目,刚开始还是好好的状态,过了一段时间,然后就发现启 ...
- java方法句柄-----4.你所不知道的MethodHandle【翻译】
Method Handles in Java 1.介绍 在本文中,我们将探讨一个重要的API,它是在Java 7中引入的,并在Java 7版本之后更加完善:全限定名是:Java.lang.invoke ...
- 【大厂面试03期】MySQL是怎么解决幻读问题的?
问题分析 首先幻读是什么? 根据MySQL文档上面的定义 The so-called phantom problem occurs within a transaction when the same ...
- Java实现 LeetCode 583 两个字符串的删除操作(求最长公共子序列问题)
583. 两个字符串的删除操作 给定两个单词 word1 和 word2,找到使得 word1 和 word2 相同所需的最小步数,每步可以删除任意一个字符串中的一个字符. 示例: 输入: " ...
- java实现第六届蓝桥杯无穷分数
无穷分数 无穷分数 无穷的分数,有时会趋向于固定的数字. 请计算[图1.jpg]所示的无穷分数,要求四舍五入,精确到小数点后5位,小数位不足的补0. 请填写该浮点数,不能填写任何多余的内容. 结果:0 ...