eclipse上搭建MyBatis环境

在eclipse上搭建了MyBatis运行环境,并实现基本查询操作

第一步:数据库准备:
1.创建数据库表 user_information
eclipse上搭建MyBatis环境_第1张图片
2.向表中插入一些记录
eclipse上搭建MyBatis环境_第2张图片
第二步:建立Java项目命名为Mybatis_1,并建立文件夹lib如下图:
eclipse上搭建MyBatis环境_第3张图片
第三步:下载需要的jar包,MyBatis需要用到的jar包如下:
在这里插入图片描述
下载链接:
mybatis-3.5.4.jar
下载mybatis-3.5.4.jar之后解压,在lib目录下找到 log4j-1.2.17.jar
下载mysql-connector-java-5.1.46-bin.jar

第四步:导入jar包,将这三个jar包复制到lib目录下,
右键→build path→add to build path
eclipse上搭建MyBatis环境_第4张图片
第五步:准备工作做好了,开始搭建MyBatis环境。
1.在src目录下创建一个wyd.mybatis.pojo包,并在其中创建实体类UserInfo,代码如下:

package wyd.mybatis.pojo;

public class UserInfo {
	private int id;
	private String username;
	private String password;
	private String realname;
	private String e_mail;
	private String phone;
	public int getId() {
		return id;
	}
	public void setId(int id) {
		this.id = id;
	}
	public String getUsername() {
		return username;
	}
	public void setUsername(String username) {
		this.username = username;
	}
	public String getPassword() {
		return password;
	}
	public void setPassword(String password) {
		this.password = password;
	}
	public String getRealname() {
		return realname;
	}
	public void setRealname(String realname) {
		this.realname = realname;
	}
	public String getE_mail() {
		return e_mail;
	}
	public void setE_mail(String e_mail) {
		this.e_mail = e_mail;
	}
	public String getPhone() {
		return phone;
	}
	public void setPhone(String phone) {
		this.phone = phone;
	}
	public UserInfo(){
		
	}
	public UserInfo(int id, String username, String password, String realname, String e_mail, String phone) {
		super();
		this.id = id;
		this.username = username;
		this.password = password;
		this.realname = realname;
		this.e_mail = e_mail;
		this.phone = phone;
	}
	@Override
	public String toString() {
		return "UserInfo [id=" + id + ", username=" + username + ", password=" + password + ", realname=" + realname
				+ ", e_mail=" + e_mail + ", phone=" + phone + "]";
	}	
}

2.创建SQL映射的XML文件UserInfoMapper.xml:
在src下创建一个名为wyd.mybatis.mapper的包,在其中创建UserInfoMapper.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 namespace="wyd.mybatis.mapper.UserInfoMapper">
	<!-- 根据用户id查询用户信息 -->
    <select id="findUserInfoById" parameterType="int" resultType="UserInfo">
        select * from user_information where ID = #{id}
    </select>
</mapper>

3.在src目录下创建db.properties文件,代码如下:

创建db.properties方式:右键src目录→File 名称输入db.properties即可

jdbc.driver=com.mysql.jdbc.Driver
jdbc.url=jdbc:mysql://ip地址/user_information
jdbc.username=root
jdbc.password=123

4.创建MyBatis的核心配置文件,代码如下:

<?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"/>
	<!--给包中的类注册别名 -->
	<typeAliases>
		<package name="wyd.mybatis.pojo"/>
	</typeAliases>
	<!-- 配置环境 -->
	<environments default="development">
		<!-- 配置一个i为development的环境 -->
		<environment id="development">
			<!-- 使用JDBC事务 -->
			<transactionManager type="JDBC" />
				<!-- 数据库连接池 -->
				<dataSource type="POOLED">
				<!-- 配置数据库信息 -->
					<property name="driver" value="${jdbc.driver}"/>
					<property name="url" value="${jdbc.url}"/>
					<property name="username" value="${jdbc.username}"/>
					<property name="password" value="${jdbc.password}"/>
				</dataSource>	
		</environment>
	</environments>
	<mappers>
		<!-- 引用映射文件 -->
		<mapper resource="wyd/mybatis/mapper/UserInfoMapper.xml"/>
	</mappers>
</configuration>

5.利用JUnit创建测试类MybatisTest,代码如下:

package wyd.mybatis.test;
import static org.junit.Assert.*;
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.After;
import org.junit.Before;
import org.junit.Test;
import wyd.mybatis.pojo.UserInfo;

public class MybatisTest {
	private SqlSessionFactory sqlSessionFactory;
	private SqlSession sqlSession;
	@Before
	public void init(){
		//读取mybatis配置文件
		String resource="mybatis-config.xml";
		InputStream inputStream;
		try {
			//得到配置文件流inputStream
			inputStream=Resources.getResourceAsStream(resource);
			//根据配置信息创建会话工厂sqlSessionFactory
			sqlSessionFactory=new SqlSessionFactoryBuilder().build(inputStream);
			//通过会话工厂获得SqlSession 
			sqlSession=sqlSessionFactory.openSession();
		} catch (IOException e) {
			e.printStackTrace();
		}		
	}
	//根据id查询
	@Test
	public void testFindUserInfoByid(){
		//通过sqlSession执行映射文件(UserInfoMapper.xml)中定义的sql语句,并封装到实体类UserInfo中		
		UserInfo ui=sqlSession.selectOne("findUserInfoById",1);
		//调用toString()方法打印查询结果
		System.out.println(ui.toString());
	}
	@After
	public void destory(){
		//提交事务
		sqlSession.commit();
		//关闭事务
		sqlSession.close();		
	}
}

注:使用JUnit时需要导入jar包
在这里插入图片描述
6.选中testFindUserInfoByid方法,右键run as
eclipse上搭建MyBatis环境_第5张图片
可以看到已经打印出对应id为3的记录了,说明mybatis环境搭建成功。

7.如果需要打印MyBatis执行日志,可以使用log4j,前边已经加入了log4j-1.2.17.jar 并执行了add to build path命令,现在只需在src中新建 log4j.properties 文件(关于properties文件创建方式在前边已经写了),其中的代码如下:

	log4j.rootLogger=DEBUG,Console
    log4j.appender.Console=org.apache.log4j.ConsoleAppender
    log4j.appender.Console.layout=org.apache.log4j.PatternLayout
    log4j.appender.Console.layout.ConversionPattern=%d [%t] %-5p [%c] - %m%n
    log4j.logger.org.apache=INFO

再次执行测试方法,如图:
在这里插入图片描述
至此,完成了mybatis环境的搭建,如有疏漏后续补充。
总结:
遇到的问题:

Error querying database.  Cause: org.apache.ibatis.executor.result.ResultMapException: Error attempting to get column 'username' from result set.  Cause: java.sql.SQLException: Invalid value for getInt() - 'yasuo'
### The error may exist in wyd/mybatis/mapper/UserInfoMapper.xml
### The error may involve wyd.mybatis.mapper.UserInfoMapper.findUserInfoById
### The error occurred while handling results
### SQL: select * from user_information where ID = ?
Cause: org.apache.ibatis.executor.result.ResultMapException: Error attempting to get column 'username' from result set.  Cause: java.sql.SQLException: Invalid value for getInt() - 'yasuo'

经查询时因为实体类中没有设置默认无参构造方法导致的。实体类中加入无参构造方法问题解决!

你可能感兴趣的:(mysql,数据库,java,mybatis,sql)