mybatis入“坑”第一步
一、导入坐标
要想通过maven创建一个简单的mybatis项目,首先需要的是要导入相关的坐标。需要导入的坐标如下:
<dependencies>
<!--mysql驱动坐标-->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>5.1.46</version>
</dependency>
<!-- mybatis坐标 -->
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis</artifactId>
<version>3.5.6</version>
</dependency>
<!--单元测试坐标-->
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.12</version>
<scope>test</scope>
</dependency>
</dependencies>
创建实体类User和在数据库中插入创建对应的user表。
二、配置mybatis的核心配置文件mybtis-config.xml
创建mybatis-config.xml的配置文件,用于配置连接数据库和注册Mapper.xml
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configuration
PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>
<properties resource="db.properties" />
<!--数据库连接的环境配置-->
<environments default="development">
<environment id="development">
<transactionManager type="JDBC"/>
<dataSource type="POOLED">
<property name="driver" value="${driver}"/>
<property name="url" value="${url}"/>
<property name="username" value="${username}"/>
<property name="password" value="${password}"/>
</dataSource>
</environment>
</environments>
<!--每一个Mapper.xml都需要在mybatis核心配置文件中注册-->
<mappers>
<mapper resource="com/wkx/dao/UserMapper.xml"/>
</mappers>
</configuration>
①properties标签:可以动态配置属性。
可以全部在外部进行配置,如下:
<properties resource="db.properties" />
也可以在通过property标签一部分在外部进行内部配置另一部分在内部进行配置(如下),增加配置的灵活性。
<properties resource="db.properties">
<property name="username" value="root"/>
<property name="password" value="123456"/>
</properties>
②环境配置environments标签:用于配置数据的环境。可配置多个数据库环境,但是SqlSessionFactory只能选择一个去使用。如下:
<environments default="development">
<environment id="development">
<transactionManager type="JDBC"/>
<dataSource type="POOLED">
<property name="driver" value="${driver}"/>
<property name="url" value="${url}"/>
<property name="username" value="${username}"/>
<property name="password" value="${password}"/>
</dataSource>
</environment>
<environment id="test">
<transactionManager type="JDBC"/>
<dataSource type="POOLED">
<property name="driver" value="${driver}"/>
<property name="url" value="${url}"/>
<property name="username" value="${username}"/>
<property name="password" value="${password}"/>
</dataSource>
</environment>
</environments>
可以在不同的环境下切换不同的数据环境,只需要修改environments标签中的default属性对应不同环境下的id属性,比如development和test不同的环境。
③映射器mappers:定义映射的路径,告诉mybatis去哪里找对应的语句。除了上述通过类路径的资源引用方式,也可以通过其它的方式。比如通过包的形式将映射器接口全部注册为映射器,如下:
<mappers>
<package name="com.wkx.dao"/>
</mappers>
问题:Mapper.xml的配置文件在mybatis核心配置文件注册时找不到对应Mapper.xml,是因为maven读取配置文件时只在resources的文件目录下寻找,所以需要在pom.xml文件中配置过滤器。所以pom.xml中应该添加如下代码:
<!--在build中配置resources,来防止资源导出失败的原因-->
<build>
<resources>
<resource>
<directory>src/main/resources</directory>
<includes>
<include>**/*.properties</include>
<include>**/*.xml</include>
</includes>
<filtering>true</filtering>
</resource>
<resource>
<directory>src/main/java</directory>
<includes>
<include>**/*.properties</include>
<include>**/*.xml</include>
</includes>
<filtering>true</filtering>
</resource>
</resources>
</build>
三、创建Mapper.xml
完成mybatis-config.xml配置文件的创建后,接着需要配置相关的Mapper.xml,进而进行SQL语句的编写。
<mapper namespace="com.wkx.dao.UserMapper">
<select id="getUser" resultType="com.wkx.pojo.User">
select * from user
</select>
<!--使用User类作为输入类型-->
<update id="updateUser" parameterType="com.wkx.pojo.User">
update user set name=#{name},pwd=#{pwd} where id=#{id}
</update>
<!--map类型(只需要其中的key对应sql语句中的需要注入的值)-->
<update id="updateUserMap" parameterType="map">
update user set name=#{username} where id=#{uid}
</update>
</mapper>
①namespace命名空间:使用全限定类名对语句进行隔离,以及实现对接口的绑定。
②select、update等标签中的id属性对应的是Mapper接口中的方法名。通过id找到对应的方法需要执行的SQL语句。
③使用的Map集合类型对数据的SQL语句进行操作,只需要将Map集合中key对应SQL语句中的需要注入的值。也就是说SQL注入的值可以不和实体类中属性一致。同时,使用Map集合而不是User类作为传入类型进行传输时不需要将User类中所有数据传输。
四、编写工具类
mybatis的使用需要以SqlSessionFactory为核心,使用SqlSessionFactory去生产SqlSession对象。创建一个工具类去生产SqlSession对象,以后使用mybatis便可以从该工具类中拿出SqlSession。
public class MybatisUtils {
private static SqlSessionFactory sqlSessionFactory;
// 调用该类执行该静态模块中的代码,获取SqlSessionFactory
static {
try {
String resource = "mybatis-config.xml";
InputStream inputStream = Resources.getResourceAsStream(resource);
sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
} catch (IOException e) {
e.printStackTrace();
}
}
// 通过该方法可以生产SqlSession对象
public SqlSession getSqlSession(){
SqlSession sqlSession = sqlSessionFactory.openSession();
return sqlSession;
}
}
五、测试
接着我们就可以利用mybatisUtils工具类生产的SqlSession对象去调用openSession执行对应的Mapper接口,就可以调用接口中的方法去执行对应的SQL语句。
具体测试类如下:
// 查询所有用户信息
@Test
public void queryUserTest(){
MybatisUtils mybatisUtils = new MybatisUtils();
// 调用mybatisUtils中的getSqlSession方法获取SqlSession对象
SqlSession sqlSession = mybatisUtils.getSqlSession();
// 执行SqlSession中的getMapper方法,以便后来来执行对应的Mapper接口方法
UserMapper mapper = sqlSession.getMapper(UserMapper.class);
// 执行接口方法,配置完成mybatis会调用的对应的SQL语句执行
List<User> user = mapper.getUser();
sqlSession.close();
System.out.println(user);
}
// 使用Map数据类型对数据进行更新
@Test
public void updateUserMap(){
MybatisUtils mybatisUtils = new MybatisUtils();
SqlSession sqlSession = mybatisUtils.getSqlSession();
UserMapper mapper = sqlSession.getMapper(UserMapper.class);
Map<String,Object> map = new HashMap<>();
map.put("username","王三");
// map.put("password","2334op");
map.put("uid","3");
int count = mapper.updateUserMap(map);
/*增删改的数据库操作需要提交事务*/
sqlSession.commit();
sqlSession.close();
System.out.println(count);
}
注意:① 增删改的SQL语句操作都需要进行事务的提交。
② SqlSession使用完后要记得关闭。
mybatis入“坑”第一步的更多相关文章
- netty入坑第一步:了解netty和编写简单的Echo服务器和客户端
早期java API通过原生socket产生所谓的"blocking",大致过程是这样 这种的特点是每次只能处理一个请求,如果要实现多个请求并行,就还要分配一个新的线程来给每个客户 ...
- vue.js 踩坑第一步 利用vue-cli vue-router搭建一个带有底部导航栏移动前端项目
vue.js学习 踩坑第一步 1.首先安装vue-cli脚手架 不多赘述,主要参考WiseWrong 的 Vue 爬坑之路(一)-- 使用 vue-cli 搭建项目 2.项目呈现效果 项目呈现网址:w ...
- Vue入坑第一篇
写在前面的话:文章是个人学习过程中的总结,为方便以后回头在学习.文章中会参考官方文档和其他的一些文章,示例均为亲自编写和实践,若有写的不对的地方欢迎大家和我一起交流. 一.前言 本篇作为vue入门的一 ...
- Vue踩坑第一步,安装Vue最新版本
学习vue第一步肯定是安装vue-cli,那么肯定想去搜下如何安装vue-cli呢? 网上搜到的结果大都是: npm i vue-cli -g 输入vue -V发现: 输入node -v发现: 自己明 ...
- 入“坑”mybatis后如何挣脱?
既然已经入"坑"mybatis了,你竟然还想着挣脱,我是不会让你挣脱的~ 当然我有一个算是挣脱的办法.那就是把它学会.理解透.这样我们也就不用在坑里一直徘徊,也算得上是一种挣脱吧! ...
- SpringBoot入坑-项目搭建
对于学过三大框架的小童鞋,从今天开始给大家带来一套新的框架学习,相信对于做程序的小童鞋一定有所耳闻,作为下一代java开发框架springboot,减去了繁琐的xml配置,相信用过spring.sta ...
- web前端入坑第五篇:秒懂Vuejs、Angular、React原理和前端发展历史
秒懂Vuejs.Angular.React原理和前端发展历史 2017-04-07 小北哥哥 前端你别闹 今天来说说 "前端发展历史和框架" 「前端程序发展的历史」 「 不学自知, ...
- [开源]入坑Qt,我的第一个小程序:MD5计算器
版权声明 --------- 本文仅在知乎与博客园发布.开发者为szx0427 MFC和Win32搞了好几年了,也算是懂了个皮毛,但是一直觉得用这两者开发软件都很麻烦,需要将大量的代码花费在UI等地方 ...
- webpack入坑之旅(六)配合vue-router实现SPA
这是一系列文章,此系列所有的练习都存在了我的github仓库中vue-webpack,在本人有了新的理解与认识之后,会对文章有不定时的更正与更新.下面是目前完成的列表: webpack入坑之旅(一)不 ...
随机推荐
- 将文件服务器及域控制器从2003迁移至Windows Server 2008 R2
(一)背景环境: 当前,多数小企业仍然使用windows server2003 系统做域控制器及文件服务器,由于windows server 2003在多年使用之后变得卡顿,且存在异常的系统错误及诟病 ...
- Keycloak 13 自定义用户身份认证流程(User Storage SPI)
Keycloak 版本:13.0.0 介绍 Keycloak 是为现代应用程序和服务提供的一个开源的身份和访问管理的解决方案. Keycloak 在测试环境可以使用内嵌数据库,生产环境需要重新配置数据 ...
- 老vue项目webpack3升级到webpack5全过程记录(一)
背景 19年新建的vue项目,使用的是webpack3,随着项目的积累,组件的增多导致本地构建,线上打包等操作速度极慢,非常影响开发效率和部署效率,基于此问题,本次对webpack及相关插件进行了优化 ...
- Jetpack Compose What and Why, 6个问题
Jetpack Compose What and Why, 6个问题 1.这个技术出现的背景, 初衷, 要达到什么样的目标或是要解决什么样的问题. Jetpack Compose是什么? 它是一个声明 ...
- ZOHO荣登“2020中国ToB行业年度企业影响力”榜单
近日,3WToB行业头条正式揭晓<2020中国ToB行业年度榜单 · 企业影响力榜>. 此次评选,ToB行业头条联合3W集团.50+知名投资机构.60+权威媒体及资深行业人士,进行深度调研 ...
- 普里姆(Prim)算法
概览 普里姆算法(Prim算法),图论中的一种算法,可在加权连通图(即"带权图")里搜索最小生成树.即此算法搜索到的边(Edge)子集所构成的树中,不但包括了连通图里的所有顶点(V ...
- 使用cockpit管理kvm虚拟机
在Centos8.2主机上部署kvm,使用cockpit管理 首先检测cpu是否支持虚拟化 [root@localhost ~]# cat /proc/cpuinfo | grep vmx flags ...
- 040.Python进程和Join
一 进程相关介绍 1.1 进程的概念(process) 进程就是正在运行的程序,它是操作系统中,资源分配的最小单位 资源分配:分配的是cpu和内存等物理资源 进程号是程的唯标识 同-个程序执行两次之 ...
- Prometheus存储原理及数据备份还原
prometheus将采集到的样本以时间序列的方式保存在内存(TSDB 时序数据库)中,并定时保存到硬盘中.与zabbix不同,zabbix会保存所有的数据,而prometheus本地存储会保存15天 ...
- 10.16-17 mailq&mail:显示邮件传输队列&发送邮件
mailq命令 是mail queue(邮件队列)的缩写,它会显示待发送的邮件队列,显示的条目包括邮件队列ID.邮件大小.加入队列时间.邮件发送者和接受者.如果邮件进行最后一次尝试后还没有将邮件投递出 ...