interlij idea创建给Web项目添加Mybatis
来源:互联网 发布:mac ps cc 防抖 编辑:程序博客网 时间:2024/06/10 05:04
0、相关知识
MyBatis 是支持普通 SQL查询,存储过程和高级映射的优秀持久层框架。MyBatis 消除了几乎所有的JDBC代码和参数的手工设置以及结果集的检索。MyBatis 使用简单的 XML或注解用于配置和原始映射,将接口和 Java 的POJOs(Plain Old Java Objects,普通的 Java对象)映射成数据库中的记录。
每个MyBatis应用程序主要都是使用SqlSessionFactory实例的,一个SqlSessionFactory实例可以通过SqlSessionFactoryBuilder获得。SqlSessionFactoryBuilder可以从一个xml配置文件或者一个预定义的配置类的实例获得。
—摘自百度百科
其实要说的是Mybatis和Hibernate的一点区别,两个都是优秀的ORM框架,用过之后,感觉都很不错,但是Hibernate对于复制的SQL语句的支持有限,而Mybatis的不像Hibernate是用HQL,而是直接用SQL语句,需要接触数据库,需要知道数据库细节,但是同时也能更好的使用数据库的复杂查询。
Hibernate也能直接通过session获得数据库对象来操作操作复杂查询的,但是这样做,与Hibernate的初衷有点违背而已。
1、系统环境
IDE:InterliJ IDEA 2017.1.4
jdk版本:1.8
Maven版本:3.5
MyBatis版本:3.X
数据库:MySQL 5.7 包含user表的sql脚本
2、添加Mybatis
创建一个maven项目,并添加tomcat服务器。
具体添加可以参考:interlij idea创建给Web项目添加Hibernate的创建项目和发布项目步骤。
接着添加如下依赖:
<!-- ********************** Java Servlet API 4.0.0-b01 ********************** --> <dependency> <groupId>javax.servlet</groupId> <artifactId>javax.servlet-api</artifactId> <version>4.0.0-b01</version> </dependency> <!-- ********************** Mysql JDBC驱动 ********************** --> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <version>6.0.6</version> </dependency> <!-- ********************** Mybatis依赖 ********************** --> <dependency> <groupId>org.mybatis</groupId> <artifactId>mybatis</artifactId> <version>3.4.4</version> </dependency> <!-- ********************** junit单元测试依赖 ********************** --> <dependency> <groupId>junit</groupId> <artifactId>junit</artifactId> <version>4.12</version> <scope>test</scope> </dependency>
添加Mybatis插件:
菜单:File->settings
具体添加:搜索栏输入MyBatisCodeHelper接着点下面的Browse repositorys在线查找。
添加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> <settings> <!--当返回行的所有列都是空时,MyBatis默认返回null--> <setting name="returnInstanceForEmptyRow" value="true"/> </settings> <environments default="development"> <environment id="development"> <!--使用了 JDBC 的提交和回滚设置,它依赖于从数据源得到的连接来管理事务作用域--> <transactionManager type="JDBC"/> <!--使用数据池,复用实例--> <dataSource type="POOLED"> <property name="driver" value="com.mysql.jdbc.Driver"/> <property name="url" value="jdbc:mysql://localhost:3306/networkalbum?serverTimezone=GMT%2B8"/> <property name="username" value="root"/> <property name="password" value="root"/> </dataSource> </environment> </environments> <mappers> </mappers></configuration>
新建实体类
package POJO;import java.util.Date;/** * Created by hui on 2017/6/17. */public class User { private int id; private String name; private Date birth; private Integer sex; private Integer age; private String phone; private String email; private String pwd; // 各属性getter和setter方法省略,toString方法
关联一下mapper和config文件,在Mybatis-config.xm添加如下:
<mappers> <mapper resource="UserDao.xml"></mapper> </mappers>
在UserDAO.xml添加如下:
<select id="getUserById" resultType="POJO.User"> SELECT * FROM USER WHERE id = #{id}; </select>
在UserDAO.java添加如下:
//使用xml配置文件 User getUserById(int id); //不使用配置文件使用注解 @Select("Select * from user where id = #{id}") User getUserByIdForAnnotation(int id);
编写单元测试
代码如下:
public class UserDAOTest { @org.junit.Test public void Test(){ String resourse = "Mybatis-config.xml"; InputStream inputStream =null; try { inputStream = Resources.getResourceAsStream(resourse); } catch (IOException e) { e.printStackTrace(); } if(inputStream==null){ System.out.println("xml is null"); } SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream); SqlSession session = sqlSessionFactory.openSession(); UserDao userDao = session.getMapper(UserDao.class); User user = userDao.getUserById(1); System.out.println(user.toString()); User user2 = userDao.getUserByIdForAnnotation(2); System.out.println(user2.toString()); }}
如果junit单元测试报错,那么写jsp调试错误吧,junit并没给出多少错误信息。
你可以吧index.jsp改成这样子
<%@ page import="java.io.InputStream" %><%@ page import="org.apache.ibatis.io.Resources" %><%@ page import="java.io.IOException" %><%@ page import="org.apache.ibatis.session.SqlSessionFactory" %><%@ page import="org.apache.ibatis.session.SqlSessionFactoryBuilder" %><%@ page import="org.apache.ibatis.session.SqlSession" %><%@ page import="POJO.UserDao" %><%@ page import="POJO.User" %><html><body><h2>Hello World!</h2><% String resourse = "MyBatis-config.xml"; InputStream inputStream =null; try { inputStream = Resources.getResourceAsStream(resourse); } catch (IOException e) { e.printStackTrace(); } if(inputStream==null){ System.out.println("xml is null"); } SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream); SqlSession sessionz = sqlSessionFactory.openSession(); UserDao userDao = sessionz.getMapper(UserDao.class); User user = userDao.getUserById(1); System.out.println(user.toString()); User user2 = userDao.getUserByIdForAnnotation(2); System.out.println(user2.toString());%></body></html>
- interlij idea创建给Web项目添加Mybatis
- interlij idea创建给Web项目添加Mybatis
- interlij idea创建给Web项目添加Hibernate
- interlij idea创建给Web项目添加struts2
- interlij idea创建给Web项目添加SS2H
- interlij idea创建给Web项目添加SS2M
- interlij idea给Web项目添加SSM
- interlij idea给Web项目添加SSM(零配置文件
- IDEA 创建web项目
- idea创建web项目
- IDEA创建WEB项目
- Idea创建web项目
- idea创建web项目
- IntelliJ IDEA创建Web SpringMVC项目(二):添加springMVC框架
- IntelliJ IDEA创建Web SpringMVC项目(二):添加springMVC框架
- 利用Idea创建web项目
- idea 创建maven web 项目
- idea 创建一个web项目
- 蒟蒻回归啦啦啦
- 实践selenium自动化时先要弄清的几件事
- HDU2019数列有序
- Google前美女面试官谈程序员面试的技巧和建议
- Python核心编程第三版——第一章练习题答案
- interlij idea创建给Web项目添加Mybatis
- 公用的vue小组件
- 设计原则
- Ubuntu 16.04 + ROS Kinetic 机器人操作系统学习镜像分享与使用安装说明
- 安卓自定义控件全解
- 事物管理
- 【CCF】101412_3集合竞价
- 一个成功程序员的要求
- HOJ_3181 Sign in