1、jar包的导入

  • mybatis需要jar包:mybatis-3.4.6.jar
  • mysql驱动jar包:mysql-connector-java-5.1.34.-bin.jar
  • 日志记录jar包:log4j-1.2.17.jar

2、创建数据库并创建表(mysql)

  • 注意数据库表字段命名的规范

3、添加日志配置文件(log4j.properties)

# Configure logging for testing: optionally with log file
log4j.rootLogger=WARN, stdout
# log4j.rootLogger=WARN, stdout, logfile log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern=%d %p [%c] - %m%n log4j.appender.logfile=org.apache.log4j.FileAppender
log4j.appender.logfile.File=target/spring.log
log4j.appender.logfile.layout=org.apache.log4j.PatternLayout
log4j.appender.logfile.layout.ConversionPattern=%d %p [%c] - %m%n

4、添加mybatis配置文件(mybatis.cfg.xml)

除数据库驱动,url,用户名,密码用自己实际的参数,其他的默认就可以

<configuration>
<environments default="development">
<environment id="development">
<transactionManager type="JDBC" />
<dataSource type="POOLED">
<!--数据库驱动-->
<property name="driver" value="com.mysql.jdbc.Driver" />
<!--数据库url-->
<property name="url"
value="jdbc:mysql://localhost:3306/mybatis"></property>
<!--数据库用户名-->
<property name="username" value="root" />
<!--数据库密码-->
<property name="password" value="root" />
</dataSource>
</environment>
</environments>
</configuration>

5、创建与数据库中表相关的实体类(POJO类)

  • 注意使用驼峰命名法

6、创建操作数据库的接口方法

    package cn.wfq.mybatis.mapper;

    import java.util.List;

    import cn.wfq.mybatis.model.User;

    public interface UserMapper {
/**
* 保存一条用户数据
* @param user
*/
public void saveUser(User user); /**
* 通过用户id获取一条记录
* @param id
* @return
*/
public User getOneUserById(int id); /**
* 修改用户数据
* @param user
*/
public void updateUser(User user); /**
* 根据id删除用户数据
* @param id
*/
public void deleteUser(int id); /**
* 获取所有用户数据
* @return
*/
public List<User> getAllUser();
}

7、添加操作数据表user的映射文件(userMapper.xml),并在mybatis.cfg.xml中注册

1、添加操作数据表user的映射文件(userMapper.xml)

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd"> <!--<mapper>标签用来使该xml文件与接口对应,'namespace'属性的参数应该是与xml文件相对应的接口的类路径,本例中就是我们第5步所写的'userMapper'接口-->
<mapper namespace="cn.wfq.mybatis.mapper.UserMapper"> <!--insert、select、update、delete四个标签即代表这增删改查,这里就不解释了 --> <!--4个标签中的id值要与接口的方法名一一对应,这样执行方法时,就会执行与方法名相同的id中的sql语句,在标签中写入sql语句 -->
<!--#{}这个符号表示要传入的参数,在`{}`中填入参数名 -->
<insert id="saveUser" useGeneratedKeys="true" keyProperty="id">
insert into user(name,age,reg_date) values
(#{name},#{age},#{regDate})
</insert>
<!--resutlType这个属性的参数是返回值类型的全类名 -->
<select id="getOneUserById" resultType="cn.wfq.mybatis.model.User">
select * from user where id = #{id}
</select>
<select id="getAllUser" resultType="cn.wfq.mybatis.model.User">
select * from user
</select>
<update id="updateUser">
update user set
name=#{name},age=#{age},reg_date=#{regDate} where id=#{id}
</update>
<delete id="deleteUser">
delete from user where id = #{id}
</delete>
</mapper>

2、在mybatis.cfg.xml中注册userMapper.xml

<mappers>
<!-- 告知映射文件方式1,一个一个的配置
<mapper resource="cn/wfq/mybatis/mapper/UserMapper.xml" /> -->
<!-- 告知映射文件方式2,自动扫描包内的Mapper接口与配置文件 -->
<package name="cn/wfq/mybatis/mapper" />
</mappers>

8、编写junit测试类

package cn.wfq.mybatis.test;

import java.io.IOException;
import java.io.InputStream;
import java.util.ArrayList;
import java.util.Date;
import java.util.List; import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;
import org.junit.jupiter.api.Test; import cn.wfq.mybatis.mapper.UserMapper;
import cn.wfq.mybatis.model.User; class UserTest { /**
* 插入数据库测设
* @throws IOException
*/
@Test
void testInsertUser() throws IOException { //获取配置文件 mybatis.cfg.xml 的输入流
InputStream inputStream = Resources.getResourceAsStream("mybatis.cfg.xml"); //构建 sqlSessionFactory 实例
SqlSessionFactory sqlSessionFactory= new SqlSessionFactoryBuilder().build(inputStream); //获取操作数据库的会话
SqlSession session = sqlSessionFactory.openSession(); UserMapper userMapper = session.getMapper(UserMapper.class);
User user = new User("晓东",18,new Date()); try {
userMapper.saveUser(user);
System.out.println(user.toString());
session.commit();
}finally {
session.close();
}
} /**
* 根据id获取一条数据测试
* @throws IOException
*/
@Test
void testGetOneUserById() throws IOException { InputStream inputStream = Resources.getResourceAsStream("mybatis.cfg.xml");
SqlSessionFactory sqlSessionFactory= new SqlSessionFactoryBuilder().build(inputStream);
SqlSession session = sqlSessionFactory.openSession(); UserMapper userMapper = session.getMapper(UserMapper.class);
User user = new User(); try {
user = userMapper.getOneUserById(10004);
System.out.println(user.toString());
session.commit();
}finally {
session.close();
}
} /**
* 获取所有数据
* @throws IOException
*/
@Test
void testGetAllUser() throws IOException { InputStream inputStream = Resources.getResourceAsStream("mybatis.cfg.xml");
SqlSessionFactory sqlSessionFactory= new SqlSessionFactoryBuilder().build(inputStream);
SqlSession session = sqlSessionFactory.openSession(); UserMapper userMapper = session.getMapper(UserMapper.class);
List<User> list = new ArrayList<User>(); try {
list = userMapper.getAllUser();
for (User user : list) {
System.out.println(user.toString());
}
session.commit();
}finally {
session.close();
}
} /**
* 修改数据
* @throws IOException
*/
@Test
void testUpdateUser() throws IOException { InputStream inputStream = Resources.getResourceAsStream("mybatis.cfg.xml");
SqlSessionFactory sqlSessionFactory= new SqlSessionFactoryBuilder().build(inputStream);
SqlSession session = sqlSessionFactory.openSession(); UserMapper userMapper = session.getMapper(UserMapper.class);
User user = new User("晓东",10,new Date());
user.setId(10003);
try {
userMapper.updateUser(user);
System.out.println(user.toString());
session.commit();
}finally {
session.close();
}
} /**
* 删除数据
* @throws IOException
*/
@Test
void testDeleteUser() throws IOException { InputStream inputStream = Resources.getResourceAsStream("mybatis.cfg.xml");
SqlSessionFactory sqlSessionFactory= new SqlSessionFactoryBuilder().build(inputStream);
SqlSession session = sqlSessionFactory.openSession(); UserMapper userMapper = session.getMapper(UserMapper.class);;
try {
userMapper.deleteUser(10003);
session.commit();
}finally {
session.close();
}
}
}

mybatis环境配置与入门例子的更多相关文章

  1. MyBatis环境配置及入门

    Mybatis 开发环境搭建,选择: MyEclipse8.5 版本,mysql 5.5, jdk 1.8, mybatis3.2.3.jar 包.这些软件工具均可以到各自的官方网站上下载. 整个过程 ...

  2. 基于Qt Designer和PyQt5的桌面软件开发--环境搭建和入门例子

      本文介绍了如何使用技术栈PyCharm+Qt Designer+PyQt5来开发桌面软件,从环境搭建.例子演示到对容易混淆概念的解释.文中用到的全部软件+代码下载链接为:https://url39 ...

  3. idea spring+springmvc+mybatis环境配置整合详解

    idea spring+springmvc+mybatis环境配置整合详解 1.配置整合前所需准备的环境: 1.1:jdk1.8 1.2:idea2017.1.5 1.3:Maven 3.5.2 2. ...

  4. Mybatis环境配置学习

    Mybatis的使用环境配置步骤主要分为以下三步 1.导入jar包 2.创建mybatis的全局配置文件,并编写 3.创建mapper的配置文件 一.导入jar包 --- (踩坑:这一步中的导入mys ...

  5. CUDA学习,环境配置和简单例子

    根据摩尔定律,每18个月,硬件的速度翻一番.纵使CPU的主频会越来越高,但是其核数受到了极大的限制,目前来说,最多只有8个或者9个核.相比之下,GPU具有很大的优势,他有成千上万个核,能完成大规模的并 ...

  6. Python+Selenium笔记(一):环境配置+简单的例子

    #环境配置基于windows操作系统 #学习selenium要有一些HTML和xpth的基础,完全不会的建议先花点时间学点基础(不然元素定位,特别是xpth可能看的有点懵) #HTML :  http ...

  7. [教程] Spring+Mybatis环境配置多数据源

    一.简要概述 在做项目的时候遇到需要从两个数据源获取数据,项目使用的Spring + Mybatis环境,看到网上有一些关于多数据源的配置,自己也整理学习一下,然后自动切换实现从不同的数据源获取数据功 ...

  8. MyBatis环境搭建配置文件+入门视频下载

    1.MyBatis优点 操作简单话,代码量少,效率高,成本就降低了 2.MyBatis缺点 参数只能限制为一个 selece语都要手动来写 3.与JDBC的关系:是对JDBC的扩展 把sql语句和ja ...

  9. MyBatis环境配置

    <settings> <!-- 使全局的映射器启用或禁用缓存. --> <setting name="cacheEnabled" value=&quo ...

随机推荐

  1. 编程语言分类,安装python解释器,变量

    1.编程语言分类 机器语言:直接使用二进制指令去编写程序,直接操作硬件 优点:执行效率高 缺点:开发效率低 汇编语言:用英文标签取代二进制指令去编写程序,直接进操作硬件 优点:开发效率高于机器语言 缺 ...

  2. React页面插入script

    项目中遇到插入广告的需要,而广告的信息只是一个url链接,这个链接返回的时一个js,和以前插入广告有点不同.所有找了很多方式. 先来展示广告链接返回的信息: 假设广告链接为:http://192.16 ...

  3. MYSQL分组合并函数

    MySQL中group_concat函数完整的语法如下:group_concat([DISTINCT] 要连接的字段 [Order BY ASC/DESC 排序字段] [Separator '分隔符' ...

  4. 通过msyql proxy链接mysql中文乱码及session问题

    1.session问题 问题前提:一台机数据库为两个实例,通过不同的socket监听不同端口对外提供服务.不同的站点都访问同一个VIP不同的端口进行访问数据库. 故障现象:一旦有一个站点先用了这个vi ...

  5. Python类继承(转发)

    目录 一.概述 二.类的继承 2.1 继承的定义 2.2 构造函数的继承 2.3 子类对父类方法的重写 三.类继承的事例 回到顶部 一.概述 面向对象编程 (OOP) 语言的一个主要功能就是“继承”. ...

  6. 信号基础知识--FFT DFT

    clc;close all;clear all; f0=10; fs=100;     %采样率 t=1/fs:1/fs:2;         %共两秒钟,共200个采样点.采样间隔T=1/100 y ...

  7. Jmeter获取redis数据

    背景:jmeter写注册登录接口时,需要获取验短信验证码,一般都是存在数据库,但我们的开发把验证码存到redis里面了 步骤:1.写个redis工具类 2.打成jar包,导入jmeter lib\ex ...

  8. BZOJ4386[POI2015]Wycieczki / Luogu3597[POI2015]WYC - 矩乘

    Solution 想到边权为$1$的情况直接矩乘就可以得出长度$<=t$ 的路径条数, 然后二分check一下即可 但是拓展到边权为$2$,$3$ 时, 需要新建节点 $i+n$ 和 $i+2n ...

  9. ubuntu中运行java程序

    查找jdk rivsidn@rivsidn:~/demo/java$ sudo apt-cache search jdk default-jdk - Standard Java or Java com ...

  10. Subarray Sums Divisible by K LT974

    Given an array A of integers, return the number of (contiguous, non-empty) subarrays that have a sum ...