OSGI企业应用开发(十)整合Spring和Mybatis框架(三)
2017-01-07 19:36
786 查看
上篇文章中,我们已经完成了OSGI应用中Spring和Mybatis框架的整合,本文就来介绍一下,如何在其他Bundle中,使用Mybatis框架来操作数据库。
为了方便演示,我们新建一个新的Plug-in Project工程,名称为com.csdn.osgi.user,表示用户模块。
上篇文章中,我们使用
如果需要在其他Bundle中使用Mybatis框架来操作数据库,则必须將sqlMapService引入,然后注入到DAO对象中。
因此我们需要在com.csdn.osgi.user工程的META-INF目录下新建一个spring目录,然后在该目录下新建一个dmconfig.xml文件用于引用其他Bundle注册的Bean。
dmconfig.xml文件内容如下:
前面文章中已经介绍到,引用其他Bundle发布的Bean,需要用到
接下来我们可以新建一个DAO类,將sqlMapService注入,这样就可以使用SqlSessionTemplate实例操作数据库了。
我们的DAO类名称为com.csdn.osgi.user.UserDao,内容如下:
接着可以在META-INF/spring目录下新建一个user.xml文件,配置一个UserDao 类的实例,并將將sqlMapService注入,user.xml文件内容如下:
工程目录及文件结构如下图所示:
接下来还需要对com.csdn.osgi.user工程中的MANIFEST.MF文件进行修改,添加Bundle依赖,内容如下,其中Require-Bundle元数据头为新增。
UserDao的start()方法会在Bean实例化时调用一次,我们在该方法中,通过SqlSessionTemplate实例的insert()方法往数据库中插入一条数据。
接下来启动OSGI容器,然后查询MySql数据库,会发现每次应用启动,数据库中会新增一条记录,如下图所示:
到此为止OSGI应用中Spring和Mybatis框架的整合已经全部完成了,后续笔者会继续介绍与Spring MVC框架的整合。
为了方便演示,我们新建一个新的Plug-in Project工程,名称为com.csdn.osgi.user,表示用户模块。
上篇文章中,我们使用
<osgi:service/>标签將用于操作数据库的SqlSessionTemplate实例注册为服务,配置如下:
<osgi:service id="sqlMapService" ref="sqlSessionTemplate" interface="org.apache.ibatis.session.SqlSession" />
如果需要在其他Bundle中使用Mybatis框架来操作数据库,则必须將sqlMapService引入,然后注入到DAO对象中。
因此我们需要在com.csdn.osgi.user工程的META-INF目录下新建一个spring目录,然后在该目录下新建一个dmconfig.xml文件用于引用其他Bundle注册的Bean。
dmconfig.xml文件内容如下:
?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:osgix="http://www.springframework.org/schema/osgi-compendium" xmlns:ctx="http://www.springframework.org/schema/context" xmlns:osgi="http://www.eclipse.org/gemini/blueprint/schema/blueprint" xsi:schemaLocation=" http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd http://www.springframework.org/schema/osgi-compendium http://www.springframework.org/schema/osgi-compendium/spring-osgi-compendium.xsd http://www.eclipse.org/gemini/blueprint/schema/blueprint http://www.eclipse.org/gemini/blueprint/schema/blueprint/gemini-blueprint.xsd"> <osgi:reference id="sqlMapService" interface="org.apache.ibatis.session.SqlSession" /> </beans>
前面文章中已经介绍到,引用其他Bundle发布的Bean,需要用到
<osgi:reference/>标签。
接下来我们可以新建一个DAO类,將sqlMapService注入,这样就可以使用SqlSessionTemplate实例操作数据库了。
我们的DAO类名称为com.csdn.osgi.user.UserDao,内容如下:
package com.csdn.osgi.user; import java.util.HashMap; import org.apache.ibatis.session.SqlSession; public class UserDao { SqlSession sqlSession; public SqlSession getSqlSession() { return sqlSession; } public void setSqlSession(SqlSession sqlSession) { this.sqlSession = sqlSession; } public void start(){ System.out.println("UserDao start function..."); HashMap userInfoMap = new HashMap(); userInfoMap.put("UserName", "Jack"); userInfoMap.put("Password", "Jack"); sqlSession.insert("user.saveUser",userInfoMap); } }
接着可以在META-INF/spring目录下新建一个user.xml文件,配置一个UserDao 类的实例,并將將sqlMapService注入,user.xml文件内容如下:
<?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans" 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.xsd"> <bean id="userDao" class="com.csdn.osgi.user.UserDao" init-method="start"> <property name="sqlSession" ref="sqlMapService"></property> </bean> </beans>
工程目录及文件结构如下图所示:
接下来还需要对com.csdn.osgi.user工程中的MANIFEST.MF文件进行修改,添加Bundle依赖,内容如下,其中Require-Bundle元数据头为新增。
Manifest-Version: 1.0 Bundle-ManifestVersion: 2 Bundle-Name: User Bundle-SymbolicName: com.csdn.osgi.user Bundle-Version: 1.0.0.qualifier Bundle-Vendor: CSDN Bundle-RequiredExecutionEnvironment: JavaSE-1.8 Require-Bundle: org.mybatis.mybatis;bundle-version="3.1.1", org.mybatis.mybatis-spring;bundle-version="1.2.3", com.springsource.com.mysql.jdbc;bundle-version="5.1.6", org.springframework.jdbc;bundle-version="3.0.0"
UserDao的start()方法会在Bean实例化时调用一次,我们在该方法中,通过SqlSessionTemplate实例的insert()方法往数据库中插入一条数据。
接下来启动OSGI容器,然后查询MySql数据库,会发现每次应用启动,数据库中会新增一条记录,如下图所示:
到此为止OSGI应用中Spring和Mybatis框架的整合已经全部完成了,后续笔者会继续介绍与Spring MVC框架的整合。
相关文章推荐
- OSGI企业应用开发(十)整合Spring和Mybatis框架(三)
- OSGI企业应用开发(九)整合Spring和Mybatis框架(二)
- OSGI企业应用开发(八)整合Spring和Mybatis框架(一)
- [置顶] OSGI企业应用开发(八)整合Spring和Mybatis框架(一)
- [置顶] OSGI企业应用开发(十)整合Spring和Mybatis框架(三)
- OSGI企业应用开发(九)整合Spring和Mybatis框架(二)
- OSGI企业应用开发(八)整合Spring和Mybatis框架(一)
- [置顶] OSGI企业应用开发(九)整合Spring和Mybatis框架(二)
- OSGI企业应用开发(十)整合Spring和Mybatis框架(三)
- OSGI企业应用开发(九)整合Spring和Mybatis框架(二)
- OSGI企业应用开发(八)整合Spring和Mybatis框架(一)
- OSGI企业应用开发(十四)整合Spring、Mybatis、Spring MVC
- OSGI企业应用开发(十四)整合Spring、Mybatis、Spring MVC
- [置顶] OSGI企业应用开发(十四)整合Spring、Mybatis、Spring MVC
- OSGI企业应用开发(十五)基于Spring、Mybatis、Spring MVC实现一个登录应用
- dwz4j企业级Java Web快速开发框架(Mybatis + SpringMVC) + jUI整合应用
- Spring的声明式事务管理(李刚 轻量级javaEE 企业应用实战-三大框架整合开发)
- OSGI企业应用开发(十五)基于Spring、Mybatis、Spring MVC实现一个登录应用
- [置顶] OSGI企业应用开发(十五)基于Spring、Mybatis、Spring MVC实现一个登录应用
- .NET企业应用开发框架Spring.NET