在eclipse上搭建了MyBatis运行环境,并实现基本查询操作
第一步:数据库准备:
1.创建数据库表 user_information
2.向表中插入一些记录
第二步:建立Java项目命名为Mybatis_1,并建立文件夹lib如下图:
第三步:下载需要的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
第五步:准备工作做好了,开始搭建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
可以看到已经打印出对应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'
经查询时因为实体类中没有设置默认无参构造方法导致的。实体类中加入无参构造方法问题解决!