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项目的整个生命周期,包括编译.构建.测试 ...
随机推荐
- 敏捷BI——岂止于快
信息爆炸的时代,唯有分析快,才可以把握住可能分分钟流失的数据信息,唯有钻取深,才可以挖掘出海量信息中蕴藏的财富.是时候为您的企业上一套敏捷BI了. [敏捷BI的产生背景] 传统BI由IT人员做报表,业 ...
- MVC项目实践,在三层架构下实现SportsStore-06,实现购物车
SportsStore是<精通ASP.NET MVC3框架(第三版)>中演示的MVC项目,在该项目中涵盖了MVC的众多方面,包括:使用DI容器.URL优化.导航.分页.购物车.订单.产品管 ...
- MongoDB概念解析
数据库 MongoDB默认把_id设置为主键(_开头的键是保留的) 数据库名必须为小写 RDBMS与MongoDB对应的术语比较 需注意 文档中的键/值对是有序的. 文档中的值不仅可以是在双引号里面的 ...
- HTML canvas font 属性
定义和用法 font 属性设置或返回画布上文本内容的当前字体属性. font 属性使用的语法与 CSS font 属性 相同. 默认值: 10px sans-serif JavaScript 语法: ...
- Virtual Box 增加虚拟硬盘容量
情景: 我现在用 Win10, 因为项目原因要在虚拟机装一个 Win7. 预先估计不足. Win7 C盘容量不够. 方法1: 增加虚拟硬盘文件. 首先把虚拟机 Win7 删掉 (但不要删虚拟硬盘文件, ...
- asp.net 登陆验证 Form表单验证的3种方式 FormsAuthentication.SetAuthCookie;FormsAuthentication.RedirectFromLoginPage;FormsAuthenticationTicket
我们在登陆成功后,使用下面的3种方法,都是同一个目的:创建身份验证票并将其附加到 Cookie, 当我们用Forms认证方式的时候,可以使用HttpContext.Current.User.Ident ...
- Orthomcl的详细使用
参考了众多文章并结合实际操作后的感想. 参考:http://www.plob.org/2013/09/18/6174.html 参考:http://www.plob.org/2012/06/12/22 ...
- codeforces343A A. Rational Resistance
http://http://codeforces.com/problemset/problem/343/A A. Rational Resistance time limit per test 1 s ...
- javascript 判断浏览器的ie版本,替换html标签
/* var browser=navigator.appName var b_version=navigator.appVersion var version=b_version.split(&quo ...
- C++之路起航——标准模板库(queue)
queue: FIFO队列:先进先出队列. 优先队列:对队列中的元素按优先级的大小输出. 定义: FIFO队列: queue<数据类性>变量名. 优先队列:priority_queue&l ...