Spring和MyBatis环境整合
SSH框架的结合几乎家喻户晓,但是一般的中小项目,使用Spring和MyBatis就够了,而且MyBatis轻便好使,易上手,值得大家尝试一次。
开篇简介:
Spring:
|
Spring是一个轻量级的控制反转(IoC)和面向切面(AOP)的容器框架。 两个重要模块:Spring 面向方面编程(AOP)和控制反转 (IOC) 容器。 控制反转模式(也称作依赖性介入)的基本概念是:不创建对象,但是描述创建它们的方式。在代码中不直接与对象和服务连接,但在配置文件中描述哪一个组件需要哪一项服务。 容器 (在 Spring 框架中是 IOC 容器) 负责将这些联系在一起。在典型的 IOC 场景中,容器创建了所有对象,并设置必要的属性将它们连接在一起,决定什么时间调用方法。 |
MyBatis:
|
MyBatis 是支持普通 SQL查询,存储过程和高级映射的优秀持久层框架。MyBatis 消除了几乎所有的JDBC代码和参数的手工设置以及
结果集的检索。
MyBatis 使用简单的 XML或注解用于配置和原始映射,将接口和 Java 的POJOs(Plain Old Java Objects,普通的 Java
对象)映射成数据库中的记录。
|
开始整合Spring和MyBatis:
1、在Eclipse里新建一个web项目,导入我们需要的jar包,可以在这里下载:http://pan.baidu.com/s/1qW8Y6yo
jar列表截图:

2、创建一个简单的数据库(springmybaitis)和数据表(user---id,username,password)。

3、以用户管理为例,创建model和dao.
文件列表截图如下:

model----User.java

1 package com.springMyBatis.system.model;
2
3 public class User {
4 private int id;
5 private String username;
6 private String password;
7 public User(){}
8 public int getId() {
9 return id;
10 }
11 public void setId(int id) {
12 this.id = id;
13 }
14 public String getUsername() {
15 return username;
16 }
17 public void setUsername(String username) {
18 this.username = username;
19 }
20 public String getPassword() {
21 return password;
22 }
23 public void setPassword(String password) {
24 this.password = password;
25 }
26 public String toString(){
27 return "User[id="+id+" , username="+username+" , password="+password+"]";
28 }
29
30
31 }

dao------接口UserDao.java

1 package com.springMyBatis.system.dao;
2
3 import com.springMyBatis.system.model.User;
4
5 public interface UserDao {
6 public User getUser(User user);
7 public void addUser(User user);
8 public void updateUser(User user);
9 public void deleteUser(int UserId);
10 }

dao-----UserDao.xml

1 <?xml version="1.0" encoding="UTF-8"?>
2 <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
3 "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
4 <mapper namespace="com.springMyBatis.system.dao.UserDao">
5 <select id="getUser" parameterType="com.springMyBatis.system.model.User" resultType="com.springMyBatis.system.model.User">
6 SELECT * FROM user WHERE username=#{username} AND password=#{password}
7 </select>
8 <insert id="addUser" parameterType="com.springMyBatis.system.model.User" flushCache="true">
9 INSERT INTO user (id,username,password) VALUES (#{id},#{username},#{password})
10 </insert>
11 <update id="updateUser" parameterType="com.springMyBatis.system.model.User">
12 UPDATE user SET password=#{password} WHERE id=#{id}
13 </update>
14 <delete id="deleteUser" parameterType="int">
15 DELETE FROM user WHERE id=#{id}
16 </delete>
17 </mapper>

4、Spring配置文件----ApplicationContext.xml


1 <?xml version="1.0" encoding="UTF-8"?>
2 <beans
3 xmlns="http://www.springframework.org/schema/beans"
4 xmlns:tx="http://www.springframework.org/schema/tx"
5 xmlns:p="http://www.springframework.org/schema/p"
6 xmlns:aop="http://www.springframework.org/schema/aop"
7 xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
8 xsi:schemaLocation="http://www.springframework.org/schema/beans
9 http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
10 http://www.springframework.org/schema/tx
11 http://www.springframework.org/schema/tx/spring-tx-3.0.xsd
12 http://www.springframework.org/schema/aop
13 http://www.springframework.org/schema/aop/spring-aop-3.0.xsd">
14 <!-- 配置数据源-->
15 <bean id="jdbcDataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
16 <property name="driverClassName">
17 <value>org.gjt.mm.mysql.Driver</value>
18 </property>
19 <property name="url">
20 <value>jdbc:mysql://localhost:3306/springmybaitis?useUnicode=true&characterEncoding=UTF-8</value>
21 <!--springmybaitis是我的数据库 -->
22 </property>
23 <property name="username">
24 <value>root</value>
25 </property>
26 <property name="password">
27 <value>123456</value>
28 </property>
29 </bean>
30 <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
31 <property name="dataSource" ref="jdbcDataSource" />
32 <property name="configLocation" value="classpath:mybatis-config.xml"></property>
33 </bean>
34 <bean id="userDao" class="org.mybatis.spring.mapper.MapperFactoryBean">
35 <property name="mapperInterface" value="com.springMyBatis.system.dao.UserDao"></property>
36 <property name="sqlSessionFactory" ref="sqlSessionFactory"></property>
37 </bean>
38 </beans>

5、MyBatis的配置文件------mybatis-config.xml


1 <?xml version="1.0" encoding="UTF-8"?>
2 <!DOCTYPE configuration PUBLIC
3 "-//mybatis.org//DTD Config 3.0//EN"
4 "http://mybatis.org/dtd/mybatis-3-config.dtd">
5 <configuration>
6 <mappers>
7 <mapper resource="com/springMyBatis/system/dao/UserDao.xml"/>
8 </mappers>
9 </configuration>

6、测试
首先测试添加一条数据:

1 package com.springMyBatis.system.test;
2
3 import org.springframework.context.ApplicationContext;
4 import org.springframework.context.support.ClassPathXmlApplicationContext;
5
6 import com.springMyBatis.system.dao.UserDao;
7 import com.springMyBatis.system.model.User;
8
9 public class UserController {
10
11 /**
12 * @param args
13 */
14 public static void main(String[] args) {
15 ApplicationContext ctx=null;
16 ctx=new ClassPathXmlApplicationContext("applicationContext.xml");
17 UserDao userDao=(UserDao) ctx.getBean("userDao");
18 User user=new User();
19 //添加两条数据
20 user.setId(1);
21 user.setUsername("Jessica");
22 user.setPassword("123");
23 userDao.addUser(user);
24 user.setId(2);
25 user.setUsername("Jessica2");
26 user.setPassword("123");
27 userDao.addUser(user);
28 System.out.println("添加成功");
29 //查询数据
30 user.setUsername("Jessica");
31 user.setPassword("123");
32 System.out.println(userDao.getUser(user).toString());
33 user.setUsername("Jessica2");
34 user.setPassword("123");
35 System.out.println(userDao.getUser(user).toString());
36 //修改数据
37 user.setId(2);
38 user.setPassword("802");
39 userDao.updateUser(user);
40 System.out.println("修改成功");
41 //删除数据
42 userDao.deleteUser(1);
43 System.out.println("删除成功");
44
45 }
46
47 }


最后数据库只剩一条数据:

结合Spring和MyBatis很简单,对于一些小一些的项目,想要做到精致易掌控,这两个框架的结合足以。虽然现在Hibernate也很红,但是感觉它内部很神秘,很难配置,也不好优化,就是有种不敢下手的感觉。虽说Hibernate配置有点难,但是搭好了环境后,开发效率还是很高的,只需要配置一下表关系什么的就Ok了。但是比如说查个数据什么的,很难掌控的到细节。Mybatis就可以控制sql的细节,虽然写sql语句比较耗费时间,也需要你的sql基础,但是也正因为这样,使用MyBatis的人的sql水平才会提高啊,看到我们项目经理二三分钟弄出一个看似复杂却又很效率的sql语句,感觉很帅,很牛的样子。这么分析起来,两者皆不可抛,结合学习一下。本文只是简单的实例,在*dao.xml的配置文件里,还有其他帮助优化和简化sql,帮助提高效率的一些知识,有待我们进一步学习呢。还有,也可以通过结合Spring自动扫描装配dao等,也可以为配置文件减轻负担不少,期待下一次更成熟的使用。
Spring和MyBatis环境整合的更多相关文章
- Spring 和 MyBatis 环境整合
本案例主要是讲述Spring 和 MyBatis 的环境整合 , 对页面功能的实现并没有做的很完整 先附上本案例的结构 1 . 创建项目并导入相关jar包 commons-collections4 ...
- idea spring+springmvc+mybatis环境配置整合详解
idea spring+springmvc+mybatis环境配置整合详解 1.配置整合前所需准备的环境: 1.1:jdk1.8 1.2:idea2017.1.5 1.3:Maven 3.5.2 2. ...
- Spring+SpringMVC+MyBatis+easyUI整合优化篇(二)Log4j讲解与整合
日常啰嗦 上一篇文章主要讲述了一下syso和Log间的一些区别与比较,重点是在项目的日志功能上,因此,承接前文<Spring+SpringMVC+MyBatis+easyUI整合优化篇(一)Sy ...
- Spring+SpringMVC+MyBatis+easyUI整合优化篇(五)结合MockMvc进行服务端的单元测试
日常啰嗦 承接前一篇文章<Spring+SpringMVC+MyBatis+easyUI整合优化篇(四)单元测试实例>,已经讲解了dao层和service层的单元测试,还有控制器这层也不能 ...
- Spring+SpringMVC+MyBatis的整合
1.基本概念 1.1.Spring Spring是一个开源框架,Spring是于2003 年兴起的一个轻量级的Java 开发框架,由Rod Johnson 在其著作Expert One-On-On ...
- Spring+SpringMVC+MyBatis+easyUI整合进阶篇(七)一次线上Mysql数据库崩溃事故的记录
作者:13 GitHub:https://github.com/ZHENFENG13 版权声明:本文为原创文章,未经允许不得转载. 文章简介 工作这几年,技术栈在不断更新,项目管理心得也增加了不少,写 ...
- SSM(Spring,SpringMVC,Mybatis)框架整合项目
快速上手SSM(Spring,SpringMVC,Mybatis)框架整合项目 环境要求: IDEA MySQL 8.0.25 Tomcat 9 Maven 3.6 数据库环境: 创建一个存放书籍数据 ...
- 关于Spring和mybatis的整合
Spring同Mybatis的整合 1.引入相应的jar包.(Mybatis的jar包,Spring的jar包,mybatis-spring-1.1.1.jar). 2.编写相应的包(三层的包).搭建 ...
- 基于maven进行spring 和mybatis的整合(Myeclpise)
学习日记:基于maven进行spring和mybatis的整合,进行分页查询 什么是maven:maven是一个项目管理工具,使用maven可以自动管理java项目的整个生命周期,包括编译.构建.测试 ...
随机推荐
- C# DEV--DateEdit长日期
参考博客: DevExpress的DateEdit设置显示日期和时间 this.datBeginTime.Properties.VistaEditTime = DevExpress.Utils.Def ...
- python_字典
1. 字典的定义 字典由多个键及其对应的值构成(我们也把键/值对称为项).键是唯一的,值不唯一.键可以是数字.字符串甚至是元组. 2. 字典的创建 (1) phonebook = {"} 名 ...
- IDisplayTransformation
IDisplayTransformation Bounds Full extent in world coordinates. The Bounds property controls the ful ...
- python故障查找:超时未设置
最近一台基于python的应用服务总是出现问题.需求是用户可以在页面上提交批量处理任务,后台把这些任务入到一个Queue里排队处理,然后通过一个线程专门处理.现在总是偶尔出现假死状态,任务处理中断执行 ...
- UIImageView属性
1.Image 设置图片,默认显示 UIImageView *_imageView = [[UIImageViewalloc]init]; _imageView.image = [UIImag ...
- 【转】Tomcat总体结构(Tomcat源代码阅读系列之二)
本文是Tomcat源代码阅读系列的第二篇文章,我们在本系列的第一篇文章:在IntelliJ IDEA 和 Eclipse运行tomcat 7源代码一文中介绍了如何在intelliJ IDEA 和 Ec ...
- Siverlight去掉ToolTip的白色边框
control作为tooltip后,外框背景是白色的,并且有边框. 我们可以定义 一个样式去掉. <Style x:Key="ToolTipTransparentStyle" ...
- 怎么设置task的最大线程数
//-------------------------------------------------------------------------- // // Copyright (c) Mic ...
- !!常见的上穿突破M20方式——突破还是试探的判断
1和2相似之处在于M5<M20, 最大的区别是M20和M5之间的间距在放大还是缩小,如果是放大,大盘会先试探一下.如果越缩越小,大盘必须选择方向 但是必须注意的是,即使是夹角缩小,选在方向不一定 ...
- 工龄居然这么有用![Reprint]
工龄有多重要?你恐怕未必知道,别以为没啥大不了,事实上,工龄会从各方面影响你的生活 .为了自己的权益,关于工龄的这些事儿,你必须要了解! 1.影响带薪年休假 (1)职工本单位累计工作满1年不满10年的 ...