JAVA学习---MyBatis(一)XML方式

前言

mybatis是一个十分容易学习和领会其设计初衷的持久层框架,它能够帮助我们对JDBC操作数据库的过程进行封装,使我们更加关注与sql本身(就是怎么写sql语句:D).

一、前期准备

1.1首先创建一下数据库的表
-- 1、删除 mybatisstudy 数据库(如果存在)
drop database if exists mybatisstudy;
-- 2、创建数据库 mybatisstudy 数据库
create database mybatisstudy charset utf8;
use mybatisstudy; -- 选择yonghedb数据库

-- 3、在 mybatisstudy 库中创建 employee 表
create table employee(
	id int primary key auto_increment,
	name varchar(50),
	job varchar(50),
	salary double
);
-- 4、往 employee 表中, 插入若干条记录
insert into employee values(null, '张三', '职业1', 3300);
insert into employee values(null, '李四', '职业2', 2800);
insert into employee values(null, '王五', '职业3', 3700);

1.2下载JAR包
1.2.1 mybatis的jar包

mybatis3.2.2 jar包下载地址

1.2.2 myslq连接驱动jar包

mysql驱动jar包版本为5.0.8,当你的mysql版本过高或过低时,需要调整本jar包版本

1.2.3 log4j的jar包

log4j 1.2.17版本的jar包,这个包的用处就是可以帮助我们打出运行日志,方便记录过程和查找问题

二、创建工程

new一个 JAVA project,起名叫mybatisstudy

在这里插入图片描述
然后新建一个文件夹,叫library,用于存放我们的jar包,并将刚刚上面准备的jar包存放到该目录下,然后将jar包引入到工程内
在这里插入图片描述
log4j需要一个配置文件才能够运行,否则将会报错所以我们在src目录下,new一个file名字叫log4j.properties
内容为(这个配置会在其他的文章讲,本次能用就行,不细说了)

# Global logging configuration
log4j.rootLogger=DEBUG, stdout
# Console output...
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern=%5p [%t] - %m%n

然后,我们在src目录下新建一个文件sqlMapConfig.xml这个文件的名字是mybatis官方推荐命名(不这么命名也可以)。这个文件是用于封装JDBC操作的。


<?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">
    
<!-- MyBatis的全局配置文件 -->
<configuration >

<!-- 环境的配置,default就是与下面id相同的一组环境 -->
	<environments default="envir01">
	
		<environment id="envir01">
		<!-- transactionManger里的 type 可以选择将事务交给JDBC来处理还是交给MANGED自己来处理,这里我们选择JDBC处理-->
			<transactionManager type="JDBC"></transactionManager>
		<!-- dataSource 里的type类型可以选择POOLED即使用连接池,和UNPOOLED不使用连接池-->
			<dataSource type="POOLED">
			<!-- 下面就是jdbc的驱动配置了-->
				<property name="driver" value="com.mysql.jdbc.Driver"/>
				<property name="url" value="jdbc:mysql://localhost:3306/mybatisstudy?characterEncoding=utf-8"/>
				<property name="username" value="root"/>
				<property name="password" value="root"/>
			</dataSource>
		</environment>
	</environments>
	<!-- mappers 配置的是sql映射文件,我们先设定映射文件是放在了com.mybatisstudy.pojo目录下 -->
	<mappers>
		<mapper resource="com/mybatisstudy/pojo/EmpMapper.xml"/>
	</mappers>
</configuration>

接下来我们创建一个java类,用于存放对象

package com.mybatisstudy.pojo;

public class Employee {
	//以下的四个都是与我们数据库列名相同的属性
	private String name;
	private String job;
	private double salary;
	private Integer id;
	//因为get和set有点长,这里自己生成吧
	
	//toString方法也生成一下吧,就不写在这里了
	
}

然后我们写一下mapper文件,文件名叫EmployeeMapper.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">
<!-- namespace是该文件的唯一辨识,用于在执行时查找到sql语句,方式为namespace+下方sqlId的方式拼接-->
<mapper namespace="com.mybatisstudy.pojo.EmployeeMapper">
<!-- 这个resultType就是返回值,如果需要返回的是对象,那么就指定对象类的位置,否则其他情况下不需要返回值-->
	<select id="findAll" resultType="com.mybatisstudy.pojo.Employee">
	<!-- sql语句在mybatis中可以加分号”;“也可以不加-->
		select * from employee
	</select>
	
	<insert id="insert01">
		insert into employee(name,job,salary) values('criss','king',20);
	</insert>
	<update id="update01">
		update employee set name = 'criss00001' where name='criss'
	</update>
</mapper>

接着创建一个测试类,TestMybatis

package com.mybtisstudy.test;

import java.io.IOException;
import java.io.InputStream;
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.Test;

import com.mybatisstudy.pojo.Employee;

public class TestMybatis {

	@Test
	public void findAll() throws IOException {
		//这里用于读取配置文件,
		InputStream stream = Resources.getResourceAsStream("sqlMapConfig.xml");
		//这里新建一个session
		SqlSessionFactory factory = new SqlSessionFactoryBuilder().build(stream);
		//开始session
		SqlSession session = factory.openSession();
		//指定sql语句位置
		String sqlId = "com.mybatisstudy.pojo.EmployeeMapper.findAll";
		//因为这里返回值是list所以我们选择selectList的方法,如果确定只有一个返回结果的话,那么方法就应该是
		//select()
		List<Employee> employee = session.selectList(sqlId);
		//打印出所有结果
		for (Employee employee2 : employee) {
			System.out.println(employee2);
		}
	}
}

打印结果如下:
在这里插入图片描述
如果要做的不是查询数据库,而是其他操作(删,改,赠)的情况下,我们需要在方法中提交事务,即session.commit(),否则会出现事务不能提交,数据库没有记录该条信息的问题

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值