eclipse上搭建MyBatis环境

在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'

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

  • 7
    点赞
  • 68
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: 在Eclipse搭建MyBatis环境的步骤如下: 1. 下载MyBatis框架,解压后将mybatis-x.x.x.jar文件复制到项目的lib目录下。 2. 下载数据库驱动程序,将其复制到项目的lib目录下。 3. 在项目的src目录下创建一个mybatis-config.xml文件,用于配置MyBatis框架。 4. 在mybatis-config.xml文件中配置数据源和Mapper映射文件的路径。 5. 在项目的src目录下创建一个Mapper映射文件,用于定义SQL语句和映射关系。 6. 在Java代码中使用MyBatis框架进行数据库操作。 以上就是在Eclipse搭建MyBatis环境的基本步骤。 ### 回答2: MyBatis是一款Java持久层框架,与Hibernate等ORM框架不同的是,MyBatis采用了SQL和对象的映射机制,提供了更为直接、简单的数据库访问方式。而Eclipse是一款Java开发IDE,提供了丰富的插件支持,极大地方便了Java开发人员的工作。下面我将介绍如何在Eclipse搭建MyBatis环境。 一、下载和安装MyBatis插件 在Eclipse Marketplace中搜索MyBatis Generator插件并下载安装。 二、创建MyBatis配置文件 在项目的src/main/resources目录下创建一个mybatis-config.xml配置文件,用于配置MyBatis框架的各种参数。 三、创建数据库连接配置文件 在src/main/resources目录下创建jdbc.properties文件,用于配置数据库连接的用户名、密码、驱动等参数。 四、创建MyBatis映射文件 映射文件是MyBatis框架中最为重要的配置文件,用于定义数据库表与Java对象之间的关系。在src/main/resources目录下创建mapper目录,并在该目录下创建一个UserMapper.xml文件,用于定义用户表与Java对象之间的映射关系。 五、创建JavaBean对象和Dao接口 创建一个JavaBean对象User,并在src/main/java目录下创建一个dao包,在该包下创建一个UserDao接口,用于定义数据库操作方法。 六、配置Spring框架 在pom.xml文件中添加Spring框架的依赖,并在src/main/resources目录下创建一个spring.xml配置文件,用于配置Spring框架的各种参数。 七、编写测试代码 在src/test/java目录下创建一个Test类,用于测试MyBatis与Spring框架的整合是否成功。 以上就是在Eclipse搭建MyBatis环境的详细步骤,希望能够对初学者有所帮助。 ### 回答3: 在Eclipse搭建MyBatis环境需要以下步骤: 1. 首先下载安装Eclipse,最新版本是Eclipse Oxygen。 2. 安装Java Development Kit(JDK),并设置环境变量。 3. 下载MyBatis框架的压缩包,将其解压缩到某个文件夹中。 4. 在Eclipse中新建一个Java项目,在项目的根目录下创建一个名为lib的文件夹,在lib文件夹中拷贝MyBatis解压后的jar文件。 5. 在Eclipse中配置MyBatis的mapper XML文件,可以在src目录下创建一个mapper文件夹,将mapper XML文件放在这个文件夹下。 6. 在项目的src目录下创建一个名为mybatis-config.xml的文件,并进行MyBatis的相关配置,例如数据库连接等等。MyBatis的官方文档中提供了丰富的配置选项和示例。 7. 在项目中引入配置文件,可以使用类似下面的Java代码: String resource = "mybatis-config.xml"; InputStream inputstream = Resources.getResourceAsStream(resource); SqlSessionFactory factory = new SqlSessionFactoryBuilder().build(inputstream); 8. 在代码中使用MyBatis,可以通过以下方式实现: SqlSession session = factory.openSession(); MyBatisMapper mybatisMapper = session.getMapper(MyBatisMapper.class); mybatisMapper.doSomething(); session.close(); 以上是在Eclipse搭建MyBatis环境的基本步骤,可以通过MyBatis官方文档或者网上查找相关示例代码来深入学习。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值