eclipse上搭建MyBatis环境

您所在的位置:网站首页 idea配置运行中没有mybatis eclipse上搭建MyBatis环境

eclipse上搭建MyBatis环境

2024-07-14 22:27| 来源: 网络整理| 查看: 265

在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配置文件,代码如下:

select * from user_information where ID = #{id}

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的核心配置文件,代码如下:

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'

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



【本文地址】


今日新闻


推荐新闻


CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3