Mybaits为什么要整合Spring?
说白了其实就想使用Spring提供的服务,比如Spring的事务管理、Spring的IOC对Bean进行管理等。
Mybatis怎么整合Spring?
由于目前Spring官方还没有出整合Mybatis的特性,所以这里在Spring框架和MyBatis框架上再添加用于整合的框架“mybatis-spring-1.0.2.jar” (该框架时MyBatis官方自己出的)。
(1)新建一个Web工程,名称为MybatisSpring。
(2)将Spring3.0.3、Mybatis3.0.6、Mybatis-Spring1.0.2、log4j、Oracle驱动和DBCP连接池的JAR包放到Web工程的lib下面,具体的JAR包如下:
classes12.jar
log4j-1.2.16.jar
mybatis-3.0.6.jar
mybatis-spring-1.0.2.jar
org.springframework.aop-3.0.3.RELEASE.jar
org.springframework.asm-3.0.3.RELEASE.jar
org.springframework.aspects-3.0.3.RELEASE.jar
org.springframework.beans-3.0.3.RELEASE.jar
org.springframework.context-3.0.3.RELEASE.jar
org.springframework.context.support-3.0.3.RELEASE.jar
org.springframework.core-3.0.3.RELEASE.jar
org.springframework.expression-3.0.3.RELEASE.jar
org.springframework.jdbc-3.0.3.RELEASE.jar
org.springframework.transaction-3.0.3.RELEASE.jar
org.springframework.web-3.0.3.RELEASE.jar
commons-logging-1.1.1.jar
commons-dbcp-1.2.jar
commons-pool-1.4.jar
(3)在src下面新建log4j.properties文件,该文件的内容如下:
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern=%d %p [%c] -%m%n
log4j.logger.com.ibatis=debug
log4j.logger.com.ibatis.common.jdbc.SimpleDataSource=debug
log4j.logger.com.ibatis.common.jdbc.ScriptRunner=debug
log4j.logger.com.ibatis.sqlmap.engine.impl.SqlMapClientDelegate=debug
log4j.logger.java.sql.Connection=debug
log4j.logger.java.sql.Statement=debug
log4j.logger.java.sql.PreparedStatement=debug,stdout
(4)在Oracle数据库执行以下SQL,创建一个USER_INFO的表:
-- Create table
create table USER_INFO
(
ID NUMBER(12) not null,
NAME VARCHAR2(50)
);
--Insert data
insert into USER_INFO(ID,NAME) values(1,'张三');
(5)新建一个Java类UserInfo.java,该类的内容如下:
package com.user;
public class UserInfo {
private int id;
private String name;
public UserInfo() {
}
public UserInfo(String name) {
this(0, name);
}
public UserInfo(int id, String name) {
this.id = id;
this.name = name;
}
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
@Override
public String toString() {
return "ID: " + id + ", Name: " + name;
}
}
(6)在com.user.sqlmap下面新建UserInfo.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="User">
<select id="selectUser" parameterType="int" resultType="UserInfo">
<![CDATA[
select * from user_info where id = #{id}
]]>
</select>
</mapper>
(7)在src下面新建mybatis.cfg.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>
<typeAliases>
<typeAlias alias="UserInfo" type="com.user.UserInfo" />
</typeAliases>
<mappers>
<mapper resource="com/user/sqlmap/UserInfo.xml" />
</mappers>
</configuration>
(8)新建一个Java类UserService.java,该类的内容如下:
package com.user;
import org.mybatis.spring.SqlSessionTemplate;
public class UserService {
private SqlSessionTemplate sqlSession;
public SqlSessionTemplate getSqlSession() {
return sqlSession;
}
public void setSqlSession(SqlSessionTemplate sqlSession) {
this.sqlSession = sqlSession;
}
public UserInfo selectUser(){
UserInfo user = null;
try {
user = (UserInfo) sqlSession.selectOne("User.selectUser", "1");
} catch (Exception e) {
e.printStackTrace();
}
return user;
}
}
(9)在src下面新建applicationContext.xml文件,该文件的内容如下:
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
default-autowire="byName"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.0.xsd">
<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource">
<property name="driverClassName" value="oracle.jdbc.OracleDriver" />
<property name="url" value="jdbc:oracle:thin:@localhost:1521:SID" />
<property name="username" value="xxxx" />
<property name="password" value="xxxx" />
<property name="maxActive" value="100"></property>
<property name="maxIdle" value="30"></property>
<property name="maxWait" value="500"></property>
<property name="defaultAutoCommit" value="true"></property>
</bean>
<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
<property name="configLocation" value="classpath:mybatis.cfg.xml"></property>
<property name="dataSource" ref="dataSource" />
</bean>
<bean id="sqlSessionTemplate" class="org.mybatis.spring.SqlSessionTemplate">
<constructor-arg index="0" ref="sqlSessionFactory" />
</bean>
<bean id="userService" class="com.user.UserService">
<property name="sqlSession" ref="sqlSessionTemplate" />
</bean>
</beans>
(10)新建一个测试Java类UserInfoTest.java,该类的具体内容如下:
package com.user;
import java.io.IOException;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;
public class UserInfoTest {
/**
* @param args
* @throws IOException
*/
public static void main(String[] args) throws IOException {
ApplicationContext context = new ClassPathXmlApplicationContext("applicationContext.xml");
UserService userService = (UserService)context.getBean("userService");
UserInfo userInfo = userService.selectUser();
System.out.println(userInfo);
}
}
(11)右键UserInfoTest 类,选择Run As Application,运行MyBaits操作数据库。
log4j:WARN No appenders could be found for logger (org.springframework.context.support.ClassPathXmlApplicationContext).
log4j:WARN Please initialize the log4j system properly.
log4j:WARN See http://logging.apache.org/log4j/1.2/faq.html#noconfig for more info.
2012-02-11 21:13:42,156 DEBUG [java.sql.PreparedStatement] -==> Executing: select * from user_info where id = ?
2012-02-11 21:13:42,156 DEBUG [java.sql.PreparedStatement] -==> Parameters: 1(String)
ID: 1, Name: 张三
分享到:
相关推荐
MyBatis和Spring整合jar: mybatis-3.2.7.jar mybatis-spring-1.2.2.jar
mybatis 所需jar包,版本为 mybatis-3.4.5.jar 整合spring、mybatis使用,整合spring、mybatis使用,整合spring、mybatis使用。
项目名称:商品信息显示系统 使用技术:Springmvc+spring+mybatis+Layui 实现功能: 1、完成ssm+layui的搭建整合 2、完成商品的分页展示 特点:将后台mysql数据显示在layui页面上
mybatis与spring整合时所依赖的jar包,包括: 1.Mybatis所需的jar包括: ant-1.9.6.jar ant-launcher-1.9.6.jar asm-5.2.jar cglib-3.2.5.jar commons-logging-1.2.jar javassist-3.22.0-CR2.jar log4j-...
spring_mybatis 整合jar包,基本常用jar包的整合,。。。。。。。。。。。。。。。
官方mybatis整合spring例子官方mybatis整合spring例子官方mybatis整合spring例子官方mybatis整合spring例子官方mybatis整合spring例子
该压缩包包含了mybatis与spring整合的全部jar包,为学习整合ssm框架提供一个环境
mybatis与spring整合全部jar包(包括springmvc)
spring整合Mybatis纯净项目,基础搭建,下载就用,包含整套源码,jar包
mybatis-spring 整合jar包,Spring和MyBatis环境整合mybatis-spring-1.1.1
SpringMVC学习(四)——Spring、MyBatis和SpringMVC的整合
如何实现spring3.0.5与mybatis3.0.5的整合。 如何实现spring3.0.5与Stripes1.5.6(类似Struts框架)的整合。 如何使用mybatis3.0.5框架。 压缩包说明: 文件解压后有mybatis(可直接导入eclipse运行的项目)和mybatis-...
spring cloud整合mybatis,spring cloud整合mybatis,spring cloud整合mybatis
Spring+Mybatis+Spring MVC的全部jar包,可以用于练习测试;
Spring-Mybatis整合包含基本的增删改查简单易懂!
mybatis和spring整合jar包
struts2_mybatis_spring_框架整合实例_数据库 源码中包括数据库文件 文档介绍
学习完mybatis,与spring,springMVC整合做的一个完整案例,简单易懂
spring3.2.6 struts2.3.15 MyBatis3整合DEMO,数据库:http://dr-yanglong.iteye.com/blog/1989484
在Spring Boot中,可以通过整合MyBatis和JPA来与数据库进行交互。以下是分别整合MyBatis和JPA的步骤: 整合MyBatis: 1. 添加依赖: 在项目的 pom.xml 文件中添加MyBatis和MySQL依赖 2.配置数据源: 在 application....