SpringMVC+Spring4+Mybatis3集成,开发简单Web项目+源码下载

转载自   SpringMVC+Spring4+Mybatis3集成,开发简单Web项目+源码下载

基本准备工作

1、安装JDK1.6以上版本,安装与配置

2、下载mybatis-3.2.0版:https://repo1.maven.org/maven2/org/mybatis/mybatis/

3、下载mybatis-spring-1.2.1版:https://repo1.maven.org/maven2/org/mybatis/mybatis-spring/

4、Spring-4.0.0的版本

5、tomacat6.x以上版本即可

当然,这些jar还不够,还需要MySQL数据库与驱动,log4j的jar等等。下面我们开始今天的旅行:

第一步:创建数据库表

在Navicat下执行如下sql命令创建数据库mybatis和表t_user

CREATE DATABASE IF NOT EXISTS mybatis;
USE mybatis;
create table t_user(user_id int(11) NOT NULL AUTO_INCREMENT,user_name varchar(20) not null,user_age varchar(20) not null,PRIMARY KEY (user_id))ENGINE=InnoDB DEFAULT CHARSET=utf8;


我们先看一下项目的完整目录,再继续下面的内容

第二步:添加jar包

   

   对于下面代码的内容,我们就不再一一贴出来,只是把最重要的内容贴出来,大家可以下载源码。

第三步:创建model

创建一个model包并在其下创建一个User.java文件。

package com.tgb.model;/**
* 用户
* @author liang
*
*/
public class User {private int id;private String age;private String userName;public User() {super();}public User(int id, String age, String userName) {super();this.id = id;this.age = age;this.userName = userName;}public int getId() {return id;}public void setId(int id) {this.id = id;}public String getAge() {return age;}public void setAge(String age) {this.age = age;}public String getUserName() {return userName;}public void setUserName(String userName) {this.userName = userName;}
}


第四步:创建DAO接
创建一个包mapper,并在其下创建一个UserMapper.java文件作为DAO接口。

package com.tgb.mapper;import com.tgb.model.User;import java.util.List;public interface UserMapper {void save(User user);boolean update(User user);boolean delete(int id);User findById(int id);List<User> findAll();
}


第五步:实现DAO接口
在dao包下创建一个UserMapper.xml文件作为上一步创建的DAO接口的实现。 

<?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">
<!--
namespace:必须与对应的接口全类名一致
id:必须与对应接口的某个对应的方法名一致
--><mapper namespace="com.tgb.mapper.UserMapper"><insert id="save" parameterType="User">
insert into t_user(user_name,user_age) values(#{userName},#{age})
</insert><update id="update" parameterType="User">
update t_user set user_name=#{userName},user_age=#{age} where user_id=#{id}
</update><delete id="delete" parameterType="int">
delete from t_user where user_id=#{id}
</delete><!-- mybsits_config中配置的alias类别名,也可直接配置resultType为类路劲 -->
<select id="findById" parameterType="int" resultType="User">
select user_id id,user_name userName,user_age age from t_user where user_id=#{id}
</select><select id="findAll" resultType="User">
select user_id id,user_name userName,user_age age from t_user
</select></mapper>

这里对这个xml文件作几点说明: 
1、namespace必须与对应的接口全类名一致。 
2、id必须与对应接口的某个对应的方法名一致即必须要和UserMapper.java接口中的方法同名。 

 

第六步:Mybatis和Spring的整合

      对于Mybatis和Spring的整合是这篇博文的重点,需要配置的内容在下面有详细的解释。

<?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:p="http://www.springframework.org/schema/p"
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-4.0.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context-4.0.xsd
http://www.springframework.org/schema/tx
http://www.springframework.org/schema/tx/spring-tx-4.0.xsd"><!-- 1. 数据源 : DriverManagerDataSource -->
<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/mybatis" />
<property name="username" value="root" />
<property name="password" value="123456" />
</bean><!--
2. mybatis的SqlSession的工厂: SqlSessionFactoryBean dataSource:引用数据源
MyBatis定义数据源,同意加载配置
-->
<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
<property name="dataSource" ref="dataSource"></property>
<property name="configLocation" value="classpath:config/mybatis-config.xml" />
</bean><!--
3. mybatis自动扫描加载Sql映射文件/接口 : MapperScannerConfigurer sqlSessionFactory
basePackage:指定sql映射文件/接口所在的包(自动扫描)
-->
<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
<property name="basePackage" value="com.tgb.mapper"></property>
<property name="sqlSessionFactory" ref="sqlSessionFactory"></property>
</bean><!--
4. 事务管理 : DataSourceTransactionManager dataSource:引用上面定义的数据源
--><bean id="txManager"
class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
<property name="dataSource" ref="dataSource"></property>
</bean><!-- 5. 使用声明式事务
transaction-manager:引用上面定义的事务管理器
--><tx:annotation-driven transaction-manager="txManager" /></beans>


第七步: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>
<!-- 实体类,简称 -设置别名 -->
<typeAliases>
<typeAlias alias="User" type="com.tgb.model.User" />
</typeAliases>
<!-- 实体接口映射资源 -->
<!--
说明:如果xxMapper.xml配置文件放在和xxMapper.java统一目录下,mappers也可以省略,因为org.mybatis.spring.mapper.MapperFactoryBean默认会去查找与xxMapper.java相同目录和名称的xxMapper.xml
-->
<mappers>
<mapper resource="com/tgb/mapper/userMapper.xml" />
</mappers>
</configuration>

 

总结

     Mybatis和Spring的集成相对而言还是很简单的,祝你成功。

     源码下载:SpringMVC+Spring4+Mybatis3

      下篇博文我们将Hibernate和Mybatis进行一下详细的对比。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/326195.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

微软宣布12月15日关闭开源软件托管平台CodePlex

网易科技讯4月1日消息&#xff0c;据Venturebeat报道&#xff0c;微软今天宣布&#xff0c;将关闭开源软件托管平台CodePlex。微软2006年推出这项服务&#xff0c;并决定在今年12月15日将其关闭。 微软公司副总裁布莱恩哈里&#xff08;Brian Harry&#xff09;在博文中写道&am…

C语言 立方体随鼠标转动,HTML5鼠标控制的旋转的立方体

拖拽思路&#xff1a;先定义上下左右重合在一起的六个面的旋转和移动角度立方体效果 transform-style: preserve-3d;定义初始值 transform: perspective(800px) rotateY(-60deg) rotateX(30deg);其中js效果中初始值 var x 30; var y -60;就是初始定义的旋转角度#box{width: 2…

HTML5的基础

HTML5的基础 一、HTML&#xff1a;Hyper Text MarkUp Language(超文本标记语言)。 二、W3C&#xff1a;1.world wide web consortium(万维网联盟)&#xff0c;成立于1994年&#xff0c;WEB技术领域最权威和最具影响力的国际中立性技术标准机构。2.w3c标准包括&#xff1a;结构化…

2018蓝桥杯省赛---java---A--2-(星期一)

题目描述 思路分析 方案一 翻电脑日历得2000年12月31日是周日 方案二 package TEST;class Main{public static void main(String[] args) {int sum0;for (int i 1901; i < 2000; i) {//开始的那天是星期二if((i%4000)||(i%100!0&&i%40)){sum366;}else {sum36…

Mybatis与Hibernate的详细对比

转载自 Mybatis与Hibernate的详细对比 前言 这篇博文我们重点分析一下Mybatis与Hibernate的区别&#xff0c;当然在前面的博文中我们已经深入的研究了Mybatis和Hibernate的原理。 Mybatis 【持久化框架】Mybatis简介与原理【持久化框架】SpringMVCSpring4Mybatis3集成&…

android微信分享之创建工程以及启动微信

android微信分享之创建工程 1、微信jar包在微信--->资源中心-->资源下载 中进行下载&#xff01; 2、项目结构&#xff1a; 3.启动微信&#xff1a; private static final String APP_ID "wxd479d0592270b192";private IWXAPI api;Overrideprotected void on…

android重置系统,安卓手机越用越卡,恢复出厂设置真有用?别瞎搞,看完就明白了!...

安卓手机越用越卡&#xff0c;恢复出厂设置真有用&#xff1f;别瞎搞&#xff0c;看完就明白了&#xff01;现在手机的价格逐渐的开始上升&#xff0c;一部好一点的手机价格还是比较贵的&#xff0c;所以很多人想要节省更多的换机支出&#xff0c;都会想要购买到一款可以使用的…

.NET Core开源组件:后台任务利器之Hangfire

一.简述 Hangfire作为一款高人气且容易上手的分布式后台执行服务&#xff0c;支持多种数据库。在.net core的环境中&#xff0c;由Core自带的DI管理着生命周期&#xff0c;免去了在NF4.X环境中配置always running的麻烦&#xff0c;真正做到开箱即用。 二.安装 Hangfie官方支…

初识CSS3

一、CSS&#xff1a; 1.概念&#xff1a;是一个层叠样式表&#xff0c;用来美化网页的。 2.优势&#xff1a; &#xff08;1&#xff09;内容与表现分离 &#xff08;2&#xff09;表现的统一&#xff0c;并且容易修改 &#xff08;3&#xff09;丰富的样式&#xff0c;使得页面…

2019蓝桥杯省赛---java---A---1(平方和)

题目描述 思路分析 用long保存防止溢出 代码实现 package TEST;public class Main {public static void main(String[] args) {Long cnt 0L;for (int i 1; i < 2019; i)if (check(i)) cnt i*i;System.out.print(cnt);}static boolean check(int n) {String an"&q…

android之微信分享文本

Android微信开发分享文本 1、xml文件说明 添加CheckBox&#xff0c;分享至微信好友还是微信朋友圈2.将APP_ID注册到微信中&#xff1a; api.registerApp(APP_ID); 3.创建EditText用于文本输入 String text editor.getText().toString();if (text null || text.length() 0) …

程序员如何写简历?来自硅谷的八条建议

转载自 程序员如何写简历?来自硅谷的八条建议 前言 半个月前我发起了程序员内推项目之后&#xff0c;收到一些邮件&#xff0c;对方单纯希望我帮忙优化一下简历。我提了一些修改意见之后&#xff0c;有一位同学专门给我送了一张亚马逊的礼品卡&#xff0c;还有一位同学在QQ…

html中无序列表怎么整体居中,html中有序列表和无序列表怎么定位?

慕粉42660912017-06-26 17:17已采纳通常都是通过定位一组元素&#xff0c;然后根据这一组元素的顺序或者独有的特征去定位# codingutf-8import timefrom selenium import webdriver定位一组元素&#xff1a;勾选部分browser webdriver.Firefox()browser.get("http://www.…

jquery给轮播图的第一张设置class样式

HTML代码&#xff1a; <div id"myCarousel" class"carousel slide"><ol class"carousel-indicators"><li data-target"#myCarousel" data-slide-to"0" class"active"></li><li data-…

android之微信分享图片

android之微信分享图片 微信图像分享分为三类1、二进制图片2、本地图片3、URL地址图片 XML分析&#xff1a;三个Button 添加点击事件&#xff01; 注意清单文件 权限 <uses-permission android:name"android.permission.INTERNET"/> <uses-permission an…

为什么MySQL将会是一个更好的NoSQL

转载自 为什么MySQL将会是一个更好的NoSQL 前言 MySQL是一个更好的NoSQL数据库。当考虑到NoSQL的使用案例&#xff0c;比如对Key/Value键值存储来讲&#xff0c;MySQL在性能、易用性和稳定性方面更有意义。MySQL毕竟是一款成熟稳定的产品&#xff0c;在互联网上有大量的在线…

气泡提示效果css.html,用纯CSS3绘制高端简约的气泡提示框

用纯css绘制一个简单的气泡提示框&#xff0c;对于长期关注课课家CSS3绘图教程的朋友来说是件轻而易举的事&#xff0c;但是程序员最不喜欢做的事情是重复造轮子&#xff0c;加上之前小编分享的几个气泡要么过于复杂&#xff0c;通用性不强&#xff0c;要么需要鼠标移上才显示&…

HTML5表格简单应用案例之[招聘需求表]

首先先来看一下实现的效果&#xff1a; 源代码&#xff1a; <!DOCTYPE html> <html><head><meta charset"UTF-8"><title></title><style type"text/css">#tab{width: 100%;}tr td{width: 10%;height: 50px;t…

我为什么鼓励工程师写blog

工程师该怎样才能突破自己能力瓶颈&#xff1f;写 blog&#xff01;工程师该怎样精进自己在职涯上所需要的能力&#xff1f;写 blog&#xff01;工程师该怎样才能保持学习与成长的动能&#xff1f;写 blog&#xff01;工程师该怎样才能证明自己的潜力与特质&#xff1f;写 blog…

2020蓝桥杯省赛---java---C---1(约数个数)

题目描述 代码实现 package TEST;class Main{public static void main(String[] args) {int ans0;for (int i 1; i < 78120; i) {if(78120%i0){ans;}}System.out.println(ans);} }答案 96