用Eclipse 或 netBeans IDE工具开发,新建一个 Java Application.
将所需的jar 引入项目。
把几个属性文件放在源包下面。
第一步,编写日志配置文件 commons-logging.properties 和 log4j.properties。
第二步,编写一个关于 jdbc 的 属性文件,如 jdbc.properties。其实,这个文件不是必需的。也可以写在Spring的XML文件中,后面会理解它的用途。
第三步,编定Spring的XML配置。
在Spring的XML中,要完成以下几个功能:
1. 定义一个 dataSource 数据库连接池
2. 定义一个 sqlSessionFactory。
如果是 WEB 应用,还应定义一个事务管理器 dataSourceTransactionManager。
那么 SpringConfig.xml 内容如下:
从上面的 SpringConfig中看到,jdbc.properties被Spring容器读取后,作为参数赋于dataSrouce ,那也就是说,没有jdbc.properties,可以直接在XML写值。
而这个dataSource是由dbcp的BasicDataSource实现的。
继续看接下来的配置,sqlSessionFactory,它必须要有dataSource数据库连接池属性。
在例子中,使用的是configLocation。
实际上,通过 mybatis-generator生成XML,放在统一的位置,使用mapperLocations则更加方便,而不需要编写一个有关Mybatis的Mappers文件。
第四步,编写 MybatisConfig.xml,设置别名,定义参数, Mappeers。
上面这个 MybatisConfig非常简单,相比典型的文件省略很多内容,只是定义了一个别名。
列了两张表的Mapper,没有其它。如果在 Mapper文件中没有引用别名,可以把typeAliases无素也删除了。
如果数据表很多,而编写Mappers 元素也有可能出错。所以说,属性mapperLocations更加合理方便。
前面四个步骤,完成了 几个配置文件的编写。接下来需要做的是针对表的Mapper和POJO类的开发。
第五步,编写POJO 类。
Pojo类的代码不再细述,只要 javaType 和 JDBCType 是对应的,数据表的列名与POJO属性名既可以相同,也可以不同, 不列举代码了。
第六步,编写 ****Mapper.xml
resultMap 是实现列名与属性的对应关系,这里只是最简单的示例,你可以在Reference文档中看到更复杂更加大的功能。
其它的select , insert等,是相关的SQL语句,不做过多解释。parameterType是传入的参数,resultMap和resultType是返回值的类型,如果SELECT 别名与 POJO 属性名相同,那么就可以使用 resultType ,进行自动映射转换。
#{}代表的是相应的参数,相当于 JDBC SQL 参数的 ? 。
这样,是不是可以结束了,开始测试了? 当然可以!也可以作进一步的封装。
先来测试一下吧。为方便起见,先写一个静态工具,用来获取SqlSession
现在可以来测试了,很简单。这里得到SqlSession后,通过Mybatis得到了Org_Type 的一个对象,又通过update更新了数据表。最后关闭连接,准确地说是释放连接,连接的打开关闭由dbcp连接池管理。
来看其中的"aps.tables.org_type.selectByID","aps.tables.org_type.update",这正是Mapper.xml 文件中 namespace和数据操作 id 的 连接,这就指定了唯一的SQL语句,而后面的对象,就是参数 parameterType。
细细地可以发现,在 Mapper.xml 文件中,insert,update,delete都没有 resultType ,因为它们最终返回的都是int,是语句执行后影响的数据行。
如果 update 或 delete 执行成功,但返回的是 0,那实际上就是一条数据也没有修改或删除。
如果,你想自己直接操作JDBC,也很简单:
Statement stmt=sess.getConnection().createStatement();
stmt.execute......
初步入门完成。
将所需的jar 引入项目。
把几个属性文件放在源包下面。
第一步,编写日志配置文件 commons-logging.properties 和 log4j.properties。
第二步,编写一个关于 jdbc 的 属性文件,如 jdbc.properties。其实,这个文件不是必需的。也可以写在Spring的XML文件中,后面会理解它的用途。
第三步,编定Spring的XML配置。
在Spring的XML中,要完成以下几个功能:
1. 定义一个 dataSource 数据库连接池
2. 定义一个 sqlSessionFactory。
如果是 WEB 应用,还应定义一个事务管理器 dataSourceTransactionManager。
那么 SpringConfig.xml 内容如下:
<beans...... ......> <bean id="propertyPlaceholder" class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer"> <property name="location" value="jdbc.properties" /> </bean> <!-- 定义一个 datasource 数据库连接池,这里使用了Apache DBCP,需要 commons-dbcp和commons-pool的包支持 --> <!-- 这里的${...},引用了 jdbc.properties中的内容,使用户不需要查找XML文件中有关JDBC的配置片段 --> <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" > <property name="driverClassName" value="${jdbc.driver}" /> <property name="url"> <value>${jdbc.url}</value> </property> <property name="username"> <value>${jdbc.user}</value> </property> <property name="password"> <value>${jdbc.password}</value> </property> <property name="maxActive" value="2" /> <property name="initialSize" value="1" /> <property name="maxIdle" value="2" /> <property name="minIdle" value="1" /> <!-- 等待连接超时时间,30秒 --> <property name="maxWait" value="30000" /> </bean> <!-- 使用指定的 dataSource 创建 SqlSessionFactory,并且指定Mybatis的配置文件, 同时,MyBatis中的Enviroment 配置段在容器中不会生效,使用指定的 dataSource。 --> <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean"> <property name="dataSource" ref="dataSource" /> <!-- mapperLocations和configLocation有一个即可, 如果Mapper.xml 中使用了 typeAliases 的别名,则可以使用 configLocation,否则可任选其一 --> <!-- 指定实体类映射文件,可以指定同时指定某一包以及子包下面的所有配置文件 --> <!-- <property name="mapperLocations" value="classpath*:.../*.xml"/> --> <property name="configLocation" value="classpath:SqlMapConfig.xml" /> </bean> <!-- 定义一个事务管理器 --> <bean id="dataSourceTransactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager"> <property name="dataSource" ref="dataSource" /> </bean> </beans>
从上面的 SpringConfig中看到,jdbc.properties被Spring容器读取后,作为参数赋于dataSrouce ,那也就是说,没有jdbc.properties,可以直接在XML写值。
而这个dataSource是由dbcp的BasicDataSource实现的。
继续看接下来的配置,sqlSessionFactory,它必须要有dataSource数据库连接池属性。
在例子中,使用的是configLocation。
实际上,通过 mybatis-generator生成XML,放在统一的位置,使用mapperLocations则更加方便,而不需要编写一个有关Mybatis的Mappers文件。
第四步,编写 MybatisConfig.xml,设置别名,定义参数, Mappeers。
<configuration> <typeAliases> <typeAlias alias="OrgType" type="MybatisTest.domain.Org_Type" /> </typeAliases> <mappers> <mapper resource="MybatisTest/domain/OrgTypeMapper.xml" /> <mapper resource="MybatisTest/domain/NtAcctinfoMapper.xml" /> </mappers> </configuration>
上面这个 MybatisConfig非常简单,相比典型的文件省略很多内容,只是定义了一个别名。
列了两张表的Mapper,没有其它。如果在 Mapper文件中没有引用别名,可以把typeAliases无素也删除了。
如果数据表很多,而编写Mappers 元素也有可能出错。所以说,属性mapperLocations更加合理方便。
前面四个步骤,完成了 几个配置文件的编写。接下来需要做的是针对表的Mapper和POJO类的开发。
第五步,编写POJO 类。
Pojo类的代码不再细述,只要 javaType 和 JDBCType 是对应的,数据表的列名与POJO属性名既可以相同,也可以不同, 不列举代码了。
第六步,编写 ****Mapper.xml
<mapper namespace="aps.tables.org_type"> <resultMap id="orgTyperesult" type="MybatisTest.domain.Org_Type"> <id column="ID" property="id" /> <result column="TYPE_CODE" property="typecode" /> <result column="TYPE_NO" property="typeno" /> <result column="TYPE_VALUE" property="typevalue" /> <result column="NOTES" property="typenotes" /> </resultMap> <select id="selectByID" parameterType="int" resultMap="orgTyperesult"> select ID, TYPE_CODE, TYPE_NO, TYPE_VALUE, NOTES from dbo.T_TYPE_ENUM where ID=#{id} </select> <delete id="delete" parameterType="int"> delete from T_TYPE_ENUM where ID=#{id} </delete> <update id="update" parameterType="OrgType" > update dbo.T_TYPE_ENUM set TYPE_CODE=#{typecode}, TYPE_NO=#{typeno}, TYPE_VALUE=#{typevalue}, NOTES=#{typenotes} where ID=#{id} </update> <insert id="insert" parameterType="MybatisTest.domain.Org_Type" > insert into dbo.T_TYPE_ENUM ( ID,TYPE_CODE, TYPE_NO, TYPE_VALUE, NOTES) values ( #{id}, #{typecode},#{typeno}, #{typevalue},#{typenotes}) </insert> </mapper>
resultMap 是实现列名与属性的对应关系,这里只是最简单的示例,你可以在Reference文档中看到更复杂更加大的功能。
其它的select , insert等,是相关的SQL语句,不做过多解释。parameterType是传入的参数,resultMap和resultType是返回值的类型,如果SELECT 别名与 POJO 属性名相同,那么就可以使用 resultType ,进行自动映射转换。
#{}代表的是相应的参数,相当于 JDBC SQL 参数的 ? 。
这样,是不是可以结束了,开始测试了? 当然可以!也可以作进一步的封装。
先来测试一下吧。为方便起见,先写一个静态工具,用来获取SqlSession
public class MybatisUtil { private static SqlSessionFactory factory; static{ ApplicationContext ctx=new ClassPathXmlApplicationContext("classpath:SpringConfig.xml"); factory=(SqlSessionFactory) ctx.getBean("sqlSessionFactory"); } public static SqlSession getSession(){ return factory.openSession(); } public static SqlSessionFactory getSessionFactory(){ return factory; } }
现在可以来测试了,很简单。这里得到SqlSession后,通过Mybatis得到了Org_Type 的一个对象,又通过update更新了数据表。最后关闭连接,准确地说是释放连接,连接的打开关闭由dbcp连接池管理。
SqlSession sess=MybatisUtil.getSession(); Org_Type org=sess.selectOne("aps.tables.org_type.selectByID",20); System.out.println(sess.update("aps.tables.org_type.update", org)); sess.close();
来看其中的"aps.tables.org_type.selectByID","aps.tables.org_type.update",这正是Mapper.xml 文件中 namespace和数据操作 id 的 连接,这就指定了唯一的SQL语句,而后面的对象,就是参数 parameterType。
细细地可以发现,在 Mapper.xml 文件中,insert,update,delete都没有 resultType ,因为它们最终返回的都是int,是语句执行后影响的数据行。
如果 update 或 delete 执行成功,但返回的是 0,那实际上就是一条数据也没有修改或删除。
如果,你想自己直接操作JDBC,也很简单:
Statement stmt=sess.getConnection().createStatement();
stmt.execute......
初步入门完成。
发表评论
-
Mybatis基础学习一
2016-01-18 15:35 596Mybatis,是一个轻量级的ORM产品,比较适合中小型项目, ... -
Java的国际化例子
2012-10-09 12:25 2090PropertyResourceBundle bundle ; ... -
Struts2,Mybatis与Spring事务管理的集成
2012-09-28 21:42 3136刚接触Struts2和Spring。Spring的事务管理可以 ... -
Hibernate与Mybatis 的比较
2012-09-26 16:00 4970Hibernate与MyBatis都是ORM工具,实现解放程序 ... -
MyBatis与Spring、commons-dbcp的集成开发(四)
2012-09-26 15:42 1184如何使用mybatis-generator? 非常简单! 编写 ... -
MyBatis与Spring、commons-dbcp的集成开发(三)
2012-09-26 14:32 1269通过 Mapper.xml中的 SQL 操作的 id 来操作 ... -
MyBatis与Spring、commons-dbcp的集成开发(一)
2012-09-26 12:59 2355近段时间,在学习如何使用Mybatis。 记录最近学习的内容。 ... -
JAXB 的List 的解析与转换POJO
2012-09-20 15:30 1799如果,有如下一个POJO类。 @XmlRootElemen ... -
JAXB解析xml 的XML声明
2012-09-20 14:57 19182转自:http://hanhongke123.blog.163 ... -
JAXB的XML与POJO类的简单转换
2012-09-20 14:18 7541在解析XML时候,最方便的方法就属 JAXB了。 它可以将一个 ...
相关推荐
spring-webmvc-5.2.6.RELEASE.jar、spring-web-5.2.6.RELEASE.jar、spring-jdbc-5.2.6.RELEASE.jar、mysql-connector-java-5.1.37-bin.jar、mybatis-spring-1.3.1.jar、commons-dbcp2-2.4.0.jar 、commons-pool2-...
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-...
commons-collections-3.1.jar、commons-dbcp.jar、commons-pool.jar、mybatis-3.2.2.jar、mybatis-spring-1.1.1.jar
commons-dbcp-1.2.2.jar,commons-logging-1.1.1.jar,commons-pool-1.3.jar,javassist-3.17.1-GA.jar,jstl-1.2.jar,junit-4.9.jar,log4j-1.2.17.jar,log4j-api-2.0-rc1.jar,log4j-core-2.0-rc1.jar,mybatis-...
3.3.1/aspectjweaver-1.6.11/cglib-2.2.2/commons-dbcp-1.2.2/commons-logging-1.1.1/commons-pool-1.3/javassist-3.17.1-GA/jstl-1.2/junit-4.9/log4j-1.2.17/log4j-api-2.0-rc1/log4j-core-2.0-rc1/mybatis-...
SSM(Spring、SpringMVC、MyBatis)框架整合是Java开发中常见的技术栈,主要用于构建企业级的Web应用程序。在这个压缩包中,我们找到了整合MyBatis和Spring所需的全部jar包,这对于初学者或者开发者搭建项目环境非常...
commons-dbcp-1.1 commons-logging-1.1.3 commons-pool-1.6 mybatis-3.2.0-SNAPSHOT mybatis-spring-1.1.1 mysql-connector-java-5.1.27 org.springframework.aop-3.1.1.RELEASE org.springframework.asm-3.1.1....
3. **配置DataSource**:SqlSessionFactory需要数据源(DataSource),所以在Spring配置中也需要定义数据源,可以使用Apache的Commons DBCP或者Tomcat的JNDI数据源等。 4. **Mapper配置**:MyBatis的Mapper接口和...
commons-collections-3.2.1 commons-dbcp-1.1 commons-logging-1.1.3 commons-pool-1.6 mybatis-3.2.0-SNAPSHOT mybatis-spring-1.1.1 mysql-connector-java-5.1.27 org.springframework.aop-3.1.1.RELEASE org....
《深入浅出MyBatis技术原理与实战》一书中的第8章,主要探讨的是MyBatis与Spring的集成,特别是在mybatis-spring版本1.2.3中的具体实践。这个章节是理解如何在实际项目中高效、稳定地结合这两个流行框架的关键。...
在Java开发领域,MyBatis和Spring框架的...总之,"mybatis与spring整合依赖包集"为开发者提供了构建MyBatis-Spring整合项目的必要组件,涵盖了数据源、缓存和基础框架的集成,极大地简化了开发过程,提高了开发效率。
- `mybatis-spring-1.x.x.jar`: 这是MyBatis与Spring的适配器,提供了Spring环境下的事务管理、SqlSession工厂和Mapper工厂等功能,使得MyBatis能够无缝集成到Spring应用中。 2. Spring核心Jar包: - `spring-...
│ commons-dbcp-1.2.2.jar │ commons-fileupload-1.2.1.jar │ commons-logging-1.0.4.jar │ commons-logging.jar │ commons-pool.jar │ dom4j-1.6.1.jar │ freemarker-2.3.15.jar │ freemarker.jar │ ...
"mybatis--Spring集成nybatis.rar"这个压缩包文件很可能是为了教授如何将MyBatis ORM框架与Spring框架结合使用的教程。Struts2、Spring和MyBatis是Java Web开发中的三大核心技术,它们各自负责不同的职责:Struts2...
commons-dbcp-1.1 commons-logging-1.1.3 commons-pool-1.6 mybatis-3.2.0-SNAPSHOT mybatis-spring-1.1.1 mysql-connector-java-5.1.27 org.springframework.aop-3.1.1.RELEASE org.springframework.asm-3.1.1....
spring_mvc和mybatis_jar包: spring-context-4.3.2.RELEASE.jar spring-aop-4.3.2.RELEASE.jar spring-beans-4.3.2.RELEASE.jar spring-core-4.3.2.RELEASE.jar ...commons-dbcp-1.4.jar commons-pool-1.6.jar
此包解决了Spring3.0不直接支持MyBatis3.0的问题,提供了如SqlSessionFactoryBean、MapperFactoryBean等类,简化了MyBatis与Spring的集成。 **4. 数据源支持** Commons-dbcp和Commons-pool是Spring数据源支持的...
commons-dbcp-1.4.jar commons-email-1.4.jar commons-fileupload-1.3.1.jar commons-io-2.4.jar commons-lang3-3.3.2.jar commons-logging-1.0.4.jar commons-pool-1.5.4.jar commons-pool2-2.0.jar core-2.2.jar ...
总的来说,Spring与MyBatis的整合提供了高效、灵活的数据库操作方式,降低了开发难度,提高了项目的可维护性。这份"mybatis-spring-chinese.pdf"文档将详细介绍这些内容,帮助开发者更好地理解和运用这一组合。
commons-dbcp-1.2.2.jar commons-fileupload-1.3.1.jar commons-io-2.2.jar commons-logging-1.1.1.jar commons-pool-1.3.jar ehcache-core-2.6.5.jar hibernate-validator-4.3.0.Final.jar jackson-core-asl-1.8.8....