搭建SSM框架之集成mybatis
本篇是基于上一篇在Idea中新建基于Maven的Spring Mvc项目 基础上完成的,上一篇完成基于Maven的Spring mvc项目,这一篇开始在此基础上集成mybatis
项目完整目录
下面开始集成mybatis
1.1 修改pom.xml,添加mybatis和数据库相关依赖
<?xml version="1.0" encoding="UTF-8"?> <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> <modelVersion>4.0.0</modelVersion> <groupId>com.chenguo</groupId> <artifactId>TestMavenAndMybatis</artifactId> <version>1.0-SNAPSHOT</version> <packaging>war</packaging> <name>TestMavenAndMybatis Maven Webapp</name> <!-- FIXME change it to the project's website --> <url>http://www.example.com</url> <properties> <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding> <maven.compiler.source>1.7</maven.compiler.source> <maven.compiler.target>1.7</maven.compiler.target> </properties> <dependencies> <dependency> <groupId>junit</groupId> <artifactId>junit</artifactId> <version>4.11</version> <scope>test</scope> </dependency> <dependency> <groupId>javax.servlet</groupId> <artifactId>javax.servlet-api</artifactId> <version>3.1.0</version> </dependency> <dependency> <groupId>javax.servlet.jsp</groupId> <artifactId>jsp-api</artifactId> <version>2.2</version> </dependency> <dependency> <groupId>javax.servlet</groupId> <artifactId>jstl</artifactId> <version>1.2</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-core</artifactId> <version>5.1.5.RELEASE</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-beans</artifactId> <version>5.1.5.RELEASE</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-context</artifactId> <version>5.1.5.RELEASE</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-jdbc</artifactId> <version>5.1.5.RELEASE</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-tx</artifactId> <version>5.1.5.RELEASE</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-webmvc</artifactId> <version>5.1.5.RELEASE</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-web</artifactId> <version>5.1.5.RELEASE</version> </dependency> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <version>8.0.15</version> </dependency> <dependency>
<!-- database connect pool -->
<groupId>commons-dbcp</groupId> <artifactId>commons-dbcp</artifactId> <version>1.4</version> </dependency> <dependency> <groupId>org.mybatis</groupId> <artifactId>mybatis</artifactId> <version>3.5.0</version> </dependency> <dependency> <groupId>org.mybatis</groupId> <artifactId>mybatis-spring</artifactId> <version>2.0.0</version> </dependency> <dependency> <groupId>com.fasterxml.jackson.core</groupId> <artifactId>jackson-databind</artifactId> <version>2.9.8</version> </dependency> </dependencies> <build> <finalName>TestMavenAndMybatis</finalName> <pluginManagement><!-- lock down plugins versions to avoid using Maven defaults (may be moved to parent pom) --> <plugins> <plugin> <artifactId>maven-clean-plugin</artifactId> <version>3.1.0</version> </plugin> <!-- see http://maven.apache.org/ref/current/maven-core/default-bindings.html#Plugin_bindings_for_war_packaging --> <plugin> <artifactId>maven-resources-plugin</artifactId> <version>3.0.2</version> </plugin> <plugin> <artifactId>maven-compiler-plugin</artifactId> <version>3.8.0</version> </plugin> <plugin> <artifactId>maven-surefire-plugin</artifactId> <version>2.22.1</version> </plugin> <plugin> <artifactId>maven-war-plugin</artifactId> <version>3.2.2</version> </plugin> <plugin> <artifactId>maven-install-plugin</artifactId> <version>2.5.2</version> </plugin> <plugin> <artifactId>maven-deploy-plugin</artifactId> <version>2.8.2</version> </plugin> </plugins> </pluginManagement> </build> </project>
添加依赖时有两个地方需要注意:1、 Spring版本要一致,不然很可能因为版本冲突导致create bean失败;2、mysql-connector-java的版本不能太低,相对于mysql和java版本,不然后续会报莫名的错误。
1.2 在resources目录下新建mysqlDB.properties数据库配置文件
driverClass=com.mysql.cj.jdbc.Driver jdbcUrl=jdbc:mysql://localhost:3306/mylogin?useUnicode=true&characterEncoding=UTF-8&serverTimezone=UTC username=root password=****(将此处修改为你数据库的密码) #定义初始连接数 initialSize=0 #定义最大连接数 maxActive=20 #定义最大空闲 maxIdle=20 #定义最小空闲 minIdle=1 #定义最长等待时间 maxWait=60000
1.3 在resources目录下新建mybatis全局配置文件 mybatis-config.xml
<?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> <!--使用jdbc的getGeneratedKeys 获取数据库自增主键值--> <setting name="useGeneratedKeys" value="ture"/> <!--使用列别名替换列明 默认值true select name as title from table --> <setting name="useColumnLabel" value="true"/> <!-- 开启驼峰命名转换:Table(create_time)->Entity(creatTime) --> <setting name="mapUnderscoreToCamelCase" value="true"/> </settings> </configuration>
1.4 配置Spring mvc和mybatis整合需要的配置文件spring-mybatis.xml
<?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:context="http://www.springframework.org/schema/context" xmlns:tx="http://www.springframework.org/schema/tx" xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx.xsd"> <!--自动扫描--> <context:component-scan base-package="myProject"/> <!--1:配置数据库相关参数--> <context:property-placeholder location="classpath:mysqlDB.properties"/> <!-- 配置数据源 --> <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close"> <property name="driverClassName" value="${driverClass}"/> <property name="url" value="${jdbcUrl}"/> <property name="username" value="${username}"/> <property name="password" value="${password}"/> <property name="initialSize" value="${initialSize}"/> <!-- 连接池最大数量 --> <property name="maxActive" value="${maxActive}"/> <!-- 连接池最大空闲 --> <property name="maxIdle" value="${maxIdle}"/> <!-- 连接池最小空闲 --> <property name="minIdle" value="${minIdle}"/> <!-- 获取连接最大等待时间 --> <property name="maxWait" value="${maxWait}"/> </bean> <!-- mybatis和spring完美整合,不需要mybatis的配置映射文件 --> <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean"> <property name="dataSource" ref="dataSource"/> <property name="configLocation" value="classpath:mybatis-config.xml"/> <!-- 自动扫描mapping.xml文件 --> <property name="mapperLocations" value="classpath:mapping/*.xml"/> </bean> <!--配置扫描DAO接口包,动态实现DAO接口,并注入到Spring容器中--> <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer"> <!--给出扫描DAO 接口的包--> <property name="basePackage" value="myProject.Dao"/> <!-- 注入sqlSessionFactory (适应beanname方式后处理,防止在注入之前就使用)--> <property name="sqlSessionFactoryBeanName" value="sqlSessionFactory"/> </bean> <!-- (事务管理)transaction manager, use JtaTransactionManager for global tx --> <bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager"> <property name="dataSource" ref="dataSource"/> </bean> <!-- (事务管理)transaction manager, use JtaTransactionManager for global tx --> <tx:annotation-driven transaction-manager="transactionManager"/> </beans>
在引用mysqlDB.properties文件具体引用路径怎么写,一直很纠结,这里当做个笔记, "classpath:mysqlDB.properties",在此前加classpath,classpath是指 WEB-INF文件夹下的classes目录 ,在本项目下该文件在resources目录下,对应IDEA输出的target目录,其确实是在classes目录下
1.5 配置web.xml文件
<?xml version="1.0" encoding="UTF-8"?> <web-app xmlns="http://xmlns.j cp.org/xml/ns/javaee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_4_0.xsd" version="4.0"> <context-param> <param-name>contextConfigLocation</param-name> <param-value>/WEB-INF/applicationContext.xml</param-value> </context-param> <context-param> <param-name>contextConfigLocation</param-name> <param-value>classpath:spring-mybatis.xml</param-value> </context-param> <listener> <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class> </listener> <servlet> <servlet-name>dispatcher</servlet-name> <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class> <init-param> <!--配置dispatcher-servlet.xml作为mvc的配置文件,在单独用Spring-MVC时,可以默认 ,不加下面两行,在此处建maven项目后一定要,不然Tomcat不会加载org.springframework相关文件--> <param-name>contextConfigLocation</param-name> <param-value>/WEB-INF/dispatcher-servlet.xml</param-value> </init-param> <load-on-startup>1</load-on-startup> </servlet> <servlet-mapping> <servlet-name>dispatcher</servlet-name> <url-pattern>/</url-pattern> </servlet-mapping> <filter> <filter-name>CharacterEncodingFilter</filter-name> <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class> <init-param> <param-name>encoding</param-name> <param-value>utf-8</param-value> </init-param> </filter> <filter-mapping> <filter-name>CharacterEncodingFilter</filter-name> <url-pattern>/*</url-pattern> </filter-mapping> </web-app>
此处主要是在web中加入spring-mybatis.xml,因为spring-mybatis.xml文件里引用的
mysqlDB.properties 数据库配置文件、 mybatis-config.xml mybatis全局配置文件、mapping/*.xml 所有的mapping文件,这样就连起来啦
<context-param> <param-name>contextConfigLocation</param-name> <param-value>classpath:spring-mybatis.xml</param-value> </context-param>
至此相关配置已基本完成,下面开始测试SSM框架是否搭建成功
二 、测试mybatis是否成功集成
2.1 首先建表
建表语句 建立t_user表,该sql为Navicat转存处理自动生成的sql
SET NAMES utf8mb4; SET FOREIGN_KEY_CHECKS = 0; -- ---------------------------- -- Table structure for t_user -- ---------------------------- DROP TABLE IF EXISTS `t_user`; CREATE TABLE `t_user` ( `id` int(11) NOT NULL AUTO_INCREMENT, `user_name` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL COMMENT '用户名', `user_phone` varchar(20) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL COMMENT '手机号', `user_email` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL COMMENT '邮箱地址', `create_time` datetime(0) NULL DEFAULT NULL COMMENT '创建时间', `modify_time` datetime(0) NULL DEFAULT NULL COMMENT '最后修改时间', `is_delete` tinyint(4) NULL DEFAULT NULL COMMENT '是否删除,0-未删除;1-已删除', `user_pwd` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL COMMENT '密码', PRIMARY KEY (`id`) USING BTREE ) ENGINE = InnoDB AUTO_INCREMENT = 4 CHARACTER SET = utf8 COLLATE = utf8_general_ci COMMENT = '用户登录表' ROW_FORMAT = Dynamic; -- ---------------------------- -- Records of t_user -- ---------------------------- INSERT INTO `t_user` VALUES (1, '张三', '13285250574', '1045221654@qq.com', '2016-07-15 23:38:56', '2016-07-15 23:39:09', 0, '123'); INSERT INTO `t_user` VALUES (2, '李四', '15985250574', '1198224554@qq.com', '2016-07-15 23:39:01', '2016-07-15 23:39:13', 0, '456'); INSERT INTO `t_user` VALUES (3, '王五', '13685250574', '1256221654@qq.com', '2016-07-15 23:39:05', '2016-07-15 23:39:16', 0, '789'); SET FOREIGN_KEY_CHECKS = 1;
t_user表
2.2 建对应的实体类User
package myProject.Model; import java.util.Date; public class User { private Integer id; private String userName; private String userPhone; private String userEmail; private String userPwd; private Date createTime; private Date modifyTime; private Short isDelete; //省略get set方法 }
2.3 在mapping文件夹下建立UserMapper.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="myProject.Dao.UserDao"> <resultMap id="UserBaseMap" type="myProject.Model.User"> <id column="id" property="id" jdbcType="INTEGER"/> <result column="user_name" property="userName" jdbcType="VARCHAR"/> <result column="user_phone" property="userPhone" jdbcType="VARCHAR"/> <result column="user_email" property="userEmail" jdbcType="VARCHAR"/> <result column="user_pwd" property="userPwd" jdbcType="VARCHAR"/> <result column="create_time" property="createTime" jdbcType="DATE"/> <result column="modify_time" property="modifyTime" jdbcType="DATE"/> <result column="is_delete" property="isDelete" jdbcType="SMALLINT"/> </resultMap> <select id="selectUserById" parameterType="java.lang.Integer" resultMap="UserBaseMap"> SELECT * FROM t_user WHERE id = #{userId} </select> <select id="selectAllUser" resultMap="UserBaseMap"> SELECT * FROM t_user </select> <select id="selectUserByName" parameterType="java.lang.String" resultMap="UserBaseMap"> select * from t_user where user_name = #{userName} </select> <update id="updateUser" parameterType="Map"> update t_user set user_name = #{user_name},user_phone = #{userPhone},user_email = #{userEmail},user_pwd = #{userPwd},create_time = #{create_time},modify_time = #{modifyTime},is_delete = #{isDelete} where id = #{userId} </update> </mapper>
在这一步Idea可能会提醒没有数据源,点击database配置即可
2.4 建UserDao接口
package myProject.Dao; import myProject.Model.User; import org.apache.ibatis.annotations.Param; import org.springframework.stereotype.Repository; import java.util.List; @Repository public interface UserDao { User selectUserById(@Param("userId") Integer userId); List<User> selectAllUser(); User selectUserByName(String username); }
2.5 建UserService接口
package myProject.Service; import myProject.Model.User; import java.util.List; public interface UserService { List<User> getAllUser(); User getUserById(Integer userId); User getUserByName(String username); }
2.6 建UserServiceImpl实现类
package myProject.Service.impl; import myProject.Dao.UserDao; import myProject.Model.User; import myProject.Service.UserService; import org.springframework.stereotype.Service; import org.springframework.transaction.annotation.Transactional; import javax.annotation.Resource; import java.util.List; @Service @Transactional(rollbackFor = Exception.class) public class UserServiceImpl implements UserService { @Resource private UserDao userDao; public List<User> getAllUser() { return userDao.selectAllUser(); } public User getUserById(Integer userId) { return userDao.selectUserById(userId); } public User getUserByName(String username){ return userDao.selectUserByName(username); } }
2.7 编写Controller测试
package myProject.Controller; import myProject.Model.User; import myProject.Service.UserService; import org.springframework.stereotype.Controller; import org.springframework.ui.Model; import org.springframework.web.bind.annotation.RequestMapping; import javax.annotation.Resource; import java.util.List; @Controller public class UserController { @Resource private UserService userService; @RequestMapping("/showUser") public String showUser(Model model){ System.out.println("进入该方法"); List<User> userList = userService.getAllUser(); model.addAttribute("userList",userList); User oneuser= userService.getUserById(1); model.addAttribute("oneuser",oneuser); return "showUser"; } }
2.8 编写showUser.jsp显示最后结果 ,使用<c:forEach>标签遍历上面的List
<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %> <%-- Created by IntelliJ IDEA. User: chen Date: 2019/3/26 Time: 20:18 To change this template use File | Settings | File Templates. --%> <%@ page contentType="text/html;charset=UTF-8" language="java" %> <html> <head> <title>shouUser-page</title> </head> <body> <c:forEach items="${userList}" var="user"> <tr> <td>${user.userName}</td> <td>${user.id}</td> <td>${user.userPhone}</td> <br/> </tr> </c:forEach> <br/><br/><br/><br/> oneuser值<br/> ${oneuser.id} ${oneuser.userName} </body> </html>
2.9 发布项目,在浏览器中输入http://localhost:8080/TestMavenAndMybatis/showUser
测试成功,成功取回数据库中用户,至此说明我们的SSM框架搭建成功。
相关参考:https://www.jianshu.com/p/c3286cb68369
https://www.jianshu.com/p/8ee3beded7df