学习MyBatis必知必会(5)~了解myBatis的作用域和生命周期并抽取工具类MyBatisUtil、mybatis执行增删改查操作
一、了解myBatis的作用域和生命周期
[错误的使用会导致非常严重的并发问题]
(1)SqlSessionFactoryBuilder
[ 作用:仅仅是用来创建SqlSessionFactory,作用域:方法作用域(局部变量) ]
(2)SqlSessionFactory(类似连接池)
[ 生命周期:一旦被创建就应该在应用的运行期间一直存在,作用域:应用作用域变量(使 用单例
模式/静态单例模式) ]
(3)SqlSession(类似连接对象)
[ 特点:非线程安全,不能共享,作用域:请求或方法作用域(局部变量) ]
二、抽取MyBatis工具类[用来创建Sqlsession]
✿ 在理解myBatis的作用域和生命周期基础上,抽取MyBatis工具类:
public class MyBatisUtil {
//创建一个sqlSessionFactory对象【应用对象(静态单例模式)】
private static SqlSessionFactory factory = null;
static {
try {
InputStream in = Resources.getResourceAsStream("mybatis-config.xml");
factory = new SqlSessionFactoryBuilder().build(in);
} catch (IOException e) {
e.printStackTrace();
}
}
//返回sqlSession对象
public static SqlSession getSession() {
return factory.openSession();
}
}
通过factory.openSession() 默认是不提交事务的方式,当修改了对象的属性之后,发现数据库的表的记录的列值没有改变----因为默认是不提交事务,需要
手动提交事务
://手动提交事务
session.commit();
三、mybatis执行增删改查操作:
1、mybatis的映射文件[UserMapper.xml] 编写增删改查sql
【 把sql存放到insert|update|delete|select 元素中去】
<mapper namespace="com.shan.hello.UserMapper">
<!-- 保存操作 -->
<insert id="insert">
insert into t_user (name, salary) values (#{name}, #{salary});
</insert>
<!-- 保存操作,并设置返回自动生成的主键【useGeneratedKeys、keyProperty】
useGeneratedKeys:是否需要返回自动生成的主键 keyProperty:把自动生成的主键设置到对象的哪个属性(OID)
-->
<insert id="keyInsert" useGeneratedKeys="true" keyProperty="id">
insert into t_user (name, salary) values (#{name}, #{salary});
</insert>
<!-- 删除操作 -->
<delete id="delete">
delete from t_user where id = #{id};
</delete>
<!-- 更改操作 -->
<update id="update">
update t_user set name = #{name}, salary = #{salary} where id = #{aid};
</update>
<!-- 查询操作 -->
<select id="get" parameterType="java.lang.Long" resultType="com.shan.hello.User">
select * from t_user where id = #{id}
</select>
<select id="getList" parameterType="java.lang.Long" resultType="com.shan.hello.User">
select * from t_user;
</select>
</mapper>
2、测试mybatis的增删改查:
/* 测试查询 */
@Test
public void testGetList3() {
//jdk7try-finally结构的另外一种写法,将关闭资源的finally部分内容放大try后边的括号内容
try(SqlSession session = MyBatisUtil.getSession();){
//4、进行数据库操作(CRUD)
User user = session.selectOne("com.shan.hello.UserMapper.get", 2L);
}
}
/* 测试更改 */
@Test
public void testUpdate() {
User user = new User();
user.setId(4L);
user.setName("好贱");
user.setSalary(new BigDecimal(100));
//jdk7try-finally结构的另外一种写法,将关闭资源的finally部分内容放大try后边的括号内容
try(SqlSession session = MyBatisUtil.getSession();){
//4、进行数据库操作(CRUD)
int rows = session.update("com.shan.hello.UserMapper.update", user);
session.commit();
}
}
/* 测试删除 */
@Test
public void testDelete() {
//jdk7try-finally结构的另外一种写法,将关闭资源的finally部分内容放大try后边的括号内容
try(SqlSession session = MyBatisUtil.getSession();){
//4、进行数据库操作(CRUD)
int rows = session.delete("com.shan.hello.UserMapper.delete", 4L);
session.commit();
}
}
/* 测试保存 */
@Test
public void testInsert() {
User user = new User();
user.setName("就是贱");
user.setSalary(new BigDecimal(1));
//jdk7try-finally结构的另外一种写法,将关闭资源的finally部分内容放大try后边的括号内容
try(SqlSession session = MyBatisUtil.getSession();){
//4、进行数据库操作(CRUD)
int rows = session.insert("com.shan.hello.UserMapper.insert", user);
session.commit();
System.out.println(user);
}
}
/* 测试保存(获取自动生成的主键) */
@Test
public void testKeyInsert() {
User user = new User();
user.setName("贱");
user.setSalary(new BigDecimal(1));
//jdk7try-finally结构的另外一种写法,将关闭资源的finally部分内容放大try后边的括号内容
try(SqlSession session = MyBatisUtil.getSession();){
//4、进行数据库操作(CRUD)
int rows = session.insert("com.shan.hello.UserMapper.keyInsert", user);
session.commit();
System.out.println(user);
}
}
✿ 获取主键的作用
---注册时,一次性填写过多信息,不友好,分成两次填写呗【获取主键,将其传递给第二个填写注册信息界面】
学习MyBatis必知必会(5)~了解myBatis的作用域和生命周期并抽取工具类MyBatisUtil、mybatis执行增删改查操作的更多相关文章
- MyBatis学习之简单增删改查操作、MyBatis存储过程、MyBatis分页、MyBatis一对一、MyBatis一对多
一.用到的实体类如下: Student.java package com.company.entity; import java.io.Serializable; import java.util.D ...
- MyBatis批量增删改查操作
前文我们介绍了MyBatis基本的增删该查操作,本文介绍批量的增删改查操作.前文地址:http://blog.csdn.net/mahoking/article/details/43673741 ...
- mybatis中的增删改查操作
在这一个部分,主要进行增删改查的示例书写. 增删改查可以基于xml的,也可以基于注解的方式. 一:对单条数据的查询 1.目录结构 这个使得目录更加清晰 2.User.java 这个使用以前的user表 ...
- 【Mybatis】mybatis开启Log4j日志、增删改查操作
Mybatis日志(最常用的Log4j) 官方网站http://www.mybatis.org/mybatis-3/zh/logging.html 1.在src目录下创建一个log4j.propert ...
- Mybatis学习(二) - CRUD操作(增删改查操作)
直接上例子: 1.项目结构: 2.具体代码及配置 User.java package com.mybatis.bean; public class User { private int id; pri ...
- Mybatis select、insert、update、delete 增删改查操作
MyBatis 是支持普通 SQL 查询,存储过程和高级映射的优秀持久层框架. MyBatis 消除了几乎所有的 JDBC 代码和参数的手工设置以及对结果集的检索.MyBatis 可以使用简单的XML ...
- Mybatis之增删改查操作
准备工作 建立整体项目目录 新建一个java工程,创建如下工程目录 其中com.kang.pojo中存放pojo类,com.kang.test中存放测试类. 源码目录config中存放Mybatis的 ...
- MyBatis的增删改查操作
搭建好mybatis之后 进行对数据库的操作 添加语句 在映射文件中添加语句 insert into student(name,age,score) values(#{name},#{age},#{s ...
- MyBatis对数据库的增删改查操作,简单演示样例
之前一直有用Hibernate进行开发.近期公司在使用Mybatis.依据网上的演示样例,做了一个简单的Demo,以便日后复习 使用XMl方式映射sql语句 整体结构例如以下图 watermark/2 ...
随机推荐
- Codeforces 450C:Jzzhu and Chocolate(贪心)
C. Jzzhu and Chocolate time limit per test: 1 seconds memory limit per test: 256 megabytes input: st ...
- 牛客练习赛39 B:选点(二叉树遍历+LIS)
链接: https://ac.nowcoder.com/acm/contest/368/B 来源:牛客网 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 131072K,其他语言262 ...
- 第四十三个知识点:为AES描述一些基础的(可能无效)的对抗侧信道攻击的防御
第四十三个知识点:为AES描述一些基础的(可能无效)的对抗侧信道攻击的防御 原文地址:http://bristolcrypto.blogspot.com/2015/07/52-things-numbe ...
- VMware客户端vSphereClient新建虚拟机
1.说明 VMware客户端工具vSphere Client, 用来连接和管理ESX或ESXi主机(下面称为宿主机), 可以方便的创建.管理虚拟机,并分配相应的资源.宿主机就是使用虚拟化软件运行虚拟机 ...
- 基于node和npm的命令行工具——tive-cli
前端开发过程中经常会用到各种各样的脚手架工具.npm全局工具包等命令行工具,如:Vue脚手架@vue/cli.React脚手架create-react-app.node进程守卫工具pm2.本地静态服务 ...
- 线性基(Linear Basis)学习笔记
前言 我看网络上没有什么非常系统的教学,可能是我太菜了吧,现在才学,做个记录给自己看. 简略介绍 一个数集能两两异或,能表出许多新的数. 线性基是一个集合,能够在记录最少的数的基础上,表示出一个等价的 ...
- C语言 生成一个随机数
随机数的生成 有缺陷的生成方式 生成随机数可以使用 <stdlib.h> 里的 int rand(void); 函数实现! 注释: C语言中还有一个 random() 函数可以获取随机数, ...
- java mapreduce实现网站PV分析
原文链接: https://www.toutiao.com/i6765677128022229517/ PV 是Page Views的缩写,即页面浏览量,用户每一次对网站中的每个网页访问均被记录一次. ...
- 基于Spring实现策略模式
背景: 看多很多策略模式,总结下来实现原理大体都差不多,在这里主要是讲解下自己基于Spring更优雅的实现方案:这个方案主要是看了一些开源rpc和Spring相关源码后的一些思路,所以在此进行总结 首 ...
- MASA Framework - 整体设计思路
源起 年初我们在找一款框架,希望它有如下几个特点: 学习成本低 只需要学.Net每年主推的技术栈和业务特性必须支持的中间件,给开发同学减负,只需要专注业务就好 个人见解:一款好用的框架应该是补充,而不 ...