Mybatis+Spring整合创建Web项目_Evankaka的博客-程序员宅基地

技术标签: 整合  Spring  Mybatis  创建Web项目  

          林炳文Evankaka原创作品。转载请注明出处http://blog.csdn.net/evankaka

        本文要实现使用Mybatis+Spring+Mysql实现一个Web项目的整目。在Spring中配置数据源和Mybatis的SqlSessionFactory,然后在Web中的JSP中取得Spring中的bean。通过这个bean来操作Mysql中的表。网上看了好多人有写,但是要么是图没表示清楚,要么是代码没贴完。本文是一个完整的教程,照着做你也可以自己整合!

使用的版本:Mybatis-3.2.8

                        Spring3.2.9

                         Mysql5.6

开发环境:    Eclipse  Java EE Kepler+Win7

本文工程免费下载

一、创建Web项目并导入包

Eclipse中创建一个Web项目,导入如下的包:


这里一定要注意不能少mybatis-spring-1.2.2.jar这个包,这个包是用来联系Spring和Mybatis的,很重要!!

整个工程目录如下:


二、创建库表映射类并配置MyBatis

1、首先在数据库中创建一张表 t_user

use test;
DROP TABLE IF EXISTS t_user;
create table t_user
(
 userId  int primary key auto_increment,
 userName VARCHAR(50) not null,
 userAge int not null
);
然后插入4条数据:

insert into t_user values(1,'小王',10);
insert into t_user values(2,'红红',11);
insert into t_user values(3,'明明',12);
insert into t_user values(4,'天天',13);
查看下结果:


2、表创建好之后便创建其映射类User,位于包com.mucfc.model中

package com.mucfc.model;
/**
 * User映射类
 * @author linbingwen
 * @time 2015.5.15
 */
public class User {
	private Integer userId;
	private String userName;
	private int userAge;
	public Integer getUserId() {
		return userId;
	}
	public void setUserId(Integer userId) {
		this.userId = userId;
	}
	public String getUserName() {
		return userName;
	}
	public void setUserName(String userName) {
		this.userName = userName;
	}
	public int getUserAge() {
		return userAge;
	}
	public void setUserAge(int userAge) {
		this.userAge = userAge;
	}
	@Override
	public String toString() {
		return "User [userId=" + userId + ", userName=" + userName
				+ ", userAge=" + userAge + "]";
	}

}

2、映射类创建好之后便创建MyBatis映射文件(即Mapper文件),位于和src同级的conf的mapper包中,文件内容如下:

<?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="com.mucfc.mapper.UserMapper">	
	<!--  查询单条记录  -->  
    <select id="selectUserById" parameterType="int" resultType="User">  
       select * from t_user where userId = #{userId}  
    </select>  
</mapper>
3、创建映射UserMapper类如下,位于包com.mucfc.mapper中

package com.mucfc.mapper;

import com.mucfc.model.User;
/**
 * Mapper映射类
 * @author linbingwen
 * @time 2015.5.15
 */
public interface UserMapper {
	public User selectUserById(int userId);

}
4、创建操作数据的DAO层

package com.mucfc.dao;

import com.mucfc.model.User;
/**
 * DAO接口层
 * @author linbingwen
 * @time 2015.5.15
 */
public interface UserDao {
	/**
	 * 根据用户ID查询用户信息
	 * @param id
	 * @return
	 */
	public User findUserById(int id);
}
然后是对应的实现层

package com.mucfc.dao;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Component;
import  com.mucfc.mapper.UserMapper;
import com.mucfc.model.User;
/**
 * DAO实现层
 * @author linbingwen
 * @time 2015.5.15
 */
@Component
public class UserDaoImpl implements UserDao{
    @Autowired
	private UserMapper userMapper;
	@Override
	public User findUserById(int id) {
		User user = userMapper.selectUserById(id);
		 return user; 
	}
	
}

5、在conf里配置Mybatis的配置文件:

MyBatisConf.xmll放在conf里,注意路径

<?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>
   <!-- 配置映射类的别名 -->
 	<typeAliases>
      <typeAlias alias="User" type="com.mucfc.model.User"/> 
   </typeAliases>  
   <!-- 配置Mapper文件的路径 -->
   <mappers>
       <mapper resource="mapper/UserMapper.xml"/>
   </mappers>
</configuration>

如果不与Spring进行整合的话,此配置文件还需要配置数据源信息,与Spring整合之后数据源就配置在Spring配置文件中,只需要配置映射文件的路径就可以了。

三、配置Spring

1、在WEB-INF里配置Spring的配置文件:

SpringConf.xml放在WEB-INF里,注意路径

<?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:aop="http://www.springframework.org/schema/aop"
	xsi:schemaLocation="  
           http://www.springframework.org/schema/beans  
           http://www.springframework.org/schema/beans/spring-beans-3.0.xsd  
           http://www.springframework.org/schema/aop  
           http://www.springframework.org/schema/aop/spring-aop-3.0.xsd
           http://www.springframework.org/schema/context  
           http://www.springframework.org/schema/context/spring-context-3.0.xsd">
	<!-- 配置数据源 -->
	<bean id="dataSource"
		class="org.springframework.jdbc.datasource.DriverManagerDataSource">
		<property name="driverClassName" value="com.mysql.jdbc.Driver" />
		<property name="url" value="jdbc:mysql://localhost:3306/test" />
		<property name="username" value="root" />
		<property name="password" value="[email protected]" />
	</bean>


	<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
		<property name="dataSource" ref="dataSource" />
	<!-- 	 <property name="mapperLocations" value="conf/mapper/UserMapper.xml"/>  -->
		<property name="configLocation" value="conf/MyBatisConf.xml" />
		<!-- <property name="typeAliasesPackage" value="com.tiantian.ckeditor.model" 
			/> -->
	</bean>

	  <bean id="userMapper" class="org.mybatis.spring.mapper.MapperFactoryBean">  
       <property name="mapperInterface"  
           value="com.mucfc.mapper.UserMapper" />  
       <property name="sqlSessionFactory" ref="sqlSessionFactory" />  
    </bean> 
	<!-- 自动扫描注解的bean -->
	<context:component-scan base-package="com.mucfc.dao" />

</beans>

2、web.xml中启动Spring

web.xml放在WEB-INF里

<?xml version="1.0" encoding="UTF-8"?>
<web-app version="2.5" xmlns="http://java.sun.com/xml/ns/javaee"
	xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
	xsi:schemaLocation="http://java.sun.com/xml/ns/javaee 
	http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd">
	<!-- 配置初始打开的页面 -->
	<welcome-file-list>
		<welcome-file>index.html</welcome-file>
		<welcome-file>index.htm</welcome-file>
		<welcome-file>index.jsp</welcome-file>
	</welcome-file-list>
	
	<!-- Spring 容器加载 -->
	<listener>
		<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
	</listener>
	<context-param>
		<param-name>contextConfigLocation</param-name>
		<param-value>/WEB-INF/SpringConf.xml</param-value>
	</context-param>

</web-app>

3、读取bean,进行查找

在index.jsp中设置如下:

index.jsp放置在WebContent中

<%@ page import="com.mucfc.dao.UserDao"%>
<%@page import="org.springframework.web.context.WebApplicationContext"%>
<%@page
	import="org.springframework.web.context.support.WebApplicationContextUtils"%>
<%@ page language="java" contentType="text/html" pageEncoding="UTF-8"%>

<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<title>Insert title here</title>
</head>
<body>
	<center>
		欢迎<br/>
		<%
			WebApplicationContext wac = WebApplicationContextUtils
					.getWebApplicationContext(this.getServletContext());
			UserDao userDao = (UserDao) wac.getBean("userDaoImpl");
		%>
		<%=userDao.findUserById(1)%><br />
		<%=userDao.findUserById(2)%><br />
		<%=userDao.findUserById(3)%><br />
		<%=userDao.findUserById(4)%><br />
	</center>
</body>
</html>

四、运行

1、以run on server运行

2、浏览器输入:http://localhost:8080/MybatisLearningChapter5/

结果如下:




林炳文Evankaka原创作品。转载请注明出处http://blog.csdn.net/evankaka

本文工程免费下载

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/Evankaka/article/details/45745345

智能推荐

微信小程序Promise封装_qq_41619567的博客-程序员宅基地

request.jsvar sendRequest = function (url, method, data = {}, header = {}) { var promise = new Promise(function (resolve, reject) { wx.request({ url: url, data: data, method...

XML课后练习答案(一)——HTML小测验答案分享_qq_40996041的博客-程序员宅基地

1 HTML 指的是?. 超文本标记语言(Hyper Text Markup Language). 家庭工具标记语言(Home Tool Markup Language). 超链接和文本标记语言(Hyperlinks and Text Markup Language)答:超文本标记语言(Hyper Text Markup Language) 2 Web 标准的制定者是?...

程序员看金融_布玮的博客-程序员宅基地

基本要求借贷记账法的记账规则可以概括为:有借必有贷,借贷必相等。借贷记账法借贷只是一种记录经济业务的符号,不能与生活中的所谓的“借”,“贷”相对比(一)资产类账户的结构在资产类账户中,它的借方记录资产的增加额,贷方记录资产的减少额。在同一会计期间(年、月),借方记录的合计数额称作本期借方发生额,贷方记录的合计数称作本期贷方发生额,在每一会计期间的期末将借贷方发生额相比较,其差额称作期...

洛谷P4555 最长双回文串 回文自动机_SigmaQuadrant的博客-程序员宅基地_p上4555

给出n≤1e5n\leq1e5n≤1e5的字符串,然后求出最长双回文串,双回文串满足的定义是SSS可以切割为XXX和YYY两部分,使得这两部分都是回文串。正反各跑一次PAMPAMPAM,记录下当前到iii这个位置为结尾的最长回文长度。最后O(n)O(n)O(n)枚举断点更新答案。#include&lt;bits/stdc++.h&gt;using namespace std;typedef...

Bugku WEB md5+程序员本地网站_显哥无敌的博客-程序员宅基地_bugku web md5

今天这两题都比较容易,就不演示了第一题:md5 ,没有啥的,直接撞库,直接传参?a=s532378020a不要想为什么,就是应撞,简单粗暴第二题:程序员本地网站 ,经典X-Forwarded-For:127.0.0.1直接得到flag,这两题放在后面的位置,但是比之前的还简单,挺浪费积分的...

Python基本图形绘制-turtle库总结_WangGangdan的博客-程序员宅基地

1:turtle库概述Turtle库是turtle绘图体系的python实现是python标准库2:turtle绘图窗体Turtle.setup(width, height, startx, starty) 设置窗口的位置及其大小例: 3:turtle空间坐标体系turtle.goto(x, y),海龟从当前位置直线移动到(x, y)。例: Tu...

随便推点

Mysql学习笔记04--尚硅谷李玉婷老师mysql课程_Sweet_57的博客-程序员宅基地

视图含义:理解成一张虚拟的表视图和表的区别:使用方式 占用物理空间视图 完全相同 不占用,仅仅保存的是sql逻辑表 完全相同 占用视图的好处:1、sql语句提高重用性,效率高2、和表实现了分离,提高了安全性视图的创建语法:CREATE VIEW 视图名AS查询语句;视图的增删改查1、查看视图的数据 ★SELECT * FROM my_v4;S...

PyCharm安装成功后打不开,解决方法_GiffordY的博客-程序员宅基地_pycharm安装后打不开

最近在公司换了台新的电脑,在官网下载PyCharm社区版安装完成后,双击桌面图标,发现软件一直在加载页面打不开,在任务管理器里面查看了下,PyCharm在后台进程中运行而不是前台。双击pycharm.bat弹出一个控制台窗口后,pycharm软件也随之打开,但如果不小心关闭了控制台窗口,pycharm也就关了,非常不方便。因此,想着怎样解决这个问题。网上看到教程说卸载软件、删除注册表,再重装,等等办法,也没有解决。而且需要说明的是,我这个电脑是全新的,以前没有装过PyCharm,也没有装汉化、破解工

Ubuntu 安装 Docker(译)_weixin_34279579的博客-程序员宅基地

为什么80%的码农都做不了架构师?&gt;&gt;&gt; ...

linux如何修改文件权限_白尾灰猫的博客-程序员宅基地_linux 设置文件夹权限

显示文件或目录的访问权限$ ls -l (文件名/文件) ls -l(文件名/文件)文件权限解读– rw- r– r–普通文件 文件主 组用户 其他用户linux常用命令:创建文件和文件夹touch+文件名,touch与文件名之间一定要有空格#touch abcLinux 修改文件读写权限chmod 命令.假设我的文件夹在主目录里,地址为 /var/home/dengc...

C语言数据类型转换_Comma丶的博客-程序员宅基地

在不同数据 类型混合运算时 char—&amp;gt;int    float—&amp;gt;int   float—&amp;gt;double自动类型转换         char—&amp;gt;int—&amp;gt;long—&amp;gt;double强制类型转换        float—&amp;gt;int时要四舍五入 bool转整数:true为1,false为0.整数转bool:非0为true,0为fa...